summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorSamuel Ortiz <sameo@linux.intel.com>2011-02-16 01:38:44 +0100
committerSamuel Ortiz <sameo@linux.intel.com>2011-02-16 01:49:39 +0100
commitff7dff1a78557d8b849dc1f82ee00797c55fbb22 (patch)
treecd894b215fedbf183402e3bd16e2855612ee6714
parent33b9f646559724e35f9b7dc661f3732e412c64a0 (diff)
downloadconnman-ff7dff1a78557d8b849dc1f82ee00797c55fbb22.tar.gz
connman-ff7dff1a78557d8b849dc1f82ee00797c55fbb22.tar.bz2
connman-ff7dff1a78557d8b849dc1f82ee00797c55fbb22.zip
service: Remove APN property
APNs are operator specific settings and should be either provisioned or set through oFono.
-rw-r--r--doc/service-api.txt9
-rw-r--r--plugins/ofono.c34
-rw-r--r--src/service.c164
3 files changed, 2 insertions, 205 deletions
diff --git a/doc/service-api.txt b/doc/service-api.txt
index b3e758ea..9695059f 100644
--- a/doc/service-api.txt
+++ b/doc/service-api.txt
@@ -259,15 +259,6 @@ Properties string State [readonly]
In most cases it is required to fill in the APN
details.
- string APN [readwrite]
-
- If the service is Cellular, then this property
- contains the APN details.
-
- The APN is network provider specific and even
- sometimes data plan specific. Possible examples
- are "isp.cingular" or "internet.t-mobile".
-
boolean Roaming [readonly]
This property indicates if this service is roaming.
diff --git a/plugins/ofono.c b/plugins/ofono.c
index 43872ffc..29aaa618 100644
--- a/plugins/ofono.c
+++ b/plugins/ofono.c
@@ -452,25 +452,6 @@ static int set_network_active(struct connman_network *network,
return error;
}
-static void set_apn(struct connman_network *network)
-{
- const char *apn, *path;
-
- apn = connman_network_get_string(network, "Cellular.APN");
- if (apn == NULL)
- return;
-
- path = connman_network_get_string(network, "Path");
- if (path == NULL)
- return;
-
- DBG("path %s, apn %s", path, apn);
-
- set_property(path, OFONO_CONTEXT_INTERFACE,
- "AccessPointName", DBUS_TYPE_STRING, &apn,
- NULL, NULL, NULL);
-}
-
static int network_connect(struct connman_network *network)
{
struct connman_device *device;
@@ -520,14 +501,6 @@ static void network_remove(struct connman_network *network)
g_hash_table_remove(network_hash, path);
}
-static int network_setup(struct connman_network *network, const char *key)
-{
- if (g_strcmp0(key, "Cellular.APN") == 0)
- set_apn(network);
-
- return 0;
-}
-
static struct connman_network_driver network_driver = {
.name = "network",
.type = CONNMAN_NETWORK_TYPE_CELLULAR,
@@ -535,7 +508,6 @@ static struct connman_network_driver network_driver = {
.remove = network_remove,
.connect = network_connect,
.disconnect = network_disconnect,
- .setup = network_setup,
};
static void update_settings(DBusMessageIter *array,
@@ -615,12 +587,6 @@ static int add_network(struct connman_device *device,
DBG("path %p type %s", path, type);
goto error;
}
- } else if (g_str_equal(key, "AccessPointName")) {
- const char *ap;
-
- dbus_message_iter_get_basic(&value, &ap);
-
- connman_network_set_string(network, "Cellular.APN", ap);
} else if (g_str_equal(key, "Settings"))
update_settings(&value, network);
else if (g_str_equal(key, "Active") == TRUE)
diff --git a/src/service.c b/src/service.c
index 013b77ec..dbbd33f9 100644
--- a/src/service.c
+++ b/src/service.c
@@ -73,9 +73,6 @@ struct connman_service {
char *name;
char *passphrase;
char *profile;
- char *apn;
- char *username;
- char *password;
char *mcc;
char *mnc;
connman_bool_t roaming;
@@ -940,32 +937,6 @@ static void login_changed(struct connman_service *service)
DBUS_TYPE_BOOLEAN, &required);
}
-static void apn_changed(struct connman_service *service)
-{
- dbus_bool_t required;
-
- switch (service->type) {
- case CONNMAN_SERVICE_TYPE_UNKNOWN:
- case CONNMAN_SERVICE_TYPE_SYSTEM:
- case CONNMAN_SERVICE_TYPE_ETHERNET:
- case CONNMAN_SERVICE_TYPE_WIMAX:
- case CONNMAN_SERVICE_TYPE_BLUETOOTH:
- case CONNMAN_SERVICE_TYPE_WIFI:
- case CONNMAN_SERVICE_TYPE_GPS:
- case CONNMAN_SERVICE_TYPE_VPN:
- case CONNMAN_SERVICE_TYPE_GADGET:
- return;
- case CONNMAN_SERVICE_TYPE_CELLULAR:
- break;
- }
-
- required = (service->apn == NULL) ? TRUE : FALSE;
-
- connman_dbus_property_changed_basic(service->path,
- CONNMAN_SERVICE_INTERFACE, "SetupRequired",
- DBUS_TYPE_BOOLEAN, &required);
-}
-
static void append_security(DBusMessageIter *iter, void *user_data)
{
struct connman_service *service = user_data;
@@ -1630,24 +1601,7 @@ static void append_properties(DBusMessageIter *dict, dbus_bool_t limited,
connman_dbus_dict_append_basic(dict, "Roaming",
DBUS_TYPE_BOOLEAN, &service->roaming);
- if (service->apn != NULL) {
- connman_dbus_dict_append_basic(dict, "APN",
- DBUS_TYPE_STRING, &service->apn);
-
- if (service->username != NULL)
- connman_dbus_dict_append_basic(dict,
- "Username", DBUS_TYPE_STRING,
- &service->username);
-
- if (service->password != NULL)
- connman_dbus_dict_append_basic(dict,
- "Password", DBUS_TYPE_STRING,
- &service->password);
-
- required = FALSE;
- } else
- required = TRUE;
-
+ required = FALSE;
connman_dbus_dict_append_basic(dict, "SetupRequired",
DBUS_TYPE_BOOLEAN, &required);
connman_dbus_dict_append_dict(dict, "Ethernet",
@@ -2187,74 +2141,6 @@ static DBusMessage *set_property(DBusConnection *conn,
dbus_message_iter_get_basic(&value, &passphrase);
__connman_service_set_passphrase(service, passphrase);
- } else if (g_str_equal(name, "APN") == TRUE) {
- const char *apn;
-
- if (type != DBUS_TYPE_STRING)
- return __connman_error_invalid_arguments(msg);
-
- if (service->immutable == TRUE)
- return __connman_error_not_supported(msg);
-
- if (service->type != CONNMAN_SERVICE_TYPE_CELLULAR)
- return __connman_error_invalid_service(msg);
-
- dbus_message_iter_get_basic(&value, &apn);
-
- g_free(service->apn);
- service->apn = g_strdup(apn);
-
- apn_changed(service);
-
- if (service->network != NULL)
- connman_network_set_string(service->network,
- "Cellular.APN", service->apn);
-
- __connman_storage_save_service(service);
- } else if (g_str_equal(name, "Username") == TRUE) {
- const char *username;
-
- if (type != DBUS_TYPE_STRING)
- return __connman_error_invalid_arguments(msg);
-
- if (service->immutable == TRUE)
- return __connman_error_not_supported(msg);
-
- if (service->type != CONNMAN_SERVICE_TYPE_CELLULAR)
- return __connman_error_invalid_service(msg);
-
- dbus_message_iter_get_basic(&value, &username);
-
- g_free(service->username);
- service->username = g_strdup(username);
-
- if (service->network != NULL)
- connman_network_set_string(service->network,
- "Cellular.Username", service->username);
-
- __connman_storage_save_service(service);
- } else if (g_str_equal(name, "Password") == TRUE) {
- const char *password;
-
- if (type != DBUS_TYPE_STRING)
- return __connman_error_invalid_arguments(msg);
-
- if (service->immutable == TRUE)
- return __connman_error_not_supported(msg);
-
- if (service->type != CONNMAN_SERVICE_TYPE_CELLULAR)
- return __connman_error_invalid_service(msg);
-
- dbus_message_iter_get_basic(&value, &password);
-
- g_free(service->password);
- service->password = g_strdup(password);
-
- if (service->network != NULL)
- connman_network_set_string(service->network,
- "Cellular.Password", service->password);
-
- __connman_storage_save_service(service);
} else if (g_str_equal(name, "Nameservers.Configuration") == TRUE) {
DBusMessageIter entry;
GString *str;
@@ -2788,17 +2674,6 @@ static DBusMessage *remove_service(DBusConnection *conn,
passphrase_changed(service);
- g_free(service->apn);
- service->apn = NULL;
-
- g_free(service->username);
- service->username = NULL;
-
- g_free(service->password);
- service->password = NULL;
-
- apn_changed(service);
-
set_idle(service);
__connman_service_set_favorite(service, FALSE);
@@ -2941,9 +2816,6 @@ static void service_free(gpointer user_data)
g_free(service->pac);
g_free(service->mcc);
g_free(service->mnc);
- g_free(service->apn);
- g_free(service->username);
- g_free(service->password);
g_free(service->profile);
g_free(service->name);
g_free(service->passphrase);
@@ -3649,15 +3521,7 @@ static connman_bool_t prepare_network(struct connman_service *service)
case CONNMAN_NETWORK_TYPE_WIMAX:
case CONNMAN_NETWORK_TYPE_BLUETOOTH_PAN:
case CONNMAN_NETWORK_TYPE_BLUETOOTH_DUN:
- break;
case CONNMAN_NETWORK_TYPE_CELLULAR:
- connman_network_set_string(service->network,
- "Cellular.APN", service->apn);
-
- connman_network_set_string(service->network,
- "Cellular.Username", service->username);
- connman_network_set_string(service->network,
- "Cellular.Password", service->password);
break;
}
@@ -3711,11 +3575,8 @@ static int service_connect(struct connman_service *service)
case CONNMAN_SERVICE_TYPE_ETHERNET:
case CONNMAN_SERVICE_TYPE_WIMAX:
case CONNMAN_SERVICE_TYPE_BLUETOOTH:
- case CONNMAN_SERVICE_TYPE_VPN:
- break;
case CONNMAN_SERVICE_TYPE_CELLULAR:
- if (service->apn == NULL)
- return -EINVAL;
+ case CONNMAN_SERVICE_TYPE_VPN:
break;
case CONNMAN_SERVICE_TYPE_WIFI:
switch (service->security) {
@@ -4964,15 +4825,6 @@ static int service_load(struct connman_service *service)
case CONNMAN_SERVICE_TYPE_WIMAX:
case CONNMAN_SERVICE_TYPE_BLUETOOTH:
case CONNMAN_SERVICE_TYPE_CELLULAR:
- service->apn = g_key_file_get_string(keyfile,
- service->identifier, "APN", NULL);
-
- service->username = g_key_file_get_string(keyfile,
- service->identifier, "Username", NULL);
-
- service->password = g_key_file_get_string(keyfile,
- service->identifier, "Password", NULL);
-
service->favorite = g_key_file_get_boolean(keyfile,
service->identifier, "Favorite", NULL);
@@ -5142,18 +4994,6 @@ update:
case CONNMAN_SERVICE_TYPE_WIMAX:
case CONNMAN_SERVICE_TYPE_BLUETOOTH:
case CONNMAN_SERVICE_TYPE_CELLULAR:
- if (service->apn != NULL)
- g_key_file_set_string(keyfile, service->identifier,
- "APN", service->apn);
-
- if (service->username != NULL)
- g_key_file_set_string(keyfile, service->identifier,
- "Username", service->username);
-
- if (service->password != NULL)
- g_key_file_set_string(keyfile, service->identifier,
- "Password", service->password);
-
g_key_file_set_boolean(keyfile, service->identifier,
"Favorite", service->favorite);