aboutsummaryrefslogtreecommitdiff
path: root/src
diff options
context:
space:
mode:
authorTed Gould <ted@gould.cx>2012-08-21 18:26:38 -0500
committerTed Gould <ted@gould.cx>2012-08-21 18:26:38 -0500
commitdebd3a94955e7a64ec3430340ea20efdaa927636 (patch)
treee0f8fe2d6dd0c9242aae3612f0867f9ab7ffd542 /src
parentfcf1e8bdf126996d1b24c60f07fa817c30b2af90 (diff)
downloadlibpam-x2go-debd3a94955e7a64ec3430340ea20efdaa927636.tar.gz
libpam-x2go-debd3a94955e7a64ec3430340ea20efdaa927636.tar.bz2
libpam-x2go-debd3a94955e7a64ec3430340ea20efdaa927636.zip
Adding some freerdp-ness to it
Diffstat (limited to 'src')
-rw-r--r--src/freerdp-auth-check.c64
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;
+ }
}