mirror of git://git.sysmocom.de/ofono
gprs-provision: Refactor provisioning
This commit is contained in:
parent
5e5eed9f83
commit
71e5278ce6
|
@ -47,34 +47,31 @@ void __ofono_gprs_provision_free_settings(
|
||||||
g_free(settings);
|
g_free(settings);
|
||||||
}
|
}
|
||||||
|
|
||||||
void __ofono_gprs_provision_get_settings(const char *mcc, const char *mnc,
|
ofono_bool_t __ofono_gprs_provision_get_settings(const char *mcc,
|
||||||
struct ofono_gprs_provision_data **settings,
|
const char *mnc,
|
||||||
int *count)
|
struct ofono_gprs_provision_data **settings,
|
||||||
|
int *count)
|
||||||
{
|
{
|
||||||
GSList *d;
|
GSList *d;
|
||||||
|
|
||||||
*settings = NULL;
|
|
||||||
*count = 0;
|
|
||||||
|
|
||||||
if (mcc == NULL || strlen(mcc) == 0 || mnc == NULL || strlen(mnc) == 0)
|
if (mcc == NULL || strlen(mcc) == 0 || mnc == NULL || strlen(mnc) == 0)
|
||||||
return;
|
return FALSE;
|
||||||
|
|
||||||
for (d = g_drivers; d != NULL; d = d->next) {
|
for (d = g_drivers; d != NULL; d = d->next) {
|
||||||
const struct ofono_gprs_provision_driver *driver = d->data;
|
const struct ofono_gprs_provision_driver *driver = d->data;
|
||||||
|
|
||||||
|
if (driver->get_settings == NULL)
|
||||||
|
continue;
|
||||||
|
|
||||||
DBG("Calling provisioning plugin '%s'", driver->name);
|
DBG("Calling provisioning plugin '%s'", driver->name);
|
||||||
|
|
||||||
driver->get_settings(mcc, mnc, settings, count);
|
if (driver->get_settings(mcc, mnc, settings, count) < 0)
|
||||||
|
continue;
|
||||||
|
|
||||||
if (*count > 0) {
|
return TRUE;
|
||||||
DBG("Plugin '%s' returned %d context settings",
|
|
||||||
driver->name, *count);
|
|
||||||
return;
|
|
||||||
}
|
|
||||||
|
|
||||||
ofono_warn("Provisioning plugin '%s' returned no settings",
|
|
||||||
driver->name);
|
|
||||||
}
|
}
|
||||||
|
|
||||||
|
return FALSE;
|
||||||
}
|
}
|
||||||
|
|
||||||
static gint compare_priority(gconstpointer a, gconstpointer b)
|
static gint compare_priority(gconstpointer a, gconstpointer b)
|
||||||
|
|
|
@ -422,9 +422,10 @@ void __ofono_nettime_info_received(struct ofono_modem *modem,
|
||||||
#include <ofono/sim-auth.h>
|
#include <ofono/sim-auth.h>
|
||||||
|
|
||||||
#include <ofono/gprs-provision.h>
|
#include <ofono/gprs-provision.h>
|
||||||
void __ofono_gprs_provision_get_settings(const char *mcc, const char *mnc,
|
ofono_bool_t __ofono_gprs_provision_get_settings(const char *mcc,
|
||||||
struct ofono_gprs_provision_data **settings,
|
const char *mnc,
|
||||||
int *count);
|
struct ofono_gprs_provision_data **settings,
|
||||||
|
int *count);
|
||||||
void __ofono_gprs_provision_free_settings(
|
void __ofono_gprs_provision_free_settings(
|
||||||
struct ofono_gprs_provision_data *settings,
|
struct ofono_gprs_provision_data *settings,
|
||||||
int count);
|
int count);
|
||||||
|
|
Loading…
Reference in New Issue