summaryrefslogtreecommitdiffstats
path: root/src/kim/lib/kim_options.c
diff options
context:
space:
mode:
authorAlexandra Ellwood <lxs@mit.edu>2008-09-28 20:53:12 +0000
committerAlexandra Ellwood <lxs@mit.edu>2008-09-28 20:53:12 +0000
commit876e89da92c0a98e25e16b4080546b7de0d5137c (patch)
treefb08ff04d2e6b4bf2d1e83e627be64e78ee615a7 /src/kim/lib/kim_options.c
parentb5dce4285a9330d25542528030ce93da78e36375 (diff)
downloadkrb5-876e89da92c0a98e25e16b4080546b7de0d5137c.tar.gz
krb5-876e89da92c0a98e25e16b4080546b7de0d5137c.tar.xz
krb5-876e89da92c0a98e25e16b4080546b7de0d5137c.zip
Added kim_selection_hints_create_from_stream and
kim_selection_hints_write_to_stream for client/server communication. ticket: 6055 git-svn-id: svn://anonsvn.mit.edu/krb5/trunk@20770 dc483132-0cff-0310-8789-dd5450dbe970
Diffstat (limited to 'src/kim/lib/kim_options.c')
-rw-r--r--src/kim/lib/kim_options.c123
1 files changed, 120 insertions, 3 deletions
diff --git a/src/kim/lib/kim_options.c b/src/kim/lib/kim_options.c
index a5470f413..89272b635 100644
--- a/src/kim/lib/kim_options.c
+++ b/src/kim/lib/kim_options.c
@@ -136,7 +136,7 @@ kim_error kim_options_copy (kim_options *out_options,
}
}
}
-
+
if (!err) {
*out_options = options;
options = NULL;
@@ -484,7 +484,7 @@ krb5_get_init_creds_opt *kim_options_init_cred_options (kim_options in_options)
addresses);
addresses = NULL;
}
-
+
if (addresses) { krb5_free_addresses (in_options->init_cred_context,
addresses); }
@@ -508,8 +508,125 @@ void kim_options_free (kim_options *io_options)
}
krb5_free_context ((*io_options)->init_cred_context);
}
-
+
free (*io_options);
*io_options = NULL;
}
}
+
+#pragma mark -
+
+/* ------------------------------------------------------------------------ */
+
+kim_error kim_options_write_to_stream (kim_options in_options,
+ k5_ipc_stream io_stream)
+{
+ kim_error err = KIM_NO_ERROR;
+
+ if (!err && !in_options) { err = check_error (KIM_NULL_PARAMETER_ERR); }
+ if (!err && !io_stream ) { err = check_error (KIM_NULL_PARAMETER_ERR); }
+
+ if (!err) {
+ err = k5_ipc_stream_write_int64 (io_stream, in_options->start_time);
+ }
+
+ if (!err) {
+ err = k5_ipc_stream_write_int64 (io_stream, in_options->lifetime);
+ }
+
+ if (!err) {
+ err = k5_ipc_stream_write_int32 (io_stream, in_options->renewable);
+ }
+
+ if (!err) {
+ err = k5_ipc_stream_write_int64 (io_stream,
+ in_options->renewal_lifetime);
+ }
+
+ if (!err) {
+ err = k5_ipc_stream_write_int32 (io_stream, in_options->forwardable);
+ }
+
+ if (!err) {
+ err = k5_ipc_stream_write_int32 (io_stream, in_options->proxiable);
+ }
+
+ if (!err) {
+ err = k5_ipc_stream_write_int32 (io_stream, in_options->addressless);
+ }
+
+ if (!err) {
+ kim_string service_name = (in_options->service_name ?
+ in_options->service_name : "");
+ err = k5_ipc_stream_write_string (io_stream, service_name);
+ }
+
+
+
+ return check_error (err);
+}
+
+/* ------------------------------------------------------------------------ */
+
+kim_error kim_options_create_from_stream (kim_options *out_options,
+ k5_ipc_stream io_stream)
+{
+ kim_error err = KIM_NO_ERROR;
+ kim_options options = NULL;
+
+ if (!err && !out_options) { err = check_error (KIM_NULL_PARAMETER_ERR); }
+ if (!err && !io_stream ) { err = check_error (KIM_NULL_PARAMETER_ERR); }
+
+ if (!err) {
+ err = kim_options_allocate (&options);
+ }
+
+ if (!err) {
+ err = k5_ipc_stream_read_int64 (io_stream, &options->start_time);
+ }
+
+ if (!err) {
+ err = k5_ipc_stream_read_int64 (io_stream, &options->lifetime);
+ }
+
+ if (!err) {
+ err = k5_ipc_stream_read_int32 (io_stream, &options->renewable);
+ }
+
+ if (!err) {
+ err = k5_ipc_stream_read_int64 (io_stream,
+ &options->renewal_lifetime);
+ }
+
+ if (!err) {
+ err = k5_ipc_stream_read_int32 (io_stream, &options->forwardable);
+ }
+
+ if (!err) {
+ err = k5_ipc_stream_read_int32 (io_stream, &options->proxiable);
+ }
+
+ if (!err) {
+ err = k5_ipc_stream_read_int32 (io_stream, &options->addressless);
+ }
+
+ if (!err) {
+ char *service_name = NULL;
+ err = k5_ipc_stream_read_string (io_stream, &service_name);
+
+ if (!err) {
+ err = kim_string_copy (&options->service_name, service_name);
+ }
+
+ k5_ipc_stream_free_string (service_name);
+ }
+
+ if (!err) {
+ *out_options = options;
+ options = NULL;
+ }
+
+ kim_options_free (&options);
+
+ return check_error (err);
+}