diff options
author | Ted Gould <ted@gould.cx> | 2012-08-21 18:26:38 -0500 |
---|---|---|
committer | Ted Gould <ted@gould.cx> | 2012-08-21 18:26:38 -0500 |
commit | debd3a94955e7a64ec3430340ea20efdaa927636 (patch) | |
tree | e0f8fe2d6dd0c9242aae3612f0867f9ab7ffd542 | |
parent | fcf1e8bdf126996d1b24c60f07fa817c30b2af90 (diff) | |
download | libpam-x2go-debd3a94955e7a64ec3430340ea20efdaa927636.tar.gz libpam-x2go-debd3a94955e7a64ec3430340ea20efdaa927636.tar.bz2 libpam-x2go-debd3a94955e7a64ec3430340ea20efdaa927636.zip |
Adding some freerdp-ness to it
-rw-r--r-- | src/freerdp-auth-check.c | 64 |
1 files changed, 63 insertions, 1 deletions
diff --git a/src/freerdp-auth-check.c b/src/freerdp-auth-check.c index 309be4c..5b29cf1 100644 --- a/src/freerdp-auth-check.c +++ b/src/freerdp-auth-check.c @@ -1,8 +1,70 @@ +#include <freerdp/freerdp.h> +#include <freerdp/channels/channels.h> +#include <string.h> + +void +auth_context_new (freerdp * instance, rdpContext * context) +{ + context->channels = freerdp_channels_new(); + return; +} + +void +auth_context_free (freerdp * instance, rdpContext * context) +{ + return; +} + +boolean +auth_pre_connect (freerdp * instance) +{ + freerdp_channels_pre_connect(instance->context->channels, instance); + return true; +} + +boolean +auth_post_connect (freerdp * instance) +{ + freerdp_channels_post_connect(instance->context->channels, instance); + return true; +} int main (int argc, char * argv[]) { + char password[512]; + if (argc != 4) { + printf("Not enough params"); + return -1; + } + + if (scanf("%511s", password) != 1) { + return -1; + } + + freerdp_channels_global_init(); + + freerdp * instance = freerdp_new(); + + instance->PreConnect = auth_pre_connect; + instance->PostConnect = auth_post_connect; + + instance->context_size = sizeof(rdpContext); + instance->ContextNew = auth_context_new; + instance->ContextFree = auth_context_free; + + freerdp_context_new(instance); + instance->settings->hostname = argv[1]; + instance->settings->username = argv[2]; + instance->settings->domain = argv[3]; + instance->settings->password = password; + instance->settings->ignore_certificate = true; - return -1; + if (freerdp_connect(instance)) { + freerdp_disconnect(instance); + return 0; + } else { + return -1; + } } |