1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
|
/*
SSSD
Service monitor
Copyright (C) Stephen Gallagher 2008
This program is free software; you can redistribute it and/or modify
it under the terms of the GNU General Public License as published by
the Free Software Foundation; either version 3 of the License, or
(at your option) any later version.
This program is distributed in the hope that it will be useful,
but WITHOUT ANY WARRANTY; without even the implied warranty of
MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
GNU General Public License for more details.
You should have received a copy of the GNU General Public License
along with this program. If not, see <http://www.gnu.org/licenses/>.
*/
#include "util/util.h"
#include "talloc.h"
#include "events.h"
#include "sbus/sssd_dbus.h"
#include "confdb/confdb.h"
#include "service_helpers.h"
#include "sbus_interfaces.h"
/*
* Set up an SBUS connection to the monitor
*/
struct service_sbus_ctx *sssd_service_sbus_init(TALLOC_CTX *mem_ctx,
struct event_context *ev,
struct confdb_ctx *cdb,
sbus_msg_handler_fn get_identity,
sbus_msg_handler_fn ping)
{
struct service_sbus_ctx *ss_ctx;
struct sbus_method_ctx *sm_ctx;
TALLOC_CTX *ctx;
char *sbus_address;
char *default_monitor_address;
DBusConnection *conn;
int ret;
ctx = talloc_new(mem_ctx);
if (ctx == NULL) goto error;
ss_ctx = talloc_zero(ctx, struct service_sbus_ctx);
if (ss_ctx == NULL) return NULL;
default_monitor_address = talloc_asprintf(ctx, "unix:path=%s/%s",
PIPE_PATH, SSSD_SERVICE_PIPE);
if (default_monitor_address == NULL) goto error;
ret = confdb_get_string(cdb, ctx,
"config/services/monitor", "sbusAddress",
default_monitor_address, &sbus_address);
if (ret != EOK) goto error;
ss_ctx->ev = ev;
ret = sbus_new_connection(ss_ctx, ss_ctx->ev,
sbus_address, &ss_ctx->scon_ctx,
NULL);
if (ret != EOK) goto error;
conn = sbus_get_connection(ss_ctx->scon_ctx);
/* set up handler for service methods */
sm_ctx = talloc_zero(ss_ctx, struct sbus_method_ctx);
if (sm_ctx == NULL) goto error;
sm_ctx->interface = talloc_strdup(sm_ctx, SERVICE_INTERFACE);
sm_ctx->path = talloc_strdup(sm_ctx, SERVICE_PATH);
if (!sm_ctx->interface || !sm_ctx->path) goto error;
/* Set up required monitor methods */
sm_ctx->methods = talloc_array(sm_ctx, struct sbus_method, 3);
if (sm_ctx->methods == NULL) goto error;
/* Handle getIdentity */
sm_ctx->methods[0].method = SERVICE_METHOD_IDENTITY;
sm_ctx->methods[0].fn = get_identity;
/* Handle ping */
sm_ctx->methods[1].method = SERVICE_METHOD_PING;
sm_ctx->methods[1].fn = ping;
/* Terminate the list */
sm_ctx->methods[2].method = NULL;
sm_ctx->methods[2].fn = NULL;
sm_ctx->message_handler = sbus_message_handler;
sbus_conn_add_method_ctx(ss_ctx->scon_ctx, sm_ctx);
talloc_steal(mem_ctx,ss_ctx);
talloc_free(ctx);
return ss_ctx;
error:
talloc_free(ctx);
return NULL;
}
|