summaryrefslogtreecommitdiff
path: root/gio/gunixcredentialsmessage.c
diff options
context:
space:
mode:
authorJoe Marcus Clarke <marcus@freebsd.org>2010-09-09 14:10:01 -0400
committerDavid Zeuthen <davidz@redhat.com>2010-09-09 14:10:01 -0400
commit964eb62343b53cf9172d409adacbb58d78896092 (patch)
tree3db2c4ec02622a27e04e8bf83d703009f8f0fe43 /gio/gunixcredentialsmessage.c
parentee945d8f621609086a8777ca4226cb93308c12e4 (diff)
downloadglib-964eb62343b53cf9172d409adacbb58d78896092.tar.gz
Bug 628904 – Add credential support for FreeBSD and fix a socket issue
Signed-off-by: David Zeuthen <davidz@redhat.com>
Diffstat (limited to 'gio/gunixcredentialsmessage.c')
-rw-r--r--gio/gunixcredentialsmessage.c46
1 files changed, 46 insertions, 0 deletions
diff --git a/gio/gunixcredentialsmessage.c b/gio/gunixcredentialsmessage.c
index e6dadfb4d..82224ab6b 100644
--- a/gio/gunixcredentialsmessage.c
+++ b/gio/gunixcredentialsmessage.c
@@ -46,6 +46,13 @@
#include <fcntl.h>
#define G_UNIX_CREDENTIALS_MESSAGE_SUPPORTED 1
+#elif defined(__FreeBSD__)
+#include <sys/types.h>
+#include <sys/socket.h>
+#include <sys/un.h>
+#include <unistd.h>
+#include <fcntl.h>
+#define G_UNIX_CREDENTIALS_MESSAGE_SUPPORTED 1
#else
/* TODO: please add support for your UNIX flavor */
#define G_UNIX_CREDENTIALS_MESSAGE_SUPPORTED 0
@@ -79,6 +86,8 @@ g_unix_credentials_message_get_size (GSocketControlMessage *message)
{
#ifdef __linux__
return sizeof (struct ucred);
+#elif defined(__FreeBSD__)
+ return sizeof (struct cmsgcred);
#else
return 0;
#endif
@@ -89,6 +98,8 @@ g_unix_credentials_message_get_level (GSocketControlMessage *message)
{
#ifdef __linux__
return SOL_SOCKET;
+#elif defined(__FreeBSD__)
+ return SOL_SOCKET;
#else
return 0;
#endif
@@ -99,6 +110,8 @@ g_unix_credentials_message_get_msg_type (GSocketControlMessage *message)
{
#ifdef __linux__
return SCM_CREDENTIALS;
+#elif defined(__FreeBSD__)
+ return SCM_CREDS;
#else
return 0;
#endif
@@ -140,6 +153,33 @@ g_unix_credentials_message_deserialize (gint level,
out:
;
}
+#elif defined(__FreeBSD__)
+ {
+ GCredentials *credentials;
+ struct cmsgcred *cred;
+
+ if (level != SOL_SOCKET || type != SCM_CREDS)
+ {
+ goto out;
+ }
+ if (size < CMSG_LEN (sizeof *cred))
+ {
+ g_warning ("Expected a struct cmsgcred (%" G_GSIZE_FORMAT " bytes) but "
+ "got %" G_GSIZE_FORMAT " bytes of data",
+ CMSG_LEN (sizeof *cred),
+ size);
+ goto out;
+ }
+
+ cred = data;
+
+ credentials = g_credentials_new ();
+ g_credentials_set_native (credentials, G_CREDENTIALS_TYPE_FREEBSD_CMSGCRED, cred);
+ message = g_unix_credentials_message_new_with_credentials (credentials);
+ g_object_unref (credentials);
+ out:
+ ;
+ }
#endif
return message;
@@ -155,6 +195,12 @@ g_unix_credentials_message_serialize (GSocketControlMessage *_message,
g_credentials_get_native (message->priv->credentials,
G_CREDENTIALS_TYPE_LINUX_UCRED),
sizeof (struct ucred));
+#elif defined(__FreeBSD__)
+ memcpy (data,
+ g_credentials_get_native (message->priv->credentials,
+ G_CREDENTIALS_TYPE_FREEBSD_CMSGCRED),
+ sizeof (struct cmsgcred));
+
#endif
}