2003-08-13 01:53:07 +00:00
/*
Unix SMB / CIFS implementation .
SMB parameters and setup
Copyright ( C ) Andrew Tridgell 1992 - 1998
Modified by Jeremy Allison 1995.
Copyright ( C ) Jeremy Allison 1995 - 2000.
Copyright ( C ) Luke Kennethc Casson Leighton 1996 - 2000.
Copyright ( C ) Andrew Bartlett < abartlet @ samba . org > 2002 - 2003
This program is free software ; you can redistribute it and / or modify
it under the terms of the GNU General Public License as published by
the Free Software Foundation ; either version 2 of the License , or
( at your option ) any later version .
This program is distributed in the hope that it will be useful ,
but WITHOUT ANY WARRANTY ; without even the implied warranty of
MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE . See the
GNU General Public License for more details .
You should have received a copy of the GNU General Public License
along with this program ; if not , write to the Free Software
Foundation , Inc . , 675 Mass Ave , Cambridge , MA 0213 9 , USA .
*/
# include "includes.h"
# include "byteorder.h"
/*
This implements the X / Open SMB password encryption
It takes a password ( ' unix ' string ) , a 8 byte " crypt key "
2004-05-02 08:45:00 +00:00
and puts 24 bytes of encrypted password into p24
Returns False if password must have been truncated to create LM hash
*/
2004-06-01 08:30:34 +00:00
BOOL SMBencrypt ( const char * passwd , const uint8_t * c8 , uint8_t p24 [ 24 ] )
2003-08-13 01:53:07 +00:00
{
2004-05-02 08:45:00 +00:00
BOOL ret ;
2004-06-01 08:30:34 +00:00
uint8_t p21 [ 21 ] ;
2003-08-13 01:53:07 +00:00
memset ( p21 , ' \0 ' , 21 ) ;
2004-05-02 08:45:00 +00:00
ret = E_deshash ( passwd , p21 ) ;
2003-08-13 01:53:07 +00:00
SMBOWFencrypt ( p21 , c8 , p24 ) ;
# ifdef DEBUG_PASSWORD
DEBUG ( 100 , ( " SMBencrypt: lm#, challenge, response \n " ) ) ;
dump_data ( 100 , ( char * ) p21 , 16 ) ;
dump_data ( 100 , ( const char * ) c8 , 8 ) ;
dump_data ( 100 , ( char * ) p24 , 24 ) ;
# endif
2004-05-02 08:45:00 +00:00
return ret ;
2003-08-13 01:53:07 +00:00
}
/**
* Creates the MD4 Hash of the users password in NT UNICODE .
* @ param passwd password in ' unix ' charset .
* @ param p16 return password hashed with md4 , caller allocated 16 byte buffer
*/
2004-06-01 08:30:34 +00:00
void E_md4hash ( const char * passwd , uint8_t p16 [ 16 ] )
2003-08-13 01:53:07 +00:00
{
int len ;
smb_ucs2_t wpwd [ 129 ] ;
/* Password must be converted to NT unicode - null terminated. */
push_ucs2 ( NULL , wpwd , ( const char * ) passwd , 256 , STR_UNICODE | STR_NOALIGN | STR_TERMINATE ) ;
/* Calculate length in bytes */
2004-05-25 17:24:24 +00:00
len = strlen_w ( wpwd ) * sizeof ( int16_t ) ;
2003-08-13 01:53:07 +00:00
2004-05-29 08:11:46 +00:00
mdfour ( p16 , ( uint8_t * ) wpwd , len ) ;
2003-08-13 01:53:07 +00:00
ZERO_STRUCT ( wpwd ) ;
}
/**
* Creates the DES forward - only Hash of the users password in DOS ASCII charset
* @ param passwd password in ' unix ' charset .
* @ param p16 return password hashed with DES , caller allocated 16 byte buffer
2004-05-02 08:45:00 +00:00
* @ return False if password was > 14 characters , and therefore may be incorrect , otherwise True
* @ note p16 is filled in regardless
2003-08-13 01:53:07 +00:00
*/
2004-06-01 08:30:34 +00:00
BOOL E_deshash ( const char * passwd , uint8_t p16 [ 16 ] )
2003-08-13 01:53:07 +00:00
{
2004-05-02 08:45:00 +00:00
BOOL ret = True ;
2003-08-13 01:53:07 +00:00
fstring dospwd ;
ZERO_STRUCT ( dospwd ) ;
/* Password must be converted to DOS charset - null terminated, uppercase. */
2003-11-26 01:16:41 +00:00
push_ascii ( dospwd , passwd , sizeof ( dospwd ) , STR_UPPER | STR_TERMINATE ) ;
2004-05-02 08:45:00 +00:00
2003-08-13 01:53:07 +00:00
/* Only the fisrt 14 chars are considered, password need not be null terminated. */
2004-05-29 08:11:46 +00:00
E_P16 ( ( const uint8_t * ) dospwd , p16 ) ;
2003-08-13 01:53:07 +00:00
2004-05-02 08:45:00 +00:00
if ( strlen ( dospwd ) > 14 ) {
ret = False ;
}
2003-08-13 01:53:07 +00:00
ZERO_STRUCT ( dospwd ) ;
2004-05-02 08:45:00 +00:00
return ret ;
2003-08-13 01:53:07 +00:00
}
/* Does both the NTLMv2 owfs of a user's password */
2004-06-01 08:30:34 +00:00
BOOL ntv2_owf_gen ( const uint8_t owf [ 16 ] ,
2004-05-02 08:45:00 +00:00
const char * user_in , const char * domain_in ,
BOOL upper_case_domain , /* Transform the domain into UPPER case */
2004-06-01 08:30:34 +00:00
uint8_t kr_buf [ 16 ] )
2003-08-13 01:53:07 +00:00
{
smb_ucs2_t * user ;
smb_ucs2_t * domain ;
size_t user_byte_len ;
size_t domain_byte_len ;
HMACMD5Context ctx ;
user_byte_len = push_ucs2_allocate ( & user , user_in ) ;
if ( user_byte_len = = ( size_t ) - 1 ) {
DEBUG ( 0 , ( " push_uss2_allocate() for user returned -1 (probably malloc() failure) \n " ) ) ;
return False ;
}
domain_byte_len = push_ucs2_allocate ( & domain , domain_in ) ;
if ( domain_byte_len = = ( size_t ) - 1 ) {
DEBUG ( 0 , ( " push_uss2_allocate() for domain returned -1 (probably malloc() failure) \n " ) ) ;
return False ;
}
strupper_w ( user ) ;
2004-05-02 08:45:00 +00:00
if ( upper_case_domain )
strupper_w ( domain ) ;
2003-08-13 01:53:07 +00:00
SMB_ASSERT ( user_byte_len > = 2 ) ;
SMB_ASSERT ( domain_byte_len > = 2 ) ;
/* We don't want null termination */
user_byte_len = user_byte_len - 2 ;
domain_byte_len = domain_byte_len - 2 ;
hmac_md5_init_limK_to_64 ( owf , 16 , & ctx ) ;
2004-05-29 08:11:46 +00:00
hmac_md5_update ( ( const uint8_t * ) user , user_byte_len , & ctx ) ;
hmac_md5_update ( ( const uint8_t * ) domain , domain_byte_len , & ctx ) ;
2003-08-13 01:53:07 +00:00
hmac_md5_final ( kr_buf , & ctx ) ;
# ifdef DEBUG_PASSWORD
DEBUG ( 100 , ( " ntv2_owf_gen: user, domain, owfkey, kr \n " ) ) ;
dump_data ( 100 , ( const char * ) user , user_byte_len ) ;
dump_data ( 100 , ( const char * ) domain , domain_byte_len ) ;
dump_data ( 100 , owf , 16 ) ;
dump_data ( 100 , kr_buf , 16 ) ;
# endif
SAFE_FREE ( user ) ;
SAFE_FREE ( domain ) ;
return True ;
}
/* Does the des encryption from the NT or LM MD4 hash. */
2004-06-01 08:30:34 +00:00
void SMBOWFencrypt ( const uint8_t passwd [ 16 ] , const uint8_t * c8 , uint8_t p24 [ 24 ] )
2003-08-13 01:53:07 +00:00
{
2004-06-01 08:30:34 +00:00
uint8_t p21 [ 21 ] ;
2003-08-13 01:53:07 +00:00
ZERO_STRUCT ( p21 ) ;
memcpy ( p21 , passwd , 16 ) ;
E_P24 ( p21 , c8 , p24 ) ;
}
/* Does the NT MD4 hash then des encryption. */
2004-06-01 08:30:34 +00:00
void SMBNTencrypt ( const char * passwd , uint8_t * c8 , uint8_t * p24 )
2003-08-13 01:53:07 +00:00
{
2004-06-01 08:30:34 +00:00
uint8_t p21 [ 21 ] ;
2003-08-13 01:53:07 +00:00
memset ( p21 , ' \0 ' , 21 ) ;
E_md4hash ( passwd , p21 ) ;
SMBOWFencrypt ( p21 , c8 , p24 ) ;
# ifdef DEBUG_PASSWORD
DEBUG ( 100 , ( " SMBNTencrypt: nt#, challenge, response \n " ) ) ;
dump_data ( 100 , ( char * ) p21 , 16 ) ;
dump_data ( 100 , ( char * ) c8 , 8 ) ;
dump_data ( 100 , ( char * ) p24 , 24 ) ;
# endif
}
2003-11-26 01:16:41 +00:00
/* Does the md5 encryption from the Key Response for NTLMv2. */
2004-06-01 08:30:34 +00:00
void SMBOWFencrypt_ntv2 ( const uint8_t kr [ 16 ] ,
2003-11-26 01:16:41 +00:00
const DATA_BLOB * srv_chal ,
2004-08-04 13:23:35 +00:00
const DATA_BLOB * smbcli_chal ,
2004-06-01 08:30:34 +00:00
uint8_t resp_buf [ 16 ] )
2003-08-13 01:53:07 +00:00
{
HMACMD5Context ctx ;
hmac_md5_init_limK_to_64 ( kr , 16 , & ctx ) ;
2003-11-26 01:16:41 +00:00
hmac_md5_update ( srv_chal - > data , srv_chal - > length , & ctx ) ;
2004-08-04 13:23:35 +00:00
hmac_md5_update ( smbcli_chal - > data , smbcli_chal - > length , & ctx ) ;
2003-08-13 01:53:07 +00:00
hmac_md5_final ( resp_buf , & ctx ) ;
# ifdef DEBUG_PASSWORD
2004-08-04 13:23:35 +00:00
DEBUG ( 100 , ( " SMBOWFencrypt_ntv2: srv_chal, smbcli_chal, resp_buf \n " ) ) ;
2003-11-26 01:16:41 +00:00
dump_data ( 100 , srv_chal - > data , srv_chal - > length ) ;
2004-08-04 13:23:35 +00:00
dump_data ( 100 , smbcli_chal - > data , smbcli_chal - > length ) ;
2003-08-13 01:53:07 +00:00
dump_data ( 100 , resp_buf , 16 ) ;
# endif
}
2004-06-01 08:30:34 +00:00
void SMBsesskeygen_ntv2 ( const uint8_t kr [ 16 ] ,
const uint8_t * nt_resp , uint8_t sess_key [ 16 ] )
2003-08-13 01:53:07 +00:00
{
2003-11-26 01:16:41 +00:00
/* a very nice, 128 bit, variable session key */
2003-08-13 01:53:07 +00:00
HMACMD5Context ctx ;
hmac_md5_init_limK_to_64 ( kr , 16 , & ctx ) ;
hmac_md5_update ( nt_resp , 16 , & ctx ) ;
2004-05-29 08:11:46 +00:00
hmac_md5_final ( ( uint8_t * ) sess_key , & ctx ) ;
2003-08-13 01:53:07 +00:00
# ifdef DEBUG_PASSWORD
DEBUG ( 100 , ( " SMBsesskeygen_ntv2: \n " ) ) ;
dump_data ( 100 , sess_key , 16 ) ;
# endif
}
2004-06-01 08:30:34 +00:00
void SMBsesskeygen_ntv1 ( const uint8_t kr [ 16 ] , uint8_t sess_key [ 16 ] )
2003-08-13 01:53:07 +00:00
{
2003-11-26 01:16:41 +00:00
/* yes, this session key does not change - yes, this
is a problem - but it is 128 bits */
2004-05-29 08:11:46 +00:00
mdfour ( ( uint8_t * ) sess_key , kr , 16 ) ;
2003-08-13 01:53:07 +00:00
# ifdef DEBUG_PASSWORD
DEBUG ( 100 , ( " SMBsesskeygen_ntv1: \n " ) ) ;
dump_data ( 100 , sess_key , 16 ) ;
# endif
}
2004-06-01 08:30:34 +00:00
void SMBsesskeygen_lm_sess_key ( const uint8_t lm_hash [ 16 ] ,
const uint8_t lm_resp [ 24 ] , /* only uses 8 */
2004-05-25 17:50:17 +00:00
uint8_t sess_key [ 16 ] )
2003-11-26 01:16:41 +00:00
{
/* Calculate the LM session key (effective length 40 bits,
but changes with each session ) */
2004-06-01 08:30:34 +00:00
uint8_t p24 [ 24 ] ;
uint8_t p21 [ 21 ] ;
2004-05-02 12:42:01 +00:00
memset ( p21 , ' \0 ' , 21 ) ;
memcpy ( p21 , lm_hash , 8 ) ;
memset ( p21 + 8 , 0xbd , 8 ) ;
2003-11-26 01:16:41 +00:00
2004-05-02 12:42:01 +00:00
E_P24 ( p21 , lm_resp , p24 ) ;
2004-05-02 08:45:00 +00:00
memcpy ( sess_key , p24 , 16 ) ;
# ifdef DEBUG_PASSWORD
2004-05-02 12:42:01 +00:00
DEBUG ( 100 , ( " SMBsesskeygen_lm_sess_key: \n " ) ) ;
2004-05-02 08:45:00 +00:00
dump_data ( 100 , sess_key , 16 ) ;
# endif
}
2004-05-25 14:06:28 +00:00
DATA_BLOB NTLMv2_generate_names_blob ( TALLOC_CTX * mem_ctx ,
const char * hostname ,
2003-11-26 01:16:41 +00:00
const char * domain )
{
2004-05-25 14:06:28 +00:00
DATA_BLOB names_blob = data_blob_talloc ( mem_ctx , NULL , 0 ) ;
2003-11-26 01:16:41 +00:00
2004-06-28 06:46:27 +00:00
msrpc_gen ( mem_ctx , & names_blob , " aaa " ,
NTLMSSP_NAME_TYPE_DOMAIN , domain ,
NTLMSSP_NAME_TYPE_SERVER , hostname ,
0 , " " ) ;
2003-11-26 01:16:41 +00:00
return names_blob ;
}
2004-05-25 14:06:28 +00:00
static DATA_BLOB NTLMv2_generate_client_data ( TALLOC_CTX * mem_ctx , const DATA_BLOB * names_blob )
2003-11-26 01:16:41 +00:00
{
2004-06-01 08:30:34 +00:00
uint8_t client_chal [ 8 ] ;
2003-11-26 01:16:41 +00:00
DATA_BLOB response = data_blob ( NULL , 0 ) ;
char long_date [ 8 ] ;
2004-04-10 20:18:22 +00:00
NTTIME nttime ;
unix_to_nt_time ( & nttime , time ( NULL ) ) ;
2003-11-26 01:16:41 +00:00
2004-07-14 12:14:07 +00:00
generate_random_buffer ( client_chal , sizeof ( client_chal ) ) ;
2003-11-26 01:16:41 +00:00
2004-05-25 13:57:39 +00:00
push_nttime ( long_date , 0 , nttime ) ;
2003-11-26 01:16:41 +00:00
/* See http://www.ubiqx.org/cifs/SMB.html#SMB.8.5 */
2004-06-28 06:46:27 +00:00
msrpc_gen ( mem_ctx , & response , " ddbbdb " ,
0x00000101 , /* Header */
0 , /* 'Reserved' */
long_date , 8 , /* Timestamp */
client_chal , 8 , /* client challenge */
0 , /* Unknown */
names_blob - > data , names_blob - > length ) ; /* End of name list */
2003-11-26 01:16:41 +00:00
return response ;
}
2004-06-01 08:30:34 +00:00
static DATA_BLOB NTLMv2_generate_response ( const uint8_t ntlm_v2_hash [ 16 ] ,
2003-11-26 01:16:41 +00:00
const DATA_BLOB * server_chal ,
const DATA_BLOB * names_blob )
2003-08-13 01:53:07 +00:00
{
2004-06-01 08:30:34 +00:00
uint8_t ntlmv2_response [ 16 ] ;
2003-08-13 01:53:07 +00:00
DATA_BLOB ntlmv2_client_data ;
DATA_BLOB final_response ;
2004-05-25 14:06:28 +00:00
TALLOC_CTX * mem_ctx = talloc_init ( " NTLMv2_generate_response internal context " ) ;
if ( ! mem_ctx ) {
return data_blob ( NULL , 0 ) ;
}
2003-08-13 01:53:07 +00:00
/* NTLMv2 */
2003-11-26 01:16:41 +00:00
/* generate some data to pass into the response function - including
the hostname and domain name of the server */
2004-05-25 14:06:28 +00:00
ntlmv2_client_data = NTLMv2_generate_client_data ( mem_ctx , names_blob ) ;
2003-08-13 01:53:07 +00:00
/* Given that data, and the challenge from the server, generate a response */
2003-11-26 01:16:41 +00:00
SMBOWFencrypt_ntv2 ( ntlm_v2_hash , server_chal , & ntlmv2_client_data , ntlmv2_response ) ;
2003-08-13 01:53:07 +00:00
2003-11-26 01:16:41 +00:00
final_response = data_blob ( NULL , sizeof ( ntlmv2_response ) + ntlmv2_client_data . length ) ;
2003-08-13 01:53:07 +00:00
memcpy ( final_response . data , ntlmv2_response , sizeof ( ntlmv2_response ) ) ;
2003-11-26 01:16:41 +00:00
memcpy ( final_response . data + sizeof ( ntlmv2_response ) ,
ntlmv2_client_data . data , ntlmv2_client_data . length ) ;
2004-05-25 14:06:28 +00:00
talloc_destroy ( mem_ctx ) ;
2003-08-13 01:53:07 +00:00
return final_response ;
}
2004-06-01 08:30:34 +00:00
static DATA_BLOB LMv2_generate_response ( const uint8_t ntlm_v2_hash [ 16 ] ,
2003-11-26 01:16:41 +00:00
const DATA_BLOB * server_chal )
{
2004-06-01 08:30:34 +00:00
uint8_t lmv2_response [ 16 ] ;
2003-11-26 01:16:41 +00:00
DATA_BLOB lmv2_client_data = data_blob ( NULL , 8 ) ;
DATA_BLOB final_response = data_blob ( NULL , 24 ) ;
/* LMv2 */
/* client-supplied random data */
2004-07-14 12:14:07 +00:00
generate_random_buffer ( lmv2_client_data . data , lmv2_client_data . length ) ;
2003-11-26 01:16:41 +00:00
/* Given that data, and the challenge from the server, generate a response */
SMBOWFencrypt_ntv2 ( ntlm_v2_hash , server_chal , & lmv2_client_data , lmv2_response ) ;
memcpy ( final_response . data , lmv2_response , sizeof ( lmv2_response ) ) ;
/* after the first 16 bytes is the random data we generated above,
so the server can verify us with it */
memcpy ( final_response . data + sizeof ( lmv2_response ) ,
lmv2_client_data . data , lmv2_client_data . length ) ;
data_blob_free ( & lmv2_client_data ) ;
return final_response ;
}
2003-08-13 01:53:07 +00:00
BOOL SMBNTLMv2encrypt ( const char * user , const char * domain , const char * password ,
2003-11-26 01:16:41 +00:00
const DATA_BLOB * server_chal ,
const DATA_BLOB * names_blob ,
2003-08-13 01:53:07 +00:00
DATA_BLOB * lm_response , DATA_BLOB * nt_response ,
2004-05-02 08:45:00 +00:00
DATA_BLOB * user_session_key )
2003-08-13 01:53:07 +00:00
{
2004-06-01 08:30:34 +00:00
uint8_t nt_hash [ 16 ] ;
uint8_t ntlm_v2_hash [ 16 ] ;
2003-08-13 01:53:07 +00:00
E_md4hash ( password , nt_hash ) ;
/* We don't use the NT# directly. Instead we use it mashed up with
the username and domain .
This prevents username swapping during the auth exchange
*/
2004-05-02 08:45:00 +00:00
if ( ! ntv2_owf_gen ( nt_hash , user , domain , True , ntlm_v2_hash ) ) {
2003-08-13 01:53:07 +00:00
return False ;
}
2003-11-26 01:16:41 +00:00
if ( nt_response ) {
* nt_response = NTLMv2_generate_response ( ntlm_v2_hash , server_chal ,
names_blob ) ;
2004-05-02 08:45:00 +00:00
if ( user_session_key ) {
* user_session_key = data_blob ( NULL , 16 ) ;
2003-11-26 01:16:41 +00:00
/* The NTLMv2 calculations also provide a session key, for signing etc later */
/* use only the first 16 bytes of nt_response for session key */
2004-05-02 08:45:00 +00:00
SMBsesskeygen_ntv2 ( ntlm_v2_hash , nt_response - > data , user_session_key - > data ) ;
2003-11-26 01:16:41 +00:00
}
}
2003-08-13 01:53:07 +00:00
/* LMv2 */
2003-11-26 01:16:41 +00:00
if ( lm_response ) {
* lm_response = LMv2_generate_response ( ntlm_v2_hash , server_chal ) ;
}
2003-08-13 01:53:07 +00:00
return True ;
}
/***********************************************************
2004-04-21 05:01:31 +00:00
encode a password buffer with a unicode password . The buffer
is filled with random data to make it harder to attack .
2003-08-13 01:53:07 +00:00
* * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * */
2004-04-21 05:01:31 +00:00
BOOL encode_pw_buffer ( char buffer [ 516 ] , const char * password , int string_flags )
2003-08-13 01:53:07 +00:00
{
2004-06-01 08:30:34 +00:00
uint8_t new_pw [ 512 ] ;
2004-04-21 05:01:31 +00:00
size_t new_pw_len ;
2003-08-13 01:53:07 +00:00
2004-04-21 05:01:31 +00:00
new_pw_len = push_string ( NULL , new_pw ,
password ,
sizeof ( new_pw ) , string_flags ) ;
memcpy ( & buffer [ 512 - new_pw_len ] , new_pw , new_pw_len ) ;
2004-07-14 12:14:07 +00:00
generate_random_buffer ( ( uint8_t * ) buffer , 512 - new_pw_len ) ;
2003-08-13 01:53:07 +00:00
/*
* The length of the new password is in the last 4 bytes of
* the data buffer .
*/
2004-04-21 05:01:31 +00:00
SIVAL ( buffer , 512 , new_pw_len ) ;
ZERO_STRUCT ( new_pw ) ;
2003-08-13 01:53:07 +00:00
return True ;
}
2004-04-22 06:18:40 +00:00
2003-08-13 01:53:07 +00:00
/***********************************************************
decode a password buffer
* new_pw_len is the length in bytes of the possibly mulitbyte
returned password including termination .
* * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * */
BOOL decode_pw_buffer ( char in_buffer [ 516 ] , char * new_pwrd ,
2004-05-25 16:24:13 +00:00
int new_pwrd_size , uint32_t * new_pw_len ,
2004-05-02 08:45:00 +00:00
int string_flags )
2003-08-13 01:53:07 +00:00
{
int byte_len = 0 ;
/*
Warning ! ! ! : This function is called from some rpc call .
2004-05-02 08:45:00 +00:00
The password IN the buffer may be a UNICODE string .
2003-08-13 01:53:07 +00:00
The password IN new_pwrd is an ASCII string
If you reuse that code somewhere else check first .
*/
/* The length of the new password is in the last 4 bytes of the data buffer. */
byte_len = IVAL ( in_buffer , 512 ) ;
# ifdef DEBUG_PASSWORD
dump_data ( 100 , in_buffer , 516 ) ;
# endif
2004-05-02 08:45:00 +00:00
/* Password cannot be longer than the size of the password buffer */
if ( ( byte_len < 0 ) | | ( byte_len > 512 ) ) {
2003-08-13 01:53:07 +00:00
DEBUG ( 0 , ( " decode_pw_buffer: incorrect password length (%d). \n " , byte_len ) ) ;
DEBUG ( 0 , ( " decode_pw_buffer: check that 'encrypt passwords = yes' \n " ) ) ;
return False ;
}
2004-05-02 08:45:00 +00:00
/* decode into the return buffer. Buffer length supplied */
* new_pw_len = pull_string ( NULL , new_pwrd , & in_buffer [ 512 - byte_len ] , new_pwrd_size ,
byte_len , string_flags ) ;
2003-08-13 01:53:07 +00:00
# ifdef DEBUG_PASSWORD
DEBUG ( 100 , ( " decode_pw_buffer: new_pwrd: " ) ) ;
dump_data ( 100 , ( char * ) new_pwrd , * new_pw_len ) ;
DEBUG ( 100 , ( " multibyte len:%d \n " , * new_pw_len ) ) ;
DEBUG ( 100 , ( " original char len:%d \n " , byte_len / 2 ) ) ;
# endif
return True ;
}