diff options
author | Philippe Nunes <philippe.nunes@linux.intel.com> | 2011-12-14 18:56:07 +0100 |
---|---|---|
committer | Denis Kenzior <denkenz@gmail.com> | 2012-01-07 12:49:25 -0600 |
commit | 21e57a5d3665bf295d4f375cb04740cb25b0d082 (patch) | |
tree | 3107819e22514ff6d4592813c084480a3f08bd0f /src/cdma-netreg.c | |
parent | 9631d53ad04d853f6dc914a1e758208f396c0567 (diff) | |
download | ofono-21e57a5d3665bf295d4f375cb04740cb25b0d082.tar.bz2 |
cdma-netreg: Add provider name and SID support
Diffstat (limited to 'src/cdma-netreg.c')
-rw-r--r-- | src/cdma-netreg.c | 40 |
1 files changed, 40 insertions, 0 deletions
diff --git a/src/cdma-netreg.c b/src/cdma-netreg.c index 222c3b7c..1a88d331 100644 --- a/src/cdma-netreg.c +++ b/src/cdma-netreg.c @@ -24,6 +24,7 @@ #endif #include <errno.h> +#include <string.h> #include <gdbus.h> @@ -38,6 +39,8 @@ struct ofono_cdma_netreg { const struct ofono_cdma_netreg_driver *driver; void *driver_data; struct ofono_atom *atom; + char *provider_name; + char *sid; }; static const char *cdma_netreg_status_to_string(enum cdma_netreg_status status) @@ -90,6 +93,15 @@ static DBusMessage *network_get_properties(DBusConnection *conn, &strength); } + if (cdma_netreg->sid) + ofono_dbus_dict_append(&dict, "SystemIdentifier", + DBUS_TYPE_STRING, + &cdma_netreg->sid); + + if (cdma_netreg->provider_name) + ofono_dbus_dict_append(&dict, "Name", DBUS_TYPE_STRING, + &cdma_netreg->provider_name); + dbus_message_iter_close_container(&iter, &dict); return reply; @@ -108,6 +120,8 @@ static void serving_system_callback(const struct ofono_error *error, const char *sid, void *data) { struct ofono_cdma_netreg *cdma_netreg = data; + const char *path = __ofono_atom_get_path(cdma_netreg->atom); + DBusConnection *conn = ofono_dbus_get_connection(); if (cdma_netreg->status != CDMA_NETWORK_REGISTRATION_STATUS_REGISTERED && cdma_netreg->status != @@ -120,6 +134,30 @@ static void serving_system_callback(const struct ofono_error *error, } DBG("Serving system Identifier: %s", sid); + + if (cdma_netreg->sid != NULL && !strcmp(cdma_netreg->sid, sid)) + return; + + g_free(cdma_netreg->provider_name); + g_free(cdma_netreg->sid); + cdma_netreg->provider_name = NULL; + cdma_netreg->sid = g_strdup(sid); + + ofono_dbus_signal_property_changed(conn, path, + OFONO_CDMA_NETWORK_REGISTRATION_INTERFACE, + "SystemIdentifier", DBUS_TYPE_STRING, + &cdma_netreg->sid); + + if (__ofono_cdma_provision_get_name(sid, + &cdma_netreg->provider_name) == FALSE) { + ofono_warn("Provider name not found"); + return; + } + + ofono_dbus_signal_property_changed(conn, path, + OFONO_CDMA_NETWORK_REGISTRATION_INTERFACE, + "Name", DBUS_TYPE_STRING, + &cdma_netreg->provider_name); } static void set_registration_status(struct ofono_cdma_netreg *cdma_netreg, @@ -251,6 +289,8 @@ static void cdma_netreg_remove(struct ofono_atom *atom) if (cdma_netreg->driver && cdma_netreg->driver->remove) cdma_netreg->driver->remove(cdma_netreg); + g_free(cdma_netreg->sid); + g_free(cdma_netreg->provider_name); g_free(cdma_netreg); } |