Leaked source code of windows server 2003
You can not select more than 25 topics Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.

0 lines
9.5 KiB

  1. /*****************************************************************/ /** Microsoft Windows 2000 **/ /** Copyright (C) Microsoft Corp., 1991-1998 **/ /*****************************************************************/ /*****************************************************************/ /** Microsoft Windows **/ /** Copyright (C) Microsoft Corp., 1991-1995 **/ /*****************************************************************/ /*****************************************************************/ /** Microsoft Windows for Workgroups **/ /** Copyright (C) Microsoft Corp., 1991-1992 **/ /*****************************************************************/ /********************************************************************/ /** Microsoft LAN Manager **/ /** Copyright(c) Microsoft Corp., 1987-1991 **/ /********************************************************************/ #include <stdlib.h> #include <stdio.h> #include <string.h> #ifdef __MACUAM__ #include "MWERKSCrypto.h" #endif #include "rc4.h" #include "USRPWST3.h" // --------------------------------------------------------------------------- // � EncryptStdBlock() // --------------------------------------------------------------------------- // Routine Description: // // Takes a block key encrypts the standard text block with it. // The resulting encrypted block is returned. // This is a One-Way-Function - the key cannot be recovered from the // encrypted data block. // // Arguments: // // BlockKey - The key to use to encrypt the standard text block. // // CypherBlock - The encrypted data is returned here // // Return Values: // // TRUE - The encryption was successful. // The result is in CypherBlock // // FALSE - Something failed. The CypherBlock is undefined. Boolean EncryptStdBlock( IN PBLOCK_KEY BlockKey, OUT PCYPHER_BLOCK CypherBlock ) { unsigned Result; char StdEncrPwd[] = "KGS!@#$%"; Result = DES_ECB_LM((DWORD)ENCR_KEY, (const char *)BlockKey, (unsigned char *)StdEncrPwd, (unsigned char *)CypherBlock ); if (Result == CRYPT_OK) { return(TRUE); } else { return(FALSE); } } // --------------------------------------------------------------------------- // � CalculateLmOwfPassword() // --------------------------------------------------------------------------- // Routine Description: // // Takes the passed LmPassword and performs a one-way-function on it. // The current implementation does this by using the password as a key // to encrypt a known block of text. // // Arguments: // // LmPassword - The password to perform the one-way-function on. // // LmOwfPassword - The hashed password is returned here // // Return Values: // // Boolean - The function was completed successfully. The hashed // password is in LmOwfPassword. // // FALSE - Something failed. The LmOwfPassword is undefined. Boolean CalculateLmOwfPassword( IN PLM_PASSWORD LmPassword, OUT PLM_OWF_PASSWORD LmOwfPassword ) { Boolean Status; BLOCK_KEY Key[2]; PCHAR pKey; PBLOCK_KEY pK; // Copy the password into our key buffer and zero pad to fill the 2 keys pKey = (PCHAR)(&Key[0]); while (*LmPassword && (pKey < (PCHAR)(&Key[2]))) { *pKey++ = *LmPassword++; } while (pKey < (PCHAR)(&Key[2])) { *pKey++ = 0; } // Use the keys to encrypt the standard text Status = EncryptStdBlock(&Key[0], &(LmOwfPassword->data[0])); if (!Status) { return(Status); } pK = (PBLOCK_KEY)(((PUCHAR)&Key[1])-1); Status = EncryptStdBlock(pK /*&Key[1]*/, &(LmOwfPassword->data[1])); // // clear our copy of the cleartext password // pKey = (PCHAR)(&Key