log messages corrected
[profile/ivi/message-port.git] / lib / msgport-service.c
1 #include "msgport-service.h"
2 #include "msgport-utils.h"
3 #include "common/dbus-service-glue.h"
4 #include "common/log.h"
5 #include <bundle.h>
6
7
8 struct _MsgPortService
9 {
10     GObject parent;
11
12     MsgPortDbusGlueService *proxy;
13     guint                   on_messge_signal_id;
14     messageport_message_cb  client_cb;
15 };
16
17 G_DEFINE_TYPE(MsgPortService, msgport_service, G_TYPE_OBJECT)
18
19 static void
20 _service_dispose (GObject *self)
21 {
22     MsgPortService *service = MSGPORT_SERVICE (self);
23
24     g_clear_object (&service->proxy);
25
26     G_OBJECT_CLASS(msgport_service_parent_class)->dispose (self);
27 }
28
29 static void
30 msgport_service_class_init (MsgPortServiceClass *klass)
31 {
32     GObjectClass *g_klass = G_OBJECT_CLASS(klass);
33
34     g_klass->dispose = _service_dispose;
35 }
36
37 static void
38 msgport_service_init (MsgPortService *service)
39 {
40     service->proxy = NULL;
41     service->client_cb = NULL;
42     service->on_messge_signal_id = 0;
43 }
44
45 static void
46 _on_got_message (MsgPortService *service, GVariant *data, const gchar *remote_app_id, const gchar *remote_port, gboolean remote_is_trusted, gpointer userdata)
47 {
48 #ifdef ENABLE_DEBUG
49     gchar *str_data = g_variant_print (data, TRUE);
50     DBG ("Message received : '%s' from '%s':'%s':%d",
51             str_data, remote_app_id, remote_port, remote_is_trusted);
52     g_free (str_data);
53 #endif
54     bundle *b = bundle_from_variant_map (data);
55
56     /*
57      * NOTE: wrt plugin cannot handle empty strings for port_id and app_id.
58      * It is expecting NULL in this case, But we get empty stirng from Dbus.
59      * So check for this case:
60      */
61     if (remote_app_id && !remote_app_id[0]) remote_app_id = NULL;
62     if (remote_port   && !remote_port[0])   remote_port = NULL;
63
64     service->client_cb (msgport_dbus_glue_service_get_id (service->proxy), remote_app_id, remote_port, remote_is_trusted, b);
65
66     bundle_free (b);
67 }
68
69 MsgPortService *
70 msgport_service_new (GDBusConnection *connection, const gchar *path, messageport_message_cb message_cb)
71 {
72     GError *error = NULL;
73
74     MsgPortService *service = g_object_new (MSGPORT_TYPE_SERVICE, NULL);
75     if (!service) {
76         return NULL;
77     }
78
79     service->proxy = msgport_dbus_glue_service_proxy_new_sync (connection,
80                 G_DBUS_PROXY_FLAGS_NONE, NULL, path, NULL, &error);
81     if (!service->proxy) {
82         g_object_unref (service);
83         WARN ("failed create servie proxy for path '%s' : %s", path, error->message);
84         g_error_free (error);
85         return NULL;
86     }
87
88     service->client_cb = message_cb;
89     service->on_messge_signal_id = g_signal_connect_swapped (service->proxy, "on-message", G_CALLBACK (_on_got_message), service);
90
91     return service;
92 }
93
94 guint
95 msgport_service_id (MsgPortService *service)
96 {
97     g_return_val_if_fail (service && MSGPORT_IS_SERVICE (service), 0);
98     g_return_val_if_fail (service->proxy && MSGPORT_DBUS_GLUE_IS_SERVICE (service->proxy), 0);
99
100     return msgport_dbus_glue_service_get_id (service->proxy);
101 }
102
103 const gchar *
104 msgport_service_name (MsgPortService *service)
105 {
106     g_return_val_if_fail (service && MSGPORT_IS_SERVICE (service), NULL);
107     g_return_val_if_fail (service->proxy && MSGPORT_DBUS_GLUE_IS_SERVICE (service->proxy), NULL);
108
109     return msgport_dbus_glue_service_get_port_name (service->proxy);
110 }
111
112 gboolean
113 msgport_service_is_trusted (MsgPortService *service)
114 {
115     g_return_val_if_fail (service && MSGPORT_IS_SERVICE (service), FALSE);
116     g_return_val_if_fail (service->proxy && MSGPORT_DBUS_GLUE_IS_SERVICE (service->proxy), FALSE);
117
118     return msgport_dbus_glue_service_get_is_trusted (service->proxy);
119 }
120
121 gboolean
122 msgport_service_unregister (MsgPortService *service)
123 {
124     g_return_val_if_fail (service && MSGPORT_IS_SERVICE (service), FALSE);
125     g_return_val_if_fail (service->proxy, FALSE);
126
127     /* fire and forget */
128     return msgport_dbus_glue_service_call_unregister_sync (service->proxy, NULL, NULL);
129 }
130
131 messageport_error_e
132 msgport_service_send_message (MsgPortService *service, guint remote_service_id, GVariant *message)
133 {
134     GError *error = NULL;
135     g_return_val_if_fail (service && MSGPORT_IS_SERVICE (service), MESSAGEPORT_ERROR_IO_ERROR);
136     g_return_val_if_fail (service->proxy, MESSAGEPORT_ERROR_IO_ERROR);
137     g_return_val_if_fail (message, MESSAGEPORT_ERROR_INVALID_PARAMETER);
138
139     msgport_dbus_glue_service_call_send_message_sync (service->proxy, remote_service_id, message, NULL, &error);
140
141     if (error) {
142         messageport_error_e err = msgport_daemon_error_to_error (error);
143         WARN ("Fail to send message on service %p to %d : %s", service, remote_service_id, error->message);
144         g_error_free (error);
145         return err;
146     }
147
148     return MESSAGEPORT_ERROR_NONE;
149 }