From: jbrindle@tresys.com
To: selinux@tycho.nsa.gov
Subject: [PATCH 05/33] libsepol: node serialization
Date: Mon, 23 Apr 2007 17:35:00 -0400 [thread overview]
Message-ID: <20070423213725.202604000@tresys.com> (raw)
In-Reply-To: 20070423213455.741326000@tresys.com
This adds serialize/unserialize methods for node records.
---
libsepol/include/sepol/node_record.h | 10 ++
libsepol/src/node_internal.h | 2
libsepol/src/node_record.c | 155 +++++++++++++++++++++++++++++++++++
3 files changed, 167 insertions(+)
Index: selinux-pms-support/libsepol/include/sepol/node_record.h
===================================================================
--- selinux-pms-support.orig/libsepol/include/sepol/node_record.h
+++ selinux-pms-support/libsepol/include/sepol/node_record.h
@@ -1,6 +1,7 @@
#ifndef _SEPOL_NODE_RECORD_H_
#define _SEPOL_NODE_RECORD_H_
+#include <inttypes.h>
#include <stddef.h>
#include <sepol/context_record.h>
#include <sepol/handle.h>
@@ -89,4 +90,13 @@ extern int sepol_node_clone(sepol_handle
extern void sepol_node_free(sepol_node_t * node);
+/* Serialize/Unserialize */
+extern int sepol_node_serialize(sepol_handle_t * handle,
+ const sepol_node_t * node,
+ char **data, uint64_t * size);
+
+extern int sepol_node_unserialize(sepol_handle_t * handle,
+ char **data, uint64_t * size,
+ sepol_node_t ** node);
+
#endif
Index: selinux-pms-support/libsepol/src/node_internal.h
===================================================================
--- selinux-pms-support.orig/libsepol/src/node_internal.h
+++ selinux-pms-support/libsepol/src/node_internal.h
@@ -23,4 +23,6 @@ hidden_proto(sepol_node_create)
hidden_proto(sepol_node_set_mask)
hidden_proto(sepol_node_set_mask_bytes)
hidden_proto(sepol_node_set_proto)
+ hidden_proto(sepol_node_serialize)
+ hidden_proto(sepol_node_unserialize)
#endif
Index: selinux-pms-support/libsepol/src/node_record.c
===================================================================
--- selinux-pms-support.orig/libsepol/src/node_record.c
+++ selinux-pms-support/libsepol/src/node_record.c
@@ -1,3 +1,4 @@
+#include <assert.h>
#include <stdlib.h>
#include <stddef.h>
#include <string.h>
@@ -8,6 +9,7 @@
#include "node_internal.h"
#include "context_internal.h"
#include "debug.h"
+#include "serialize.h"
struct sepol_node {
@@ -666,3 +668,156 @@ int sepol_node_set_con(sepol_handle_t *
}
hidden_def(sepol_node_set_con)
+
+/* Serialize/Unserialize */
+/** Destructively modifies data and size.
+ * Caller must pre-allocate space for data.
+ * Use sepol_node_calculate_serialized_size(). */
+int sepol_node_serialize(sepol_handle_t * handle,
+ const sepol_node_t * node,
+ char **data, uint64_t * size)
+{
+ int status = STATUS_SUCCESS;
+ char *addr = NULL;
+ char *mask = NULL;
+ int proto;
+
+ /* Sundry sanity checks. */
+ if (handle == NULL || node == NULL) {
+ status = STATUS_ERR;
+ goto cleanup;
+ }
+
+ /* Node address. */
+ /* Note that these getters allocate space. */
+ status = sepol_node_get_addr(handle, node, &addr);
+ if (status != STATUS_SUCCESS)
+ goto cleanup;
+ status =
+ sepol_serialize(handle, addr, (addr == NULL) ? 0 : strlen(addr),
+ SEPOL_SERIAL_STRING, data, size);
+ if (status != STATUS_SUCCESS)
+ goto cleanup;
+
+ /* Node mask. */
+ /* Note that these getters allocate space. */
+ status = sepol_node_get_mask(handle, node, &mask);
+ if (status != STATUS_SUCCESS)
+ goto cleanup;
+ status =
+ sepol_serialize(handle, mask, (mask == NULL) ? 0 : strlen(mask),
+ SEPOL_SERIAL_STRING, data, size);
+ if (status != STATUS_SUCCESS)
+ goto cleanup;
+
+ /* Node protocol. */
+ proto = sepol_node_get_proto(node);
+ status = sepol_serialize(handle, &proto, 0, SEPOL_SERIAL_INT32_T, data, size);
+ if (status != STATUS_SUCCESS)
+ goto cleanup;
+
+ /* Node context. */
+ status =
+ sepol_context_serialize(handle, sepol_node_get_con(node), data,
+ size);
+ if (status != STATUS_SUCCESS)
+ goto cleanup;
+
+ /* Cleanup. */
+ cleanup:
+ free(addr);
+ free(mask);
+ return status;
+}
+
+hidden_def(sepol_node_serialize)
+
+/** Destructively modifies node, data and size.
+ * Allocates space for node.
+ * Caller must free. */
+int sepol_node_unserialize(sepol_handle_t * handle,
+ char **data, uint64_t * size,
+ sepol_node_t ** node)
+{
+ int status = STATUS_SUCCESS;
+ char *addr = NULL;
+ size_t *addr_size = NULL;
+ char *mask = NULL;
+ size_t *mask_size = NULL;
+ int *proto = NULL;
+ sepol_context_t *con = NULL;
+
+ /* Sundry sanity checks. */
+ if (handle == NULL || data == NULL || *data == NULL || size == NULL) {
+ status = STATUS_ERR;
+ goto cleanup;
+ }
+
+ /* Allocate space. */
+ status = sepol_node_create(handle, node);
+ if (status != STATUS_SUCCESS)
+ goto cleanup;
+
+ /* Node address. */
+ status =
+ sepol_unserialize(handle,
+ data, size,
+ (void **)&addr, &addr_size, SEPOL_SERIAL_STRING);
+ if (status != STATUS_SUCCESS)
+ goto cleanup;
+ /* Waiting for protocol before setting. */
+
+ /* Node mask size. */
+ status =
+ sepol_unserialize(handle,
+ data, size,
+ (void **)&mask, &mask_size, SEPOL_SERIAL_STRING);
+ if (status != STATUS_SUCCESS)
+ goto cleanup;
+ /* Waiting for protocol before setting. */
+
+ /* Node protocol. */
+ status =
+ sepol_unserialize(handle,
+ data, size,
+ (void **)&proto, NULL, SEPOL_SERIAL_INT32_T);
+ if (status != STATUS_SUCCESS)
+ goto cleanup;
+ sepol_node_set_proto(*node, *proto);
+
+ /* Setting address and mask now that we know the protocol. */
+ if (addr != NULL) {
+ /* Note that sepol_*_set* calls typically create space. */
+ status = sepol_node_set_addr(handle, *node, *proto, addr);
+ if (status != STATUS_SUCCESS)
+ goto cleanup;
+ }
+
+ if (mask != NULL) {
+ /* Note that sepol_*_set* calls typically create space. */
+ status = sepol_node_set_mask(handle, *node, *proto, mask);
+ if (status != STATUS_SUCCESS)
+ goto cleanup;
+ }
+
+ /* Node context. */
+ status = sepol_context_unserialize(handle, data, size, &con);
+ if (status != STATUS_SUCCESS)
+ goto cleanup;
+ /* Note that sepol_*_set* calls typically create space. */
+ status = sepol_node_set_con(handle, *node, con);
+ if (status != STATUS_SUCCESS)
+ goto cleanup;
+
+ /* Cleanup. */
+ cleanup:
+ free(addr);
+ free(addr_size);
+ free(mask);
+ free(mask_size);
+ free(proto);
+ sepol_context_free(con);
+ return status;
+}
+
+hidden_def(sepol_node_unserialize)
--
--
This message was distributed to subscribers of the selinux mailing list.
If you no longer wish to subscribe, send mail to majordomo@tycho.nsa.gov with
the words "unsubscribe selinux" without quotes as the message.
next prev parent reply other threads:[~2007-04-24 18:30 UTC|newest]
Thread overview: 58+ messages / expand[flat|nested] mbox.gz Atom feed top
2007-04-23 21:34 [PATCH 00/33] libsemanage/libsepol object serialization and ps-api jbrindle
2007-04-23 21:34 ` [PATCH 01/33] libsepol: basic serilization support jbrindle
2007-04-24 20:00 ` Karl MacMillan
2007-04-24 22:29 ` Joshua Brindle
2007-04-25 4:49 ` Karl MacMillan
2007-04-25 14:14 ` Joshua Brindle
2007-04-25 15:16 ` Karl MacMillan
2007-04-25 15:21 ` Joshua Brindle
2007-04-25 15:40 ` Karl MacMillan
2007-04-25 15:52 ` Joshua Brindle
2007-04-25 16:00 ` Karl MacMillan
2007-04-25 16:25 ` Joshua Brindle
2007-04-25 17:11 ` James Antill
2007-04-25 18:08 ` Karl MacMillan
2007-04-23 21:34 ` [PATCH 02/33] libsepol: boolean serialization jbrindle
2007-04-25 4:56 ` Karl MacMillan
2007-04-23 21:34 ` [PATCH 03/33] libsepol: context serialization jbrindle
2007-04-23 21:34 ` [PATCH 04/33] libsepol: interface serialization jbrindle
2007-04-23 21:35 ` jbrindle [this message]
2007-04-23 21:35 ` [PATCH 06/33] libsepol: port serialization jbrindle
2007-04-23 21:35 ` [PATCH 07/33] libsepol: user serialization jbrindle
2007-04-23 21:35 ` [PATCH 08/33] libsemanage: DESTDIR support in INCLUDE and safe test target jbrindle
2007-04-23 21:35 ` [PATCH 09/33] libsemanage: dbase/dconfig cleanup jbrindle
2007-04-23 21:35 ` [PATCH 10/33] libsemanage: database serialization jbrindle
2007-04-23 21:35 ` [PATCH 11/33] libsemanage: endianness macros jbrindle
2007-04-23 21:35 ` [PATCH 12/33] libsemanage: basic serialization jbrindle
2007-04-24 21:16 ` Karl MacMillan
2007-04-24 22:31 ` Joshua Brindle
2007-04-24 22:39 ` Karl MacMillan
2007-04-23 21:35 ` [PATCH 13/33] libsemanage: testing infrastructure jbrindle
2007-04-23 21:35 ` [PATCH 14/33] libsemanage: boolean serialization jbrindle
2007-04-23 21:35 ` [PATCH 15/33] libsemanage: context serialization jbrindle
2007-04-23 21:35 ` [PATCH 16/33] libsemanage: fcontext serialization jbrindle
2007-04-23 21:35 ` [PATCH 17/33] libsemanage: interface serialization jbrindle
2007-04-23 21:35 ` [PATCH 18/33] libsemanage: node serialization jbrindle
2007-04-23 21:35 ` [PATCH 19/33] libsemanage: port serialization jbrindle
2007-04-23 21:35 ` [PATCH 20/33] libsemanage: seuser serialization jbrindle
2007-04-23 21:35 ` [PATCH 21/33] libsemanage: user serialization jbrindle
2007-04-23 21:35 ` [PATCH 22/33] libsemanage: module serialization jbrindle
2007-04-23 21:35 ` [PATCH 23/33] libsemanage: commit number serialization jbrindle
2007-04-23 21:35 ` [PATCH 24/33] libsemanage: networking support jbrindle
2007-04-23 21:35 ` [PATCH 25/33] libsemanage: policy server database hooks jbrindle
2007-04-24 21:39 ` Karl MacMillan
2007-04-24 22:39 ` Joshua Brindle
2007-04-24 23:20 ` Karl MacMillan
2007-04-24 23:57 ` Joshua Brindle
2007-04-25 4:42 ` Karl MacMillan
2007-04-23 21:35 ` [PATCH 26/33] libsemanage: module serialization tests jbrindle
2007-04-23 21:35 ` [PATCH 27/33] libsemanage: booleans " jbrindle
2007-04-23 21:35 ` [PATCH 28/33] libsemanage: fcontexts " jbrindle
2007-04-23 21:35 ` [PATCH 29/33] libsemanage: interface " jbrindle
2007-04-23 21:35 ` [PATCH 30/33] libsemanage: node " jbrindle
2007-04-23 21:35 ` [PATCH 31/33] libsemanage: port " jbrindle
2007-04-23 21:35 ` [PATCH 32/33] libsemanage: seuser " jbrindle
2007-04-23 21:35 ` [PATCH 33/33] libsemanage: user " jbrindle
2007-04-24 19:48 ` [PATCH 00/33] libsemanage/libsepol object serialization and ps-api Joshua Brindle
2007-04-24 23:12 ` James Antill
2007-04-25 4:46 ` James Antill
Reply instructions:
You may reply publicly to this message via plain-text email
using any one of the following methods:
* Save the following mbox file, import it into your mail client,
and reply-to-all from there: mbox
Avoid top-posting and favor interleaved quoting:
https://en.wikipedia.org/wiki/Posting_style#Interleaved_style
* Reply using the --to, --cc, and --in-reply-to
switches of git-send-email(1):
git send-email \
--in-reply-to=20070423213725.202604000@tresys.com \
--to=jbrindle@tresys.com \
--cc=selinux@tycho.nsa.gov \
/path/to/YOUR_REPLY
https://kernel.org/pub/software/scm/git/docs/git-send-email.html
* If your mail client supports setting the In-Reply-To header
via mailto: links, try the mailto: link
Be sure your reply has a Subject: header at the top and a blank line
before the message body.
This is an external index of several public inboxes,
see mirroring instructions on how to clone and mirror
all data and code used by this external index.