Blame winpr/tools/hash-cli/hash.c

Packit 1fb8d4
/**
Packit 1fb8d4
 * WinPR: Windows Portable Runtime
Packit 1fb8d4
 * NTLM Hashing Tool
Packit 1fb8d4
 *
Packit 1fb8d4
 * Copyright 2012 Marc-Andre Moreau <marcandre.moreau@gmail.com>
Packit 1fb8d4
 *
Packit 1fb8d4
 * Licensed under the Apache License, Version 2.0 (the "License");
Packit 1fb8d4
 * you may not use this file except in compliance with the License.
Packit 1fb8d4
 * You may obtain a copy of the License at
Packit 1fb8d4
 *
Packit 1fb8d4
 *     http://www.apache.org/licenses/LICENSE-2.0
Packit 1fb8d4
 *
Packit 1fb8d4
 * Unless required by applicable law or agreed to in writing, software
Packit 1fb8d4
 * distributed under the License is distributed on an "AS IS" BASIS,
Packit 1fb8d4
 * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
Packit 1fb8d4
 * See the License for the specific language governing permissions and
Packit 1fb8d4
 * limitations under the License.
Packit 1fb8d4
 */
Packit 1fb8d4
Packit 1fb8d4
#include <stdio.h>
Packit 1fb8d4
#include <string.h>
Packit 1fb8d4
#include <stdlib.h>
Packit 1fb8d4
#include <errno.h>
Packit 1fb8d4
Packit 1fb8d4
#include <winpr/ntlm.h>
Packit Service 5a9772
#include <winpr/ssl.h>
Packit 1fb8d4
Packit 1fb8d4
/**
Packit 1fb8d4
 * Define NTOWFv1(Password, User, Domain) as
Packit 1fb8d4
 * 	MD4(UNICODE(Password))
Packit 1fb8d4
 * EndDefine
Packit 1fb8d4
 *
Packit 1fb8d4
 * Define LMOWFv1(Password, User, Domain) as
Packit 1fb8d4
 * 	ConcatenationOf(DES(UpperCase(Password)[0..6], "KGS!@#$%"),
Packit 1fb8d4
 * 		DES(UpperCase(Password)[7..13], "KGS!@#$%"))
Packit 1fb8d4
 * EndDefine
Packit 1fb8d4
 *
Packit 1fb8d4
 * Define NTOWFv2(Password, User, Domain) as
Packit 1fb8d4
 * 	HMAC_MD5(MD4(UNICODE(Password)),
Packit 1fb8d4
 * 		UNICODE(ConcatenationOf(UpperCase(User), Domain)))
Packit 1fb8d4
 * EndDefine
Packit 1fb8d4
 *
Packit 1fb8d4
 * Define LMOWFv2(Password, User, Domain) as
Packit 1fb8d4
 * 	NTOWFv2(Password, User, Domain)
Packit 1fb8d4
 * EndDefine
Packit 1fb8d4
 *
Packit 1fb8d4
 */
Packit 1fb8d4
Packit 1fb8d4
void usage_and_exit()
Packit 1fb8d4
{
Packit 1fb8d4
	printf("winpr-hash: NTLM hashing tool\n");
Packit Service 5a9772
	printf("Usage: winpr-hash -u <username> -p <password> [-d <domain>] [-f <_default_,sam>] [-v "
Packit Service 5a9772
	       "<_1_,2>]\n");
Packit 1fb8d4
	exit(1);
Packit 1fb8d4
}
Packit 1fb8d4
Packit 1fb8d4
int main(int argc, char* argv[])
Packit 1fb8d4
{
Packit 1fb8d4
	int index = 1;
Packit 1fb8d4
	int format = 0;
Packit 1fb8d4
	unsigned long version = 1;
Packit 1fb8d4
	BYTE NtHash[16];
Packit 1fb8d4
	char* User = NULL;
Packit 1fb8d4
	UINT32 UserLength;
Packit 1fb8d4
	char* Domain = NULL;
Packit 1fb8d4
	UINT32 DomainLength;
Packit 1fb8d4
	char* Password = NULL;
Packit 1fb8d4
	UINT32 PasswordLength;
Packit 1fb8d4
	errno = 0;
Packit 1fb8d4
Packit 1fb8d4
	while (index < argc)
Packit 1fb8d4
	{
Packit 1fb8d4
		if (strcmp("-d", argv[index]) == 0)
Packit 1fb8d4
		{
Packit 1fb8d4
			index++;
Packit 1fb8d4
Packit 1fb8d4
			if (index == argc)
Packit 1fb8d4
			{
Packit 1fb8d4
				printf("missing domain\n\n");
Packit 1fb8d4
				usage_and_exit();
Packit 1fb8d4
			}
Packit 1fb8d4
Packit 1fb8d4
			Domain = argv[index];
Packit 1fb8d4
		}
Packit 1fb8d4
		else if (strcmp("-u", argv[index]) == 0)
Packit 1fb8d4
		{
Packit 1fb8d4
			index++;
Packit 1fb8d4
Packit 1fb8d4
			if (index == argc)
Packit 1fb8d4
			{
Packit 1fb8d4
				printf("missing username\n\n");
Packit 1fb8d4
				usage_and_exit();
Packit 1fb8d4
			}
Packit 1fb8d4
Packit 1fb8d4
			User = argv[index];
Packit 1fb8d4
		}
Packit 1fb8d4
		else if (strcmp("-p", argv[index]) == 0)
Packit 1fb8d4
		{
Packit 1fb8d4
			index++;
Packit 1fb8d4
Packit 1fb8d4
			if (index == argc)
Packit 1fb8d4
			{
Packit 1fb8d4
				printf("missing password\n\n");
Packit 1fb8d4
				usage_and_exit();
Packit 1fb8d4
			}
Packit 1fb8d4
Packit 1fb8d4
			Password = argv[index];
Packit 1fb8d4
		}
Packit 1fb8d4
		else if (strcmp("-v", argv[index]) == 0)
Packit 1fb8d4
		{
Packit 1fb8d4
			index++;
Packit 1fb8d4
Packit 1fb8d4
			if (index == argc)
Packit 1fb8d4
			{
Packit 1fb8d4
				printf("missing version parameter\n\n");
Packit 1fb8d4
				usage_and_exit();
Packit 1fb8d4
			}
Packit 1fb8d4
Packit 1fb8d4
			version = strtoul(argv[index], NULL, 0);
Packit 1fb8d4
Packit 1fb8d4
			if (((version != 1) && (version != 2)) || (errno != 0))
Packit 1fb8d4
			{
Packit 1fb8d4
				printf("unknown version %lu \n\n", version);
Packit 1fb8d4
				usage_and_exit();
Packit 1fb8d4
			}
Packit 1fb8d4
		}
Packit 1fb8d4
		else if (strcmp("-f", argv[index]) == 0)
Packit 1fb8d4
		{
Packit 1fb8d4
			index++;
Packit 1fb8d4
Packit 1fb8d4
			if (index == argc)
Packit 1fb8d4
			{
Packit 1fb8d4
				printf("missing format\n\n");
Packit 1fb8d4
				usage_and_exit();
Packit 1fb8d4
			}
Packit 1fb8d4
Packit 1fb8d4
			if (strcmp("default", argv[index]) == 0)
Packit 1fb8d4
				format = 0;
Packit 1fb8d4
			else if (strcmp("sam", argv[index]) == 0)
Packit 1fb8d4
				format = 1;
Packit 1fb8d4
		}
Packit 1fb8d4
		else if (strcmp("-h", argv[index]) == 0)
Packit 1fb8d4
		{
Packit 1fb8d4
			usage_and_exit();
Packit 1fb8d4
		}
Packit 1fb8d4
Packit 1fb8d4
		index++;
Packit 1fb8d4
	}
Packit 1fb8d4
Packit 1fb8d4
	if ((!User) || (!Password))
Packit 1fb8d4
	{
Packit 1fb8d4
		printf("missing username or password\n\n");
Packit 1fb8d4
		usage_and_exit();
Packit 1fb8d4
	}
Packit Service 5a9772
	winpr_InitializeSSL(WINPR_SSL_INIT_DEFAULT);
Packit 1fb8d4
Packit 1fb8d4
	UserLength = strlen(User);
Packit 1fb8d4
	PasswordLength = strlen(Password);
Packit 1fb8d4
	DomainLength = (Domain) ? strlen(Domain) : 0;
Packit 1fb8d4
Packit 1fb8d4
	if (version == 2)
Packit 1fb8d4
	{
Packit 1fb8d4
		if (!Domain)
Packit 1fb8d4
		{
Packit 1fb8d4
			printf("missing domain (version 2 requires a domain to specified)\n\n");
Packit 1fb8d4
			usage_and_exit();
Packit 1fb8d4
		}
Packit 1fb8d4
Packit Service 5a9772
		if (!NTOWFv2A(Password, PasswordLength, User, UserLength, Domain, DomainLength, NtHash))
Packit Service 5a9772
		{
Packit Service 5a9772
			fprintf(stderr, "Hash creation failed\n");
Packit Service 5a9772
			return 1;
Packit Service 5a9772
		}
Packit 1fb8d4
	}
Packit 1fb8d4
	else
Packit 1fb8d4
	{
Packit Service 5a9772
		if (!NTOWFv1A(Password, PasswordLength, NtHash))
Packit Service 5a9772
		{
Packit Service 5a9772
			fprintf(stderr, "Hash creation failed\n");
Packit Service 5a9772
			return 1;
Packit Service 5a9772
		}
Packit 1fb8d4
	}
Packit 1fb8d4
Packit 1fb8d4
	if (format == 0)
Packit 1fb8d4
	{
Packit 1fb8d4
		for (index = 0; index < 16; index++)
Packit Service 5a9772
			printf("%02" PRIx8 "", NtHash[index]);
Packit 1fb8d4
Packit 1fb8d4
		printf("\n");
Packit 1fb8d4
	}
Packit 1fb8d4
	else if (format == 1)
Packit 1fb8d4
	{
Packit 1fb8d4
		printf("%s:", User);
Packit 1fb8d4
Packit 1fb8d4
		if (DomainLength > 0)
Packit 1fb8d4
			printf("%s:", Domain);
Packit 1fb8d4
		else
Packit 1fb8d4
			printf(":");
Packit 1fb8d4
Packit 1fb8d4
		printf(":");
Packit 1fb8d4
Packit 1fb8d4
		for (index = 0; index < 16; index++)
Packit Service 5a9772
			printf("%02" PRIx8 "", NtHash[index]);
Packit 1fb8d4
Packit 1fb8d4
		printf(":::");
Packit 1fb8d4
		printf("\n");
Packit 1fb8d4
	}
Packit 1fb8d4
Packit 1fb8d4
	return 0;
Packit 1fb8d4
}