From 589051f3ef91ab1bc3029de3952907dea81c1f88 Mon Sep 17 00:00:00 2001 From: Mike Gabriel Date: Sat, 5 May 2018 16:57:41 +0200 Subject: src/: Rename files *freerdp* -> *freerdp2*. --- src/freerdp2-auth-check.c | 124 ++++++++++++++++++++++++++++++++++++++++++++++ 1 file changed, 124 insertions(+) create mode 100644 src/freerdp2-auth-check.c (limited to 'src/freerdp2-auth-check.c') diff --git a/src/freerdp2-auth-check.c b/src/freerdp2-auth-check.c new file mode 100644 index 0000000..219f434 --- /dev/null +++ b/src/freerdp2-auth-check.c @@ -0,0 +1,124 @@ +/* + * Copyright © 2012 Canonical Ltd. + * + * This program is free software: you can redistribute it and/or modify it + * under the terms of the GNU General Public License version 3, as + * published by the Free Software Foundation. + * + * This program is distributed in the hope that it will be useful, but + * WITHOUT ANY WARRANTY; without even the implied warranties of + * MERCHANTABILITY, SATISFACTORY QUALITY, 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, see . + * + * Author: Ted Gould + */ + +#include +#include +#include +#include +#include + + +BOOL +auth_context_new (freerdp * instance, rdpContext * context) +{ + return TRUE; +} + +void +auth_context_free (freerdp * instance, rdpContext * context) +{ + return; +} + +BOOL +auth_pre_connect (freerdp * instance) +{ + return TRUE; +} + +BOOL +auth_post_connect (freerdp * instance) +{ + return TRUE; +} + +int +main (int argc, char * argv[]) +{ + char password[512]; + if (argc != 5) { + printf("Not enough params\n\n"); + printf("Usage: freerdp-auth-check [:] \n\n"); + return -1; + } + + if (scanf("%511s", password) != 1) { + return -1; + } + + if (mlock(password, sizeof(password)) != 0) { + return -1; + } + +#ifndef ENABLE_WLOG + wLog* root = WLog_GetRoot(); + + if (!WLog_SetStringLogLevel(root, "OFF")){ + return -1; + } +#endif + freerdp * instance = freerdp_new(); + + instance->PreConnect = auth_pre_connect; + instance->PostConnect = auth_post_connect; + + instance->ContextSize = sizeof(rdpContext); + instance->ContextNew = auth_context_new; + instance->ContextFree = auth_context_free; + + if (!freerdp_context_new(instance)) { + printf("Couldn't create freerdp_context\n"); + return -1; + } + + char * colonloc = strstr(argv[1], ":"); + if (colonloc != NULL) { + /* We've got a port to deal with */ + colonloc[0] = '\0'; + colonloc++; + + instance->settings->ServerPort = strtoul(colonloc, NULL, 10); + } + + instance->settings->AuthenticationOnly = TRUE; + instance->settings->ServerHostname = argv[1]; + instance->settings->Username = argv[2]; + instance->settings->Domain = argv[3]; + instance->settings->Password = password; + + BOOL connection_successful; + connection_successful = freerdp_connect(instance); + freerdp_disconnect(instance); + + memset(password, 0, sizeof(password)); + munlock(password, sizeof(password)); + instance->settings->Password = NULL; + instance->settings->ServerHostname = NULL; + instance->settings->Username = NULL; + instance->settings->Domain = NULL; + + int retval = 0; + if (!connection_successful) { + retval = freerdp_get_last_error(instance->context); + } + + freerdp_context_free(instance); + freerdp_free(instance); + + return retval; +} -- cgit v1.2.3