summaryrefslogtreecommitdiff
path: root/server
diff options
context:
space:
mode:
Diffstat (limited to 'server')
-rw-r--r--server/nss/nsssrv.c35
-rw-r--r--server/providers/data_provider.c34
2 files changed, 20 insertions, 49 deletions
diff --git a/server/nss/nsssrv.c b/server/nss/nsssrv.c
index 764de846..d66fe90c 100644
--- a/server/nss/nsssrv.c
+++ b/server/nss/nsssrv.c
@@ -245,8 +245,6 @@ static int reply_ping(DBusMessage *message, void *data, DBusMessage **r)
static int nss_sbus_init(struct nss_ctx *nctx)
{
- struct sbus_method_ctx *cli_sm_ctx;
- struct sbus_method_ctx *srv_sm_ctx;
struct nss_sbus_ctx *ns_ctx;
DBusConnection *dbus_conn;
char *sbus_address;
@@ -274,37 +272,24 @@ static int nss_sbus_init(struct nss_ctx *nctx)
}
dbus_conn = sbus_get_connection(ns_ctx->scon_ctx);
- dbus_connection_set_exit_on_disconnect(dbus_conn, TRUE);
/* set up handler for service methods */
- srv_sm_ctx = talloc_zero(ns_ctx, struct sbus_method_ctx);
- if (!srv_sm_ctx) {
+ ns_ctx->sm_ctx = talloc_zero(ns_ctx, struct sbus_method_ctx);
+ if (!ns_ctx->sm_ctx) {
talloc_free(ns_ctx);
return ENOMEM;
}
- srv_sm_ctx->interface = talloc_strdup(srv_sm_ctx, SERVICE_INTERFACE);
- srv_sm_ctx->path = talloc_strdup(srv_sm_ctx, SERVICE_PATH);
- if (!srv_sm_ctx->interface || !srv_sm_ctx->path) {
+ ns_ctx->sm_ctx->interface = talloc_strdup(ns_ctx->sm_ctx,
+ SERVICE_INTERFACE);
+ ns_ctx->sm_ctx->path = talloc_strdup(ns_ctx->sm_ctx,
+ SERVICE_PATH);
+ if (!ns_ctx->sm_ctx->interface || !ns_ctx->sm_ctx->path) {
talloc_free(ns_ctx);
return ENOMEM;
}
- srv_sm_ctx->methods = nss_sbus_methods;
- srv_sm_ctx->message_handler = sbus_message_handler;
- sbus_conn_add_method_ctx(ns_ctx->scon_ctx, srv_sm_ctx);
-
- /* set up client stuff */
- cli_sm_ctx = talloc(ns_ctx, struct sbus_method_ctx);
- if (!cli_sm_ctx) {
- talloc_free(ns_ctx);
- return ENOMEM;
- }
- cli_sm_ctx->interface = talloc_strdup(cli_sm_ctx, MONITOR_DBUS_INTERFACE);
- cli_sm_ctx->path = talloc_strdup(cli_sm_ctx, MONITOR_DBUS_PATH);
- if (!cli_sm_ctx->interface || !cli_sm_ctx->path) {
- talloc_free(ns_ctx);
- return ENOMEM;
- }
- ns_ctx->sm_ctx = cli_sm_ctx;
+ ns_ctx->sm_ctx->methods = nss_sbus_methods;
+ ns_ctx->sm_ctx->message_handler = sbus_message_handler;
+ sbus_conn_add_method_ctx(ns_ctx->scon_ctx, ns_ctx->sm_ctx);
nctx->ns_ctx = ns_ctx;
diff --git a/server/providers/data_provider.c b/server/providers/data_provider.c
index df9cfdf6..565581a8 100644
--- a/server/providers/data_provider.c
+++ b/server/providers/data_provider.c
@@ -86,8 +86,6 @@ static int reply_ping(DBusMessage *message, void *data, DBusMessage **r)
static int dp_monitor_init(struct dp_ctx *dpctx)
{
- struct sbus_method_ctx *cli_sm_ctx;
- struct sbus_method_ctx *srv_sm_ctx;
struct dp_sbus_ctx *sbus_ctx;
DBusConnection *dbus_conn;
char *sbus_address;
@@ -114,36 +112,24 @@ static int dp_monitor_init(struct dp_ctx *dpctx)
return ret;
}
dbus_conn = sbus_get_connection(sbus_ctx->scon_ctx);
- dbus_connection_set_exit_on_disconnect(dbus_conn, TRUE);
/* set up handler for service methods */
- srv_sm_ctx = talloc_zero(sbus_ctx, struct sbus_method_ctx);
- if (!srv_sm_ctx) {
+ sbus_ctx->sm_ctx = talloc_zero(sbus_ctx, struct sbus_method_ctx);
+ if (!sbus_ctx->sm_ctx) {
talloc_free(sbus_ctx);
return ENOMEM;
}
- srv_sm_ctx->interface = talloc_strdup(srv_sm_ctx, SERVICE_INTERFACE);
- srv_sm_ctx->path = talloc_strdup(srv_sm_ctx, SERVICE_PATH);
- if (!srv_sm_ctx->interface || !srv_sm_ctx->path) {
+ sbus_ctx->sm_ctx->interface = talloc_strdup(sbus_ctx->sm_ctx,
+ SERVICE_INTERFACE);
+ sbus_ctx->sm_ctx->path = talloc_strdup(sbus_ctx->sm_ctx,
+ SERVICE_PATH);
+ if (!sbus_ctx->sm_ctx->interface || !sbus_ctx->sm_ctx->path) {
talloc_free(sbus_ctx);
return ENOMEM;
}
- srv_sm_ctx->methods = mon_sbus_methods;
- sbus_conn_add_method_ctx(sbus_ctx->scon_ctx, srv_sm_ctx);
-
- /* set up client stuff */
- cli_sm_ctx = talloc(sbus_ctx, struct sbus_method_ctx);
- if (!cli_sm_ctx) {
- talloc_free(sbus_ctx);
- return ENOMEM;
- }
- cli_sm_ctx->interface = talloc_strdup(cli_sm_ctx, MONITOR_DBUS_INTERFACE);
- cli_sm_ctx->path = talloc_strdup(cli_sm_ctx, MONITOR_DBUS_PATH);
- if (!cli_sm_ctx->interface || !cli_sm_ctx->path) {
- talloc_free(sbus_ctx);
- return ENOMEM;
- }
- sbus_ctx->sm_ctx = cli_sm_ctx;
+ sbus_ctx->sm_ctx->methods = mon_sbus_methods;
+ sbus_ctx->sm_ctx->message_handler = sbus_message_handler;
+ sbus_conn_add_method_ctx(sbus_ctx->scon_ctx, sbus_ctx->sm_ctx);
dpctx->sbus_ctx = sbus_ctx;