aboutsummaryrefslogtreecommitdiff
path: root/plugins/ka-plugin-pam.c
diff options
context:
space:
mode:
Diffstat (limited to 'plugins/ka-plugin-pam.c')
-rw-r--r--plugins/ka-plugin-pam.c128
1 files changed, 128 insertions, 0 deletions
diff --git a/plugins/ka-plugin-pam.c b/plugins/ka-plugin-pam.c
new file mode 100644
index 0000000..53d1f06
--- /dev/null
+++ b/plugins/ka-plugin-pam.c
@@ -0,0 +1,128 @@
+/*
+ * Copyright (C) 2010 Guido Guenther <agx@sigxcpu.org>
+ *
+ * This program is free software; you can redistribute it and/or modify
+ * it under the terms of the GNU General Public License as published by
+ * the Free Software Foundation; either version 2, or (at your option)
+ * any later version.
+ *
+ * This program is distributed in the hope that it will be useful,
+ * but WITHOUT ANY WARRANTY; without even the implied warranty of
+ * MERCHANTABILITY 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, write to the Free Software
+ * Foundation, Inc., 59 Temple Place - Suite 330, Boston, MA 02111-1307, USA.
+ */
+
+#include "ka-plugin-pam.h"
+#include <gmodule.h>
+
+#include <security/pam_appl.h>
+
+G_DEFINE_TYPE (KaPluginPam, ka_plugin_pam, KA_TYPE_PLUGIN)
+
+#define GET_PRIVATE(o) \
+ (G_TYPE_INSTANCE_GET_PRIVATE ((o), KA_TYPE_PLUGIN_PAM, KaPluginPamPrivate))
+
+typedef struct _KaPluginPamPrivate KaPluginPamPrivate;
+
+int ka_plugin_major_version = KA_PLUGIN_MAJOR_VERSION;
+int ka_plugin_minor_version = KA_PLUGIN_MINOR_VERSION;
+
+G_MODULE_EXPORT KaPlugin*
+ka_plugin_create (void)
+{
+ return KA_PLUGIN (ka_plugin_pam_new());
+}
+
+struct _KaPluginPamPrivate {
+ gulong handlers[2];
+};
+
+static void
+ka_plugin_pam_finalize (GObject *object)
+{
+ G_OBJECT_CLASS (ka_plugin_pam_parent_class)->finalize (object);
+}
+
+static int simple_conv( int n, const struct pam_message **msg, struct pam_response **resp, void *data)
+{
+ return (PAM_CONV_ERR);
+}
+
+static struct pam_conv simplepamconv = { simple_conv, NULL };
+
+static void
+renewed_event_cb (gpointer* applet, gchar* princ, guint when, gpointer user_data)
+{
+ const char *user;
+ pam_handle_t *pamh = NULL;
+ int retval = 0;
+
+ user = g_get_user_name ();
+ retval = pam_start("ka-plugin-pam", user, &simplepamconv, &pamh);
+ if (retval)
+ goto out;
+
+ retval = pam_setcred(pamh, PAM_ESTABLISH_CRED);
+ if (retval)
+ goto out;
+
+out:
+ if (retval)
+ g_warning("PAM plugin: %s", pam_strerror(pamh, retval));
+
+ if (pamh)
+ pam_end(pamh, PAM_SUCCESS);
+}
+
+static void
+ka_plugin_pam_activate (KaPlugin *self, KaApplet* applet)
+{
+ KaPluginPamPrivate *priv = GET_PRIVATE (self);
+
+ priv->handlers[1] = g_signal_connect (applet,
+ "krb-tgt-acquired",
+ G_CALLBACK (renewed_event_cb),
+ NULL);
+ priv->handlers[0] = g_signal_connect (applet,
+ "krb-tgt-renewed",
+ G_CALLBACK (renewed_event_cb),
+ NULL);
+}
+
+
+static void
+ka_plugin_pam_deactivate (KaPlugin *self, KaApplet* applet)
+{
+ KaPluginPamPrivate *priv = GET_PRIVATE (self);
+
+ g_signal_handler_disconnect (applet, priv->handlers[0]);
+ g_signal_handler_disconnect (applet, priv->handlers[1]);
+}
+
+static void
+ka_plugin_pam_class_init (KaPluginPamClass *klass)
+{
+ GObjectClass *object_class = G_OBJECT_CLASS (klass);
+ KaPluginClass *plugin_class = KA_PLUGIN_CLASS (klass);
+
+ g_type_class_add_private (klass, sizeof (KaPluginPamPrivate));
+
+ plugin_class->activate = ka_plugin_pam_activate;
+ plugin_class->deactivate = ka_plugin_pam_deactivate;
+ object_class->finalize = ka_plugin_pam_finalize;
+}
+
+static void
+ka_plugin_pam_init (KaPluginPam *self)
+{
+}
+
+KaPluginPam*
+ka_plugin_pam_new (void)
+{
+ return g_object_new (KA_TYPE_PLUGIN_PAM, KA_PLUGIN_PROP_NAME, "pam", NULL);
+}
bgstack15