mirror of git://git.sysmocom.de/ofono
push-notification: Handle WAP push messages
This commit is contained in:
parent
8f5d8280b6
commit
0d80076c79
|
@ -40,6 +40,8 @@
|
||||||
|
|
||||||
#define PUSH_NOTIFICATION_INTERFACE "org.ofono.PushNotification"
|
#define PUSH_NOTIFICATION_INTERFACE "org.ofono.PushNotification"
|
||||||
#define AGENT_INTERFACE "org.ofono.PushNotificationAgent"
|
#define AGENT_INTERFACE "org.ofono.PushNotificationAgent"
|
||||||
|
#define WAP_PUSH_SRC_PORT 9200
|
||||||
|
#define WAP_PUSH_DST_PORT 2948
|
||||||
|
|
||||||
static unsigned int modemwatch_id;
|
static unsigned int modemwatch_id;
|
||||||
|
|
||||||
|
@ -47,15 +49,38 @@ struct push_notification {
|
||||||
struct ofono_modem *modem;
|
struct ofono_modem *modem;
|
||||||
struct ofono_sms *sms;
|
struct ofono_sms *sms;
|
||||||
struct sms_agent *agent;
|
struct sms_agent *agent;
|
||||||
|
unsigned int push_watch;
|
||||||
};
|
};
|
||||||
|
|
||||||
static void agent_exited(void *userdata)
|
static void agent_exited(void *userdata)
|
||||||
{
|
{
|
||||||
struct push_notification *pn = userdata;
|
struct push_notification *pn = userdata;
|
||||||
|
|
||||||
|
if (pn->push_watch > 0) {
|
||||||
|
__ofono_sms_datagram_watch_remove(pn->sms, pn->push_watch);
|
||||||
|
pn->push_watch = 0;
|
||||||
|
}
|
||||||
|
|
||||||
pn->agent = NULL;
|
pn->agent = NULL;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
static void push_received(const char *from, const struct tm *remote,
|
||||||
|
const struct tm *local, int dst, int src,
|
||||||
|
const unsigned char *buffer,
|
||||||
|
unsigned int len, void *data)
|
||||||
|
{
|
||||||
|
struct push_notification *pn = data;
|
||||||
|
|
||||||
|
DBG("Received push of size: %u", len);
|
||||||
|
|
||||||
|
if (pn->agent == NULL)
|
||||||
|
return;
|
||||||
|
|
||||||
|
sms_agent_dispatch_datagram(pn->agent, "ReceiveNotification",
|
||||||
|
from, remote, local, buffer, len,
|
||||||
|
NULL, NULL, NULL);
|
||||||
|
}
|
||||||
|
|
||||||
static DBusMessage *push_notification_register_agent(DBusConnection *conn,
|
static DBusMessage *push_notification_register_agent(DBusConnection *conn,
|
||||||
DBusMessage *msg, void *data)
|
DBusMessage *msg, void *data)
|
||||||
{
|
{
|
||||||
|
@ -82,6 +107,11 @@ static DBusMessage *push_notification_register_agent(DBusConnection *conn,
|
||||||
|
|
||||||
sms_agent_set_removed_notify(pn->agent, agent_exited, pn);
|
sms_agent_set_removed_notify(pn->agent, agent_exited, pn);
|
||||||
|
|
||||||
|
pn->push_watch = __ofono_sms_datagram_watch_add(pn->sms, push_received,
|
||||||
|
WAP_PUSH_DST_PORT,
|
||||||
|
WAP_PUSH_SRC_PORT,
|
||||||
|
pn, NULL);
|
||||||
|
|
||||||
return dbus_message_new_method_return(msg);
|
return dbus_message_new_method_return(msg);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -120,6 +150,8 @@ static void push_notification_cleanup(gpointer user)
|
||||||
|
|
||||||
DBG("%p", pn);
|
DBG("%p", pn);
|
||||||
|
|
||||||
|
/* The push watch was already cleaned up */
|
||||||
|
pn->push_watch = 0;
|
||||||
pn->sms = NULL;
|
pn->sms = NULL;
|
||||||
|
|
||||||
sms_agent_free(pn->agent);
|
sms_agent_free(pn->agent);
|
||||||
|
|
Loading…
Reference in New Issue