| 123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491492493494495496497498499500501502503504505506507508509510511512513514515516517518519520521522523524525526527528529530531532533534535536537538539540541542543544545546547548549550551552553554555556557558559560561562563564565566567568569570571572573574575576577578579580581582583584585586587588589590591592593594595596597598599600601602603604605606607608609610611612613614615616617618619620621622623624625626627628629630631632633634635636637638639640641642643644645646647648649650651652653654655656657658659660661662663664665666667668669670671672673674675676677678679680681682683684685686687688689690691692693694695696697698699700701702703704705706707708709710711712713714715716717718719720721722723724725726727728729730731732733734735736737738739740741742743744745746747748749750751752753754755756757758759760761762763764765766767768769770771772773774775776777778779780781782783784785786787788789790791792793794795796797798799800801802803804805806807808809810811812813814815816817818819820821822823824825826827828829830831832833834835836837838839840841842843844845846847848849850851852853854855856857858859860861862863864865866867868869870871872873874875876877878879880881882883884885886887888889890891892893894895896897898899900901902903904905906907908909910911912913914915916917918919920921922923924925926927928929930931932933934935936937938939940941942943944945946947948949950951952953954955956957958959960961962963964965966967968969970971972973974975976977978979980981982983984985986987988989990991992993994995996997998999100010011002100310041005100610071008100910101011101210131014101510161017101810191020102110221023102410251026102710281029103010311032103310341035103610371038103910401041104210431044104510461047104810491050105110521053105410551056105710581059106010611062106310641065106610671068106910701071107210731074107510761077107810791080108110821083108410851086108710881089109010911092109310941095109610971098109911001101110211031104110511061107110811091110111111121113111411151116111711181119112011211122112311241125112611271128112911301131113211331134113511361137113811391140114111421143114411451146114711481149115011511152115311541155115611571158115911601161116211631164116511661167116811691170117111721173117411751176117711781179118011811182118311841185118611871188118911901191119211931194119511961197119811991200120112021203120412051206120712081209121012111212121312141215121612171218121912201221122212231224122512261227122812291230123112321233123412351236123712381239124012411242124312441245124612471248124912501251125212531254125512561257125812591260126112621263126412651266126712681269127012711272127312741275127612771278127912801281128212831284128512861287128812891290129112921293129412951296129712981299130013011302130313041305130613071308130913101311131213131314131513161317131813191320132113221323132413251326132713281329133013311332133313341335133613371338133913401341134213431344134513461347134813491350135113521353135413551356135713581359136013611362136313641365136613671368136913701371137213731374137513761377137813791380138113821383138413851386138713881389139013911392139313941395139613971398139914001401140214031404140514061407140814091410141114121413141414151416141714181419142014211422142314241425142614271428142914301431143214331434143514361437143814391440144114421443144414451446144714481449145014511452145314541455145614571458145914601461146214631464146514661467146814691470147114721473147414751476147714781479148014811482148314841485148614871488148914901491149214931494149514961497149814991500150115021503150415051506150715081509151015111512151315141515151615171518151915201521152215231524152515261527152815291530153115321533153415351536153715381539154015411542154315441545154615471548154915501551155215531554155515561557155815591560156115621563156415651566156715681569157015711572157315741575157615771578157915801581158215831584158515861587158815891590159115921593159415951596159715981599160016011602160316041605160616071608160916101611161216131614161516161617 |
- /*
- * Copyright (c) 2008-2009 Red Hat, Inc.
- *
- * All rights reserved.
- *
- * Author: Christine Caulfield (ccaulfie@redhat.com)
- *
- * This software licensed under BSD license, the text of which follows:
- *
- * Redistribution and use in source and binary forms, with or without
- * modification, are permitted provided that the following conditions are met:
- *
- * - Redistributions of source code must retain the above copyright notice,
- * this list of conditions and the following disclaimer.
- * - Redistributions in binary form must reproduce the above copyright notice,
- * this list of conditions and the following disclaimer in the documentation
- * and/or other materials provided with the distribution.
- * - Neither the name of the MontaVista Software, Inc. nor the names of its
- * contributors may be used to endorse or promote products derived from this
- * software without specific prior written permission.
- *
- * THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS "AS IS"
- * AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE
- * IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE
- * ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT OWNER OR CONTRIBUTORS BE
- * LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR
- * CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF
- * SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS
- * INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN
- * CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE)
- * ARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF
- * THE POSSIBILITY OF SUCH DAMAGE.
- */
- /*
- * Provides access to data in the corosync object database
- */
- #include <config.h>
- #include <stdlib.h>
- #include <string.h>
- #include <unistd.h>
- #include <pthread.h>
- #include <sys/types.h>
- #include <errno.h>
- #include <corosync/corotypes.h>
- #include <corosync/confdb.h>
- #include <corosync/ipc_confdb.h>
- #include <corosync/mar_gen.h>
- #include <corosync/coroipcc.h>
- #include <corosync/list.h>
- #include "sa-confdb.h"
- #undef MIN
- #define MIN(x,y) ((x) < (y) ? (x) : (y))
- /* Hold the information for iterators so that
- callers can do recursive tree traversals.
- each object_handle can have its own iterator */
- struct iter_context {
- struct list_head list;
- hdb_handle_t parent_object_handle;
- hdb_handle_t find_handle;
- hdb_handle_t next_entry;
- };
- struct confdb_inst {
- void *ipc_ctx;
- int finalize;
- int standalone;
- confdb_callbacks_t callbacks;
- const void *context;
- pthread_mutex_t response_mutex;
- pthread_mutex_t dispatch_mutex;
- struct list_head object_find_head;
- struct list_head object_iter_head;
- struct list_head key_iter_head;
- };
- static void confdb_instance_destructor (void *instance);
- static struct saHandleDatabase confdb_handle_t_db = {
- .handleCount = 0,
- .handles = 0,
- .mutex = PTHREAD_MUTEX_INITIALIZER,
- .handleInstanceDestructor = confdb_instance_destructor
- };
- static cs_error_t do_find_destroy(struct confdb_inst *confdb_inst, hdb_handle_t find_handle);
- /* Safely tidy one iterator context list */
- static void free_context_list(struct confdb_inst *confdb_inst, struct list_head *list)
- {
- struct iter_context *context;
- struct list_head *iter, *tmp;
- for (iter = list->next, tmp = iter->next;
- iter != list; iter = tmp, tmp = iter->next) {
- context = list_entry (iter, struct iter_context, list);
- (void)do_find_destroy(confdb_inst, context->find_handle);
- free(context);
- }
- }
- /*
- * Clean up function for a confdb instance (confdb_initialize) handle
- */
- static void confdb_instance_destructor (void *instance)
- {
- struct confdb_inst *confdb_inst = instance;
- pthread_mutex_destroy (&confdb_inst->response_mutex);
- pthread_mutex_destroy (&confdb_inst->dispatch_mutex);
- }
- static struct iter_context *find_iter_context(struct list_head *list, hdb_handle_t object_handle)
- {
- struct iter_context *context;
- struct list_head *iter;
- for (iter = list->next;
- iter != list; iter = iter->next) {
- context = list_entry (iter, struct iter_context, list);
- if (context->parent_object_handle == object_handle)
- return context;
- }
- return NULL;
- }
- /**
- * @defgroup confdb_corosync
- * @ingroup corosync
- *
- * @{
- */
- cs_error_t confdb_initialize (
- confdb_handle_t *handle,
- confdb_callbacks_t *callbacks)
- {
- cs_error_t error;
- struct confdb_inst *confdb_inst;
- error = saHandleCreate (&confdb_handle_t_db, sizeof (struct confdb_inst), handle);
- if (error != CS_OK) {
- goto error_no_destroy;
- }
- error = saHandleInstanceGet (&confdb_handle_t_db, *handle, (void *)&confdb_inst);
- if (error != CS_OK) {
- goto error_destroy;
- }
- if (getenv("COROSYNC_DEFAULT_CONFIG_IFACE")) {
- error = confdb_sa_init();
- confdb_inst->standalone = 1;
- }
- else {
- error = coroipcc_service_connect (IPC_SOCKET_NAME, CONFDB_SERVICE, &confdb_inst->ipc_ctx);
- }
- if (error != CS_OK)
- goto error_put_destroy;
- memcpy (&confdb_inst->callbacks, callbacks, sizeof (confdb_callbacks_t));
- pthread_mutex_init (&confdb_inst->response_mutex, NULL);
- pthread_mutex_init (&confdb_inst->dispatch_mutex, NULL);
- list_init (&confdb_inst->object_find_head);
- list_init (&confdb_inst->object_iter_head);
- list_init (&confdb_inst->key_iter_head);
- (void)saHandleInstancePut (&confdb_handle_t_db, *handle);
- return (CS_OK);
- error_put_destroy:
- (void)saHandleInstancePut (&confdb_handle_t_db, *handle);
- error_destroy:
- (void)saHandleDestroy (&confdb_handle_t_db, *handle);
- error_no_destroy:
- return (error);
- }
- cs_error_t confdb_finalize (
- confdb_handle_t handle)
- {
- struct confdb_inst *confdb_inst;
- cs_error_t error;
- error = saHandleInstanceGet (&confdb_handle_t_db, handle, (void *)&confdb_inst);
- if (error != CS_OK) {
- return (error);
- }
- pthread_mutex_lock (&confdb_inst->response_mutex);
- /*
- * Another thread has already started finalizing
- */
- if (confdb_inst->finalize) {
- pthread_mutex_unlock (&confdb_inst->response_mutex);
- (void)saHandleInstancePut (&confdb_handle_t_db, handle);
- return (CS_ERR_BAD_HANDLE);
- }
- confdb_inst->finalize = 1;
- pthread_mutex_unlock (&confdb_inst->response_mutex);
- /* Free saved context handles */
- free_context_list(confdb_inst, &confdb_inst->object_find_head);
- free_context_list(confdb_inst, &confdb_inst->object_iter_head);
- free_context_list(confdb_inst, &confdb_inst->key_iter_head);
- if (!confdb_inst->standalone) {
- coroipcc_service_disconnect (confdb_inst->ipc_ctx);
- }
- (void)saHandleDestroy (&confdb_handle_t_db, handle);
- (void)saHandleInstancePut (&confdb_handle_t_db, handle);
- return (CS_OK);
- }
- cs_error_t confdb_fd_get (
- confdb_handle_t handle,
- int *fd)
- {
- cs_error_t error;
- struct confdb_inst *confdb_inst;
- error = saHandleInstanceGet (&confdb_handle_t_db, handle, (void *)&confdb_inst);
- if (error != CS_OK) {
- return (error);
- }
- *fd = coroipcc_fd_get (confdb_inst->ipc_ctx);
- (void)saHandleInstancePut (&confdb_handle_t_db, handle);
- return (CS_OK);
- }
- cs_error_t confdb_context_get (
- confdb_handle_t handle,
- const void **context)
- {
- cs_error_t error;
- struct confdb_inst *confdb_inst;
- error = saHandleInstanceGet (&confdb_handle_t_db, handle, (void *)&confdb_inst);
- if (error != CS_OK) {
- return (error);
- }
- *context = confdb_inst->context;
- (void)saHandleInstancePut (&confdb_handle_t_db, handle);
- return (CS_OK);
- }
- cs_error_t confdb_context_set (
- confdb_handle_t handle,
- const void *context)
- {
- cs_error_t error;
- struct confdb_inst *confdb_inst;
- error = saHandleInstanceGet (&confdb_handle_t_db, handle, (void *)&confdb_inst);
- if (error != CS_OK) {
- return (error);
- }
- confdb_inst->context = context;
- (void)saHandleInstancePut (&confdb_handle_t_db, handle);
- return (CS_OK);
- }
- struct confdb_res_overlay {
- mar_res_header_t header __attribute__((aligned(8)));
- char data[512000];
- };
- cs_error_t confdb_dispatch (
- confdb_handle_t handle,
- cs_dispatch_flags_t dispatch_types)
- {
- int timeout = -1;
- cs_error_t error;
- int cont = 1; /* always continue do loop except when set to 0 */
- int dispatch_avail;
- struct confdb_inst *confdb_inst;
- confdb_callbacks_t callbacks;
- struct res_lib_confdb_key_change_callback *res_key_changed_pt;
- struct res_lib_confdb_object_create_callback *res_object_created_pt;
- struct res_lib_confdb_object_destroy_callback *res_object_destroyed_pt;
- struct confdb_res_overlay dispatch_data;
- error = saHandleInstanceGet (&confdb_handle_t_db, handle, (void *)&confdb_inst);
- if (error != CS_OK) {
- return (error);
- }
- if (confdb_inst->standalone) {
- error = CS_ERR_NOT_SUPPORTED;
- goto error_put;
- }
- /*
- * Timeout instantly for SA_DISPATCH_ONE or SA_DISPATCH_ALL and
- * wait indefinately for SA_DISPATCH_BLOCKING
- */
- if (dispatch_types == CONFDB_DISPATCH_ALL) {
- timeout = 0;
- }
- do {
- pthread_mutex_lock (&confdb_inst->dispatch_mutex);
- dispatch_avail = coroipcc_dispatch_recv (confdb_inst->ipc_ctx,
- (void *)&dispatch_data,
- sizeof (dispatch_data),
- timeout);
- /*
- * Handle has been finalized in another thread
- */
- if (confdb_inst->finalize == 1) {
- error = CS_OK;
- pthread_mutex_unlock (&confdb_inst->dispatch_mutex);
- goto error_put;
- }
- if (dispatch_avail == 0 && dispatch_types == CONFDB_DISPATCH_ALL) {
- pthread_mutex_unlock (&confdb_inst->dispatch_mutex);
- break; /* exit do while cont is 1 loop */
- } else
- if (dispatch_avail == 0) {
- pthread_mutex_unlock (&confdb_inst->dispatch_mutex);
- continue; /* next poll */
- }
- /*
- * Make copy of callbacks, message data, unlock instance, and call callback
- * A risk of this dispatch method is that the callback routines may
- * operate at the same time that confdbFinalize has been called.
- */
- memcpy (&callbacks, &confdb_inst->callbacks, sizeof (confdb_callbacks_t));
- pthread_mutex_unlock (&confdb_inst->dispatch_mutex);
- /*
- * Dispatch incoming message
- */
- switch (dispatch_data.header.id) {
- case MESSAGE_RES_CONFDB_KEY_CHANGE_CALLBACK:
- res_key_changed_pt = (struct res_lib_confdb_key_change_callback *)&dispatch_data;
- callbacks.confdb_key_change_notify_fn(handle,
- res_key_changed_pt->change_type,
- res_key_changed_pt->object_handle,
- res_key_changed_pt->parent_object_handle,
- res_key_changed_pt->object_name.value,
- res_key_changed_pt->object_name.length,
- res_key_changed_pt->key_name.value,
- res_key_changed_pt->key_name.length,
- res_key_changed_pt->key_value.value,
- res_key_changed_pt->key_value.length);
- break;
- case MESSAGE_RES_CONFDB_OBJECT_CREATE_CALLBACK:
- res_object_created_pt = (struct res_lib_confdb_object_create_callback *)&dispatch_data;
- callbacks.confdb_object_create_change_notify_fn(handle,
- res_object_created_pt->object_handle,
- res_object_created_pt->parent_object_handle,
- res_object_created_pt->name.value,
- res_object_created_pt->name.length);
- break;
- case MESSAGE_RES_CONFDB_OBJECT_DESTROY_CALLBACK:
- res_object_destroyed_pt = (struct res_lib_confdb_object_destroy_callback *)&dispatch_data;
- callbacks.confdb_object_delete_change_notify_fn(handle,
- res_object_destroyed_pt->parent_object_handle,
- res_object_destroyed_pt->name.value,
- res_object_destroyed_pt->name.length);
- break;
- default:
- error = CS_ERR_LIBRARY;
- goto error_noput;
- break;
- }
- /*
- * Determine if more messages should be processed
- * */
- switch (dispatch_types) {
- case CONFDB_DISPATCH_ONE:
- cont = 0;
- break;
- case CONFDB_DISPATCH_ALL:
- break;
- case CONFDB_DISPATCH_BLOCKING:
- break;
- }
- } while (cont);
- error_put:
- (void)saHandleInstancePut (&confdb_handle_t_db, handle);
- error_noput:
- return (error);
- }
- cs_error_t confdb_object_create (
- confdb_handle_t handle,
- hdb_handle_t parent_object_handle,
- const void *object_name,
- size_t object_name_len,
- hdb_handle_t *object_handle)
- {
- cs_error_t error;
- struct confdb_inst *confdb_inst;
- struct iovec iov;
- struct req_lib_confdb_object_create req_lib_confdb_object_create;
- struct res_lib_confdb_object_create res_lib_confdb_object_create;
- error = saHandleInstanceGet (&confdb_handle_t_db, handle, (void *)&confdb_inst);
- if (error != CS_OK) {
- return (error);
- }
- if (confdb_inst->standalone) {
- error = CS_OK;
- if (confdb_sa_object_create(parent_object_handle,
- object_name, object_name_len,
- object_handle))
- error = CS_ERR_ACCESS;
- goto error_exit;
- }
- req_lib_confdb_object_create.header.size = sizeof (struct req_lib_confdb_object_create);
- req_lib_confdb_object_create.header.id = MESSAGE_REQ_CONFDB_OBJECT_CREATE;
- req_lib_confdb_object_create.parent_object_handle = parent_object_handle;
- memcpy(req_lib_confdb_object_create.object_name.value, object_name, object_name_len);
- req_lib_confdb_object_create.object_name.length = object_name_len;
- iov.iov_base = (char *)&req_lib_confdb_object_create;
- iov.iov_len = sizeof (struct req_lib_confdb_object_create);
- pthread_mutex_lock (&confdb_inst->response_mutex);
- error = coroipcc_msg_send_reply_receive (
- confdb_inst->ipc_ctx,
- &iov,
- 1,
- &res_lib_confdb_object_create,
- sizeof (struct res_lib_confdb_object_create));
- pthread_mutex_unlock (&confdb_inst->response_mutex);
- if (error != CS_OK) {
- goto error_exit;
- }
- error = res_lib_confdb_object_create.header.error;
- *object_handle = res_lib_confdb_object_create.object_handle;
- error_exit:
- (void)saHandleInstancePut (&confdb_handle_t_db, handle);
- return (error);
- }
- cs_error_t confdb_object_destroy (
- confdb_handle_t handle,
- hdb_handle_t object_handle)
- {
- cs_error_t error;
- struct confdb_inst *confdb_inst;
- struct iovec iov;
- struct req_lib_confdb_object_destroy req_lib_confdb_object_destroy;
- mar_res_header_t res;
- error = saHandleInstanceGet (&confdb_handle_t_db, handle, (void *)&confdb_inst);
- if (error != CS_OK) {
- return (error);
- }
- if (confdb_inst->standalone) {
- error = CS_OK;
- if (confdb_sa_object_destroy(object_handle))
- error = CS_ERR_ACCESS;
- goto error_exit;
- }
- req_lib_confdb_object_destroy.header.size = sizeof (struct req_lib_confdb_object_destroy);
- req_lib_confdb_object_destroy.header.id = MESSAGE_REQ_CONFDB_OBJECT_DESTROY;
- req_lib_confdb_object_destroy.object_handle = object_handle;
- iov.iov_base = (char *)&req_lib_confdb_object_destroy;
- iov.iov_len = sizeof (struct req_lib_confdb_object_destroy);
- pthread_mutex_lock (&confdb_inst->response_mutex);
- error = coroipcc_msg_send_reply_receive (
- confdb_inst->ipc_ctx,
- &iov,
- 1,
- &res,
- sizeof (mar_res_header_t));
- pthread_mutex_unlock (&confdb_inst->response_mutex);
- if (error != CS_OK) {
- goto error_exit;
- }
- error = res.error;
- error_exit:
- (void)saHandleInstancePut (&confdb_handle_t_db, handle);
- return (error);
- }
- cs_error_t confdb_object_parent_get (
- confdb_handle_t handle,
- hdb_handle_t object_handle,
- hdb_handle_t *parent_object_handle)
- {
- cs_error_t error;
- struct confdb_inst *confdb_inst;
- struct iovec iov;
- struct req_lib_confdb_object_parent_get req_lib_confdb_object_parent_get;
- struct res_lib_confdb_object_parent_get res_lib_confdb_object_parent_get;
- error = saHandleInstanceGet (&confdb_handle_t_db, handle, (void *)&confdb_inst);
- if (error != CS_OK) {
- return (error);
- }
- if (confdb_inst->standalone) {
- error = CS_OK;
- if (confdb_sa_object_parent_get(object_handle, parent_object_handle))
- error = CS_ERR_ACCESS;
- goto error_exit;
- }
- req_lib_confdb_object_parent_get.header.size = sizeof (struct req_lib_confdb_object_parent_get);
- req_lib_confdb_object_parent_get.header.id = MESSAGE_REQ_CONFDB_OBJECT_PARENT_GET;
- req_lib_confdb_object_parent_get.object_handle = object_handle;
- iov.iov_base = (char *)&req_lib_confdb_object_parent_get;
- iov.iov_len = sizeof (struct req_lib_confdb_object_parent_get);
- pthread_mutex_lock (&confdb_inst->response_mutex);
- error = coroipcc_msg_send_reply_receive (
- confdb_inst->ipc_ctx,
- &iov,
- 1,
- &res_lib_confdb_object_parent_get,
- sizeof (struct res_lib_confdb_object_parent_get));
- pthread_mutex_unlock (&confdb_inst->response_mutex);
- if (error != CS_OK) {
- goto error_exit;
- }
- error = res_lib_confdb_object_parent_get.header.error;
- *parent_object_handle = res_lib_confdb_object_parent_get.parent_object_handle;
- error_exit:
- (void)saHandleInstancePut (&confdb_handle_t_db, handle);
- return (error);
- }
- static cs_error_t do_find_destroy(
- struct confdb_inst *confdb_inst,
- hdb_handle_t find_handle)
- {
- cs_error_t error;
- struct iovec iov;
- struct req_lib_confdb_object_find_destroy req_lib_confdb_object_find_destroy;
- mar_res_header_t res;
- if (!find_handle)
- return CS_OK;
- if (confdb_inst->standalone) {
- error = CS_OK;
- if (confdb_sa_find_destroy(find_handle))
- error = CS_ERR_ACCESS;
- goto error_exit;
- }
- req_lib_confdb_object_find_destroy.header.size = sizeof (struct req_lib_confdb_object_find_destroy);
- req_lib_confdb_object_find_destroy.header.id = MESSAGE_REQ_CONFDB_OBJECT_FIND_DESTROY;
- req_lib_confdb_object_find_destroy.find_handle = find_handle;
- iov.iov_base = (char *)&req_lib_confdb_object_find_destroy;
- iov.iov_len = sizeof (struct req_lib_confdb_object_find_destroy);
- pthread_mutex_lock (&confdb_inst->response_mutex);
- error = coroipcc_msg_send_reply_receive (
- confdb_inst->ipc_ctx,
- &iov,
- 1,
- &res,
- sizeof (mar_res_header_t));
- pthread_mutex_unlock (&confdb_inst->response_mutex);
- if (error != CS_OK) {
- goto error_exit;
- }
- error = res.error;
- error_exit:
- return (error);
- }
- cs_error_t confdb_object_find_destroy(
- confdb_handle_t handle,
- hdb_handle_t parent_object_handle)
- {
- struct iter_context *context;
- cs_error_t error;
- struct confdb_inst *confdb_inst;
- error = saHandleInstanceGet (&confdb_handle_t_db, handle, (void *)&confdb_inst);
- if (error != CS_OK) {
- return (error);
- }
- context = find_iter_context(&confdb_inst->object_find_head, parent_object_handle);
- error = do_find_destroy(confdb_inst, context->find_handle);
- if (error == CS_OK) {
- list_del(&context->list);
- free(context);
- }
- (void)saHandleInstancePut (&confdb_handle_t_db, handle);
- return error;
- }
- cs_error_t confdb_object_iter_destroy(
- confdb_handle_t handle,
- hdb_handle_t parent_object_handle)
- {
- struct iter_context *context;
- cs_error_t error;
- struct confdb_inst *confdb_inst;
- error = saHandleInstanceGet (&confdb_handle_t_db, handle, (void *)&confdb_inst);
- if (error != CS_OK) {
- return (error);
- }
- context = find_iter_context(&confdb_inst->object_iter_head, parent_object_handle);
- error = do_find_destroy(confdb_inst, context->find_handle);
- if (error == CS_OK) {
- list_del(&context->list);
- free(context);
- }
- (void)saHandleInstancePut (&confdb_handle_t_db, handle);
- return error;
- }
- cs_error_t confdb_key_create (
- confdb_handle_t handle,
- hdb_handle_t parent_object_handle,
- const void *key_name,
- size_t key_name_len,
- const void *value,
- size_t value_len)
- {
- cs_error_t error;
- struct confdb_inst *confdb_inst;
- struct iovec iov;
- struct req_lib_confdb_key_create req_lib_confdb_key_create;
- mar_res_header_t res;
- error = saHandleInstanceGet (&confdb_handle_t_db, handle, (void *)&confdb_inst);
- if (error != CS_OK) {
- return (error);
- }
- if (confdb_inst->standalone) {
- error = CS_OK;
- if (confdb_sa_key_create(parent_object_handle,
- key_name, key_name_len,
- value, value_len))
- error = CS_ERR_ACCESS;
- goto error_exit;
- }
- req_lib_confdb_key_create.header.size = sizeof (struct req_lib_confdb_key_create);
- req_lib_confdb_key_create.header.id = MESSAGE_REQ_CONFDB_KEY_CREATE;
- req_lib_confdb_key_create.object_handle = parent_object_handle;
- memcpy(req_lib_confdb_key_create.key_name.value, key_name, key_name_len);
- req_lib_confdb_key_create.key_name.length = key_name_len;
- memcpy(req_lib_confdb_key_create.value.value, value, value_len);
- req_lib_confdb_key_create.value.length = value_len;
- iov.iov_base = (char *)&req_lib_confdb_key_create;
- iov.iov_len = sizeof (struct req_lib_confdb_key_create);
- pthread_mutex_lock (&confdb_inst->response_mutex);
- error = coroipcc_msg_send_reply_receive (
- confdb_inst->ipc_ctx,
- &iov,
- 1,
- &res,
- sizeof (res));
- pthread_mutex_unlock (&confdb_inst->response_mutex);
- if (error != CS_OK) {
- goto error_exit;
- }
- error = res.error;
- error_exit:
- (void)saHandleInstancePut (&confdb_handle_t_db, handle);
- return (error);
- }
- cs_error_t confdb_key_delete (
- confdb_handle_t handle,
- hdb_handle_t parent_object_handle,
- const void *key_name,
- size_t key_name_len,
- const void *value,
- size_t value_len)
- {
- cs_error_t error;
- struct confdb_inst *confdb_inst;
- struct iovec iov;
- struct req_lib_confdb_key_delete req_lib_confdb_key_delete;
- mar_res_header_t res;
- error = saHandleInstanceGet (&confdb_handle_t_db, handle, (void *)&confdb_inst);
- if (error != CS_OK) {
- return (error);
- }
- if (confdb_inst->standalone) {
- error = CS_OK;
- if (confdb_sa_key_delete(parent_object_handle,
- key_name, key_name_len,
- value, value_len))
- error = CS_ERR_ACCESS;
- goto error_exit;
- }
- req_lib_confdb_key_delete.header.size = sizeof (struct req_lib_confdb_key_delete);
- req_lib_confdb_key_delete.header.id = MESSAGE_REQ_CONFDB_KEY_DELETE;
- req_lib_confdb_key_delete.object_handle = parent_object_handle;
- memcpy(req_lib_confdb_key_delete.key_name.value, key_name, key_name_len);
- req_lib_confdb_key_delete.key_name.length = key_name_len;
- memcpy(req_lib_confdb_key_delete.value.value, value, value_len);
- req_lib_confdb_key_delete.value.length = value_len;
- iov.iov_base = (char *)&req_lib_confdb_key_delete;
- iov.iov_len = sizeof (struct req_lib_confdb_key_delete);
- pthread_mutex_lock (&confdb_inst->response_mutex);
- error = coroipcc_msg_send_reply_receive (
- confdb_inst->ipc_ctx,
- &iov,
- 1,
- &res,
- sizeof (res));
- pthread_mutex_unlock (&confdb_inst->response_mutex);
- if (error != CS_OK) {
- goto error_exit;
- }
- error = res.error;
- error_exit:
- (void)saHandleInstancePut (&confdb_handle_t_db, handle);
- return (error);
- }
- cs_error_t confdb_key_get (
- confdb_handle_t handle,
- hdb_handle_t parent_object_handle,
- const void *key_name,
- size_t key_name_len,
- void *value,
- size_t *value_len)
- {
- cs_error_t error;
- struct confdb_inst *confdb_inst;
- struct iovec iov;
- struct req_lib_confdb_key_get req_lib_confdb_key_get;
- struct res_lib_confdb_key_get res_lib_confdb_key_get;
- error = saHandleInstanceGet (&confdb_handle_t_db, handle, (void *)&confdb_inst);
- if (error != CS_OK) {
- return (error);
- }
- if (confdb_inst->standalone) {
- error = CS_OK;
- if (confdb_sa_key_get(parent_object_handle,
- key_name, key_name_len,
- value, value_len))
- error = CS_ERR_ACCESS;
- goto error_exit;
- }
- req_lib_confdb_key_get.header.size = sizeof (struct req_lib_confdb_key_get);
- req_lib_confdb_key_get.header.id = MESSAGE_REQ_CONFDB_KEY_GET;
- req_lib_confdb_key_get.parent_object_handle = parent_object_handle;
- memcpy(req_lib_confdb_key_get.key_name.value, key_name, key_name_len);
- req_lib_confdb_key_get.key_name.length = key_name_len;
- iov.iov_base = (char *)&req_lib_confdb_key_get;
- iov.iov_len = sizeof (struct req_lib_confdb_key_get);
- pthread_mutex_lock (&confdb_inst->response_mutex);
- error = coroipcc_msg_send_reply_receive (
- confdb_inst->ipc_ctx,
- &iov,
- 1,
- &res_lib_confdb_key_get,
- sizeof (struct res_lib_confdb_key_get));
- pthread_mutex_unlock (&confdb_inst->response_mutex);
- if (error != CS_OK) {
- goto error_exit;
- }
- error = res_lib_confdb_key_get.header.error;
- if (error == CS_OK) {
- *value_len = res_lib_confdb_key_get.value.length;
- memcpy(value, res_lib_confdb_key_get.value.value, *value_len);
- }
- error_exit:
- (void)saHandleInstancePut (&confdb_handle_t_db, handle);
- return (error);
- }
- cs_error_t confdb_key_increment (
- confdb_handle_t handle,
- hdb_handle_t parent_object_handle,
- const void *key_name,
- size_t key_name_len,
- unsigned int *value)
- {
- cs_error_t error;
- struct confdb_inst *confdb_inst;
- struct iovec iov;
- struct req_lib_confdb_key_get req_lib_confdb_key_get;
- struct res_lib_confdb_key_incdec res_lib_confdb_key_incdec;
- error = saHandleInstanceGet (&confdb_handle_t_db, handle, (void *)&confdb_inst);
- if (error != CS_OK) {
- return (error);
- }
- if (confdb_inst->standalone) {
- error = CS_OK;
- if (confdb_sa_key_increment(parent_object_handle,
- key_name, key_name_len,
- value))
- error = CS_ERR_ACCESS;
- goto error_exit;
- }
- req_lib_confdb_key_get.header.size = sizeof (struct req_lib_confdb_key_get);
- req_lib_confdb_key_get.header.id = MESSAGE_REQ_CONFDB_KEY_INCREMENT;
- req_lib_confdb_key_get.parent_object_handle = parent_object_handle;
- memcpy(req_lib_confdb_key_get.key_name.value, key_name, key_name_len);
- req_lib_confdb_key_get.key_name.length = key_name_len;
- iov.iov_base = (char *)&req_lib_confdb_key_get;
- iov.iov_len = sizeof (struct req_lib_confdb_key_get);
- pthread_mutex_lock (&confdb_inst->response_mutex);
- error = coroipcc_msg_send_reply_receive (
- confdb_inst->ipc_ctx,
- &iov,
- 1,
- &res_lib_confdb_key_incdec,
- sizeof (struct res_lib_confdb_key_incdec));
- pthread_mutex_unlock (&confdb_inst->response_mutex);
- if (error != CS_OK) {
- goto error_exit;
- }
- error = res_lib_confdb_key_incdec.header.error;
- if (error == CS_OK) {
- *value = res_lib_confdb_key_incdec.value;
- }
- error_exit:
- (void)saHandleInstancePut (&confdb_handle_t_db, handle);
- return (error);
- }
- cs_error_t confdb_key_decrement (
- confdb_handle_t handle,
- hdb_handle_t parent_object_handle,
- const void *key_name,
- size_t key_name_len,
- unsigned int *value)
- {
- cs_error_t error;
- struct confdb_inst *confdb_inst;
- struct iovec iov;
- struct req_lib_confdb_key_get req_lib_confdb_key_get;
- struct res_lib_confdb_key_incdec res_lib_confdb_key_incdec;
- error = saHandleInstanceGet (&confdb_handle_t_db, handle, (void *)&confdb_inst);
- if (error != CS_OK) {
- return (error);
- }
- if (confdb_inst->standalone) {
- error = CS_OK;
- if (confdb_sa_key_decrement(parent_object_handle,
- key_name, key_name_len,
- value))
- error = CS_ERR_ACCESS;
- goto error_exit;
- }
- req_lib_confdb_key_get.header.size = sizeof (struct req_lib_confdb_key_get);
- req_lib_confdb_key_get.header.id = MESSAGE_REQ_CONFDB_KEY_DECREMENT;
- req_lib_confdb_key_get.parent_object_handle = parent_object_handle;
- memcpy(req_lib_confdb_key_get.key_name.value, key_name, key_name_len);
- req_lib_confdb_key_get.key_name.length = key_name_len;
- iov.iov_base = (char *)&req_lib_confdb_key_get;
- iov.iov_len = sizeof (struct req_lib_confdb_key_get);
- pthread_mutex_lock (&confdb_inst->response_mutex);
- error = coroipcc_msg_send_reply_receive (
- confdb_inst->ipc_ctx,
- &iov,
- 1,
- &res_lib_confdb_key_incdec,
- sizeof (struct res_lib_confdb_key_incdec));
- pthread_mutex_unlock (&confdb_inst->response_mutex);
- if (error != CS_OK) {
- goto error_exit;
- }
- error = res_lib_confdb_key_incdec.header.error;
- if (error == CS_OK) {
- *value = res_lib_confdb_key_incdec.value;
- }
- error_exit:
- (void)saHandleInstancePut (&confdb_handle_t_db, handle);
- return (error);
- }
- cs_error_t confdb_key_replace (
- confdb_handle_t handle,
- hdb_handle_t parent_object_handle,
- const void *key_name,
- size_t key_name_len,
- const void *old_value,
- size_t old_value_len,
- const void *new_value,
- size_t new_value_len)
- {
- cs_error_t error;
- struct confdb_inst *confdb_inst;
- struct iovec iov;
- struct req_lib_confdb_key_replace req_lib_confdb_key_replace;
- mar_res_header_t res;
- error = saHandleInstanceGet (&confdb_handle_t_db, handle, (void *)&confdb_inst);
- if (error != CS_OK) {
- return (error);
- }
- if (confdb_inst->standalone) {
- error = CS_OK;
- if (confdb_sa_key_replace(parent_object_handle,
- key_name, key_name_len,
- old_value, old_value_len,
- new_value, new_value_len))
- error = CS_ERR_ACCESS;
- goto error_exit;
- }
- req_lib_confdb_key_replace.header.size = sizeof (struct req_lib_confdb_key_replace);
- req_lib_confdb_key_replace.header.id = MESSAGE_REQ_CONFDB_KEY_REPLACE;
- req_lib_confdb_key_replace.object_handle = parent_object_handle;
- memcpy(req_lib_confdb_key_replace.key_name.value, key_name, key_name_len);
- req_lib_confdb_key_replace.key_name.length = key_name_len;
- memcpy(req_lib_confdb_key_replace.old_value.value, old_value, old_value_len);
- req_lib_confdb_key_replace.old_value.length = old_value_len;
- memcpy(req_lib_confdb_key_replace.new_value.value, new_value, new_value_len);
- req_lib_confdb_key_replace.new_value.length = new_value_len;
- iov.iov_base = (char *)&req_lib_confdb_key_replace;
- iov.iov_len = sizeof (struct req_lib_confdb_key_replace);
- pthread_mutex_lock (&confdb_inst->response_mutex);
- error = coroipcc_msg_send_reply_receive (
- confdb_inst->ipc_ctx,
- &iov,
- 1,
- &res,
- sizeof (res));
- pthread_mutex_unlock (&confdb_inst->response_mutex);
- if (error != CS_OK) {
- goto error_exit;
- }
- error = res.error;
- error_exit:
- (void)saHandleInstancePut (&confdb_handle_t_db, handle);
- return (error);
- }
- cs_error_t confdb_object_iter_start (
- confdb_handle_t handle,
- hdb_handle_t object_handle)
- {
- struct confdb_inst *confdb_inst;
- cs_error_t error = CS_OK;
- struct iter_context *context;
- error = saHandleInstanceGet (&confdb_handle_t_db, handle, (void *)&confdb_inst);
- if (error != CS_OK) {
- return (error);
- }
- context = find_iter_context(&confdb_inst->object_iter_head, object_handle);
- if (!context) {
- context = malloc(sizeof(struct iter_context));
- if (!context) {
- error = CS_ERR_NO_MEMORY;
- goto ret;
- }
- context->parent_object_handle = object_handle;
- context->find_handle = 0;
- list_add(&context->list, &confdb_inst->object_iter_head);
- }
- /* Start a new find context */
- if (context->find_handle) {
- (void)do_find_destroy(confdb_inst, context->find_handle);
- context->find_handle = 0;
- }
- (void)saHandleInstancePut (&confdb_handle_t_db, handle);
- ret:
- return error;
- }
- cs_error_t confdb_key_iter_start (
- confdb_handle_t handle,
- hdb_handle_t object_handle)
- {
- struct confdb_inst *confdb_inst;
- cs_error_t error = CS_OK;
- struct iter_context *context;
- error = saHandleInstanceGet (&confdb_handle_t_db, handle, (void *)&confdb_inst);
- if (error != CS_OK) {
- return (error);
- }
- context = find_iter_context(&confdb_inst->key_iter_head, object_handle);
- if (!context) {
- context = malloc(sizeof(struct iter_context));
- if (!context) {
- error = CS_ERR_NO_MEMORY;
- goto ret;
- }
- context->parent_object_handle = object_handle;
- list_add(&context->list, &confdb_inst->key_iter_head);
- }
- context->find_handle = 0;
- context->next_entry = 0;
- (void)saHandleInstancePut (&confdb_handle_t_db, handle);
- ret:
- return error;
- }
- cs_error_t confdb_object_find_start (
- confdb_handle_t handle,
- hdb_handle_t parent_object_handle)
- {
- struct confdb_inst *confdb_inst;
- cs_error_t error = CS_OK;
- struct iter_context *context;
- error = saHandleInstanceGet (&confdb_handle_t_db, handle, (void *)&confdb_inst);
- if (error != CS_OK) {
- return (error);
- }
- context = find_iter_context(&confdb_inst->object_find_head, parent_object_handle);
- if (!context) {
- context = malloc(sizeof(struct iter_context));
- if (!context) {
- error = CS_ERR_NO_MEMORY;
- goto ret;
- }
- context->find_handle = 0;
- context->parent_object_handle = parent_object_handle;
- list_add(&context->list, &confdb_inst->object_find_head);
- }
- /* Start a new find context */
- if (context->find_handle) {
- (void)do_find_destroy(confdb_inst, context->find_handle);
- context->find_handle = 0;
- }
- (void)saHandleInstancePut (&confdb_handle_t_db, handle);
- ret:
- return error;
- }
- cs_error_t confdb_object_find (
- confdb_handle_t handle,
- hdb_handle_t parent_object_handle,
- const void *object_name,
- size_t object_name_len,
- hdb_handle_t *object_handle)
- {
- cs_error_t error;
- struct confdb_inst *confdb_inst;
- struct iovec iov;
- struct iter_context *context;
- struct req_lib_confdb_object_find req_lib_confdb_object_find;
- struct res_lib_confdb_object_find res_lib_confdb_object_find;
- error = saHandleInstanceGet (&confdb_handle_t_db, handle, (void *)&confdb_inst);
- if (error != CS_OK) {
- return (error);
- }
- /* You MUST call confdb_object_find_start first */
- context = find_iter_context(&confdb_inst->object_find_head, parent_object_handle);
- if (!context) {
- error = CS_ERR_CONTEXT_NOT_FOUND;
- goto error_exit;
- }
- if (confdb_inst->standalone) {
- error = CS_OK;
- if (confdb_sa_object_find(parent_object_handle,
- &context->find_handle,
- object_handle,
- object_name, object_name_len))
- error = CS_ERR_ACCESS;
- goto error_exit;
- }
- req_lib_confdb_object_find.header.size = sizeof (struct req_lib_confdb_object_find);
- req_lib_confdb_object_find.header.id = MESSAGE_REQ_CONFDB_OBJECT_FIND;
- req_lib_confdb_object_find.parent_object_handle = parent_object_handle;
- req_lib_confdb_object_find.find_handle = context->find_handle;
- memcpy(req_lib_confdb_object_find.object_name.value, object_name, object_name_len);
- req_lib_confdb_object_find.object_name.length = object_name_len;
- iov.iov_base = (char *)&req_lib_confdb_object_find;
- iov.iov_len = sizeof (struct req_lib_confdb_object_find);
- pthread_mutex_lock (&confdb_inst->response_mutex);
- error = coroipcc_msg_send_reply_receive (
- confdb_inst->ipc_ctx,
- &iov,
- 1,
- &res_lib_confdb_object_find,
- sizeof (struct res_lib_confdb_object_find));
- pthread_mutex_unlock (&confdb_inst->response_mutex);
- if (error != CS_OK) {
- goto error_exit;
- }
- error = res_lib_confdb_object_find.header.error;
- *object_handle = res_lib_confdb_object_find.object_handle;
- context->find_handle = res_lib_confdb_object_find.find_handle;
- error_exit:
- (void)saHandleInstancePut (&confdb_handle_t_db, handle);
- return (error);
- }
- cs_error_t confdb_object_iter (
- confdb_handle_t handle,
- hdb_handle_t parent_object_handle,
- hdb_handle_t *object_handle,
- void *object_name,
- size_t *object_name_len)
- {
- cs_error_t error;
- struct confdb_inst *confdb_inst;
- struct iovec iov;
- struct iter_context *context;
- struct req_lib_confdb_object_iter req_lib_confdb_object_iter;
- struct res_lib_confdb_object_iter res_lib_confdb_object_iter;
- error = saHandleInstanceGet (&confdb_handle_t_db, handle, (void *)&confdb_inst);
- if (error != CS_OK) {
- return (error);
- }
- /* You MUST call confdb_object_iter_start first */
- context = find_iter_context(&confdb_inst->object_iter_head, parent_object_handle);
- if (!context) {
- error = CS_ERR_CONTEXT_NOT_FOUND;
- goto error_exit;
- }
- if (confdb_inst->standalone) {
- error = CS_OK;
- *object_name_len = 0;
- if (confdb_sa_object_iter(parent_object_handle,
- &context->find_handle,
- object_handle,
- NULL, 0,
- object_name, object_name_len))
- error = CS_ERR_ACCESS;
- goto sa_exit;
- }
- req_lib_confdb_object_iter.header.size = sizeof (struct req_lib_confdb_object_iter);
- req_lib_confdb_object_iter.header.id = MESSAGE_REQ_CONFDB_OBJECT_ITER;
- req_lib_confdb_object_iter.parent_object_handle = parent_object_handle;
- req_lib_confdb_object_iter.find_handle = context->find_handle;
- iov.iov_base = (char *)&req_lib_confdb_object_iter;
- iov.iov_len = sizeof (struct req_lib_confdb_object_iter);
- pthread_mutex_lock (&confdb_inst->response_mutex);
- error = coroipcc_msg_send_reply_receive (
- confdb_inst->ipc_ctx,
- &iov,
- 1,
- &res_lib_confdb_object_iter,
- sizeof (struct res_lib_confdb_object_iter));
- pthread_mutex_unlock (&confdb_inst->response_mutex);
- if (error != CS_OK) {
- goto error_exit;
- }
- error = res_lib_confdb_object_iter.header.error;
- if (error == CS_OK) {
- *object_name_len = res_lib_confdb_object_iter.object_name.length;
- memcpy(object_name, res_lib_confdb_object_iter.object_name.value, *object_name_len);
- *object_handle = res_lib_confdb_object_iter.object_handle;
- context->find_handle = res_lib_confdb_object_iter.find_handle;
- }
- sa_exit:
- error_exit:
- (void)saHandleInstancePut (&confdb_handle_t_db, handle);
- return (error);
- }
- cs_error_t confdb_key_iter (
- confdb_handle_t handle,
- hdb_handle_t parent_object_handle,
- void *key_name,
- size_t *key_name_len,
- void *value,
- size_t *value_len)
- {
- cs_error_t error;
- struct confdb_inst *confdb_inst;
- struct iovec iov;
- struct iter_context *context;
- struct req_lib_confdb_key_iter req_lib_confdb_key_iter;
- struct res_lib_confdb_key_iter res_lib_confdb_key_iter;
- error = saHandleInstanceGet (&confdb_handle_t_db, handle, (void *)&confdb_inst);
- if (error != CS_OK) {
- return (error);
- }
- /* You MUST call confdb_key_iter_start first */
- context = find_iter_context(&confdb_inst->key_iter_head, parent_object_handle);
- if (!context) {
- error = CS_ERR_CONTEXT_NOT_FOUND;
- goto error_exit;
- }
- if (confdb_inst->standalone) {
- error = CS_OK;
- if (confdb_sa_key_iter(parent_object_handle,
- context->next_entry,
- key_name, key_name_len,
- value, value_len))
- error = CS_ERR_ACCESS;
- goto sa_exit;
- }
- req_lib_confdb_key_iter.header.size = sizeof (struct req_lib_confdb_key_iter);
- req_lib_confdb_key_iter.header.id = MESSAGE_REQ_CONFDB_KEY_ITER;
- req_lib_confdb_key_iter.parent_object_handle = parent_object_handle;
- req_lib_confdb_key_iter.next_entry= context->next_entry;
- iov.iov_base = (char *)&req_lib_confdb_key_iter;
- iov.iov_len = sizeof (struct req_lib_confdb_key_iter);
- pthread_mutex_lock (&confdb_inst->response_mutex);
- error = coroipcc_msg_send_reply_receive (
- confdb_inst->ipc_ctx,
- &iov,
- 1,
- &res_lib_confdb_key_iter,
- sizeof (struct res_lib_confdb_key_iter));
- pthread_mutex_unlock (&confdb_inst->response_mutex);
- if (error != CS_OK) {
- goto error_exit;
- }
- error = res_lib_confdb_key_iter.header.error;
- if (error == CS_OK) {
- *key_name_len = res_lib_confdb_key_iter.key_name.length;
- memcpy(key_name, res_lib_confdb_key_iter.key_name.value, *key_name_len);
- *value_len = res_lib_confdb_key_iter.value.length;
- memcpy(value, res_lib_confdb_key_iter.value.value, *value_len);
- }
- sa_exit:
- context->next_entry++;
- error_exit:
- (void)saHandleInstancePut (&confdb_handle_t_db, handle);
- return (error);
- }
- cs_error_t confdb_write (
- confdb_handle_t handle,
- char *error_text,
- size_t errbuf_len)
- {
- cs_error_t error;
- struct confdb_inst *confdb_inst;
- struct iovec iov;
- mar_req_header_t req;
- struct res_lib_confdb_write res_lib_confdb_write;
- error = saHandleInstanceGet (&confdb_handle_t_db, handle, (void *)&confdb_inst);
- if (error != CS_OK) {
- /* FIXME: set error_text */
- return (error);
- }
- if (confdb_inst->standalone) {
- error = CS_OK;
- if (confdb_sa_write(error_text, errbuf_len))
- error = CS_ERR_ACCESS;
- goto error_exit;
- }
- req.size = sizeof (mar_req_header_t);
- req.id = MESSAGE_REQ_CONFDB_WRITE;
- iov.iov_base = (char *)&req;
- iov.iov_len = sizeof (mar_req_header_t);
- pthread_mutex_lock (&confdb_inst->response_mutex);
- error = coroipcc_msg_send_reply_receive (
- confdb_inst->ipc_ctx,
- &iov,
- 1,
- &res_lib_confdb_write,
- sizeof (struct res_lib_confdb_write));
- pthread_mutex_unlock (&confdb_inst->response_mutex);
- if (error != CS_OK) {
- /* FIXME: set error_text */
- goto error_exit;
- }
- error = res_lib_confdb_write.header.error;
- if (res_lib_confdb_write.error.length) {
- memcpy(error_text, res_lib_confdb_write.error.value,
- MIN(res_lib_confdb_write.error.length,errbuf_len));
- error_text[errbuf_len-1] = '\0';
- }
- error_exit:
- (void)saHandleInstancePut (&confdb_handle_t_db, handle);
- return (error);
- }
- cs_error_t confdb_reload (
- confdb_handle_t handle,
- int flush,
- char *error_text,
- size_t errbuf_len)
- {
- cs_error_t error;
- struct confdb_inst *confdb_inst;
- struct iovec iov;
- struct res_lib_confdb_reload res_lib_confdb_reload;
- struct req_lib_confdb_reload req_lib_confdb_reload;
- error = saHandleInstanceGet (&confdb_handle_t_db, handle, (void *)&confdb_inst);
- if (error != CS_OK) {
- /* FIXME: set error_text */
- return (error);
- }
- if (confdb_inst->standalone) {
- error = CS_OK;
- if (confdb_sa_reload(flush, error_text, errbuf_len))
- error = CS_ERR_ACCESS;
- goto error_exit;
- }
- req_lib_confdb_reload.header.size = sizeof (req_lib_confdb_reload);
- req_lib_confdb_reload.header.id = MESSAGE_REQ_CONFDB_RELOAD;
- req_lib_confdb_reload.flush = flush;
- iov.iov_base = (char *)&req_lib_confdb_reload;
- iov.iov_len = sizeof (req_lib_confdb_reload);
- pthread_mutex_lock (&confdb_inst->response_mutex);
- error = coroipcc_msg_send_reply_receive (
- confdb_inst->ipc_ctx,
- &iov,
- 1,
- &res_lib_confdb_reload,
- sizeof (struct res_lib_confdb_reload));
- pthread_mutex_unlock (&confdb_inst->response_mutex);
- if (error != CS_OK) {
- /* FIXME: set error_text */
- goto error_exit;
- }
- error = res_lib_confdb_reload.header.error;
- if(res_lib_confdb_reload.error.length) {
- memcpy(error_text, res_lib_confdb_reload.error.value,
- MIN(res_lib_confdb_reload.error.length,errbuf_len));
- error_text[errbuf_len-1] = '\0';
- }
- error_exit:
- (void)saHandleInstancePut (&confdb_handle_t_db, handle);
- return (error);
- }
- cs_error_t confdb_track_changes (
- confdb_handle_t handle,
- hdb_handle_t object_handle,
- unsigned int flags)
- {
- cs_error_t error;
- struct confdb_inst *confdb_inst;
- struct iovec iov;
- struct req_lib_confdb_object_track_start req;
- mar_res_header_t res;
- error = saHandleInstanceGet (&confdb_handle_t_db, handle, (void *)&confdb_inst);
- if (error != CS_OK) {
- return (error);
- }
- if (confdb_inst->standalone) {
- error = CS_ERR_NOT_SUPPORTED;
- goto error_exit;
- }
- req.header.size = sizeof (struct req_lib_confdb_object_track_start);
- req.header.id = MESSAGE_REQ_CONFDB_TRACK_START;
- req.object_handle = object_handle;
- req.flags = flags;
- iov.iov_base = (char *)&req;
- iov.iov_len = sizeof (struct req_lib_confdb_object_track_start);
- pthread_mutex_lock (&confdb_inst->response_mutex);
- error = coroipcc_msg_send_reply_receive (
- confdb_inst->ipc_ctx,
- &iov,
- 1,
- &res,
- sizeof (mar_res_header_t));
- pthread_mutex_unlock (&confdb_inst->response_mutex);
- if (error != CS_OK) {
- goto error_exit;
- }
- error = res.error;
- error_exit:
- (void)saHandleInstancePut (&confdb_handle_t_db, handle);
- return (error);
- }
- cs_error_t confdb_stop_track_changes (confdb_handle_t handle)
- {
- cs_error_t error;
- struct confdb_inst *confdb_inst;
- struct iovec iov;
- mar_req_header_t req;
- mar_res_header_t res;
- error = saHandleInstanceGet (&confdb_handle_t_db, handle, (void *)&confdb_inst);
- if (error != CS_OK) {
- return (error);
- }
- if (confdb_inst->standalone) {
- error = CS_ERR_NOT_SUPPORTED;
- goto error_exit;
- }
- req.size = sizeof (mar_req_header_t);
- req.id = MESSAGE_REQ_CONFDB_TRACK_STOP;
- iov.iov_base = (char *)&req;
- iov.iov_len = sizeof (mar_req_header_t);
- pthread_mutex_lock (&confdb_inst->response_mutex);
- error = coroipcc_msg_send_reply_receive (
- confdb_inst->ipc_ctx,
- &iov,
- 1,
- &res,
- sizeof (mar_res_header_t));
- pthread_mutex_unlock (&confdb_inst->response_mutex);
- if (error != CS_OK) {
- goto error_exit;
- }
- error = res.error;
- error_exit:
- (void)saHandleInstancePut (&confdb_handle_t_db, handle);
- return (error);
- }
|