From: Jukka Rissanen Date: Mon, 12 Nov 2012 12:07:44 +0000 (+0200) Subject: storage: Add function to remove provider files X-Git-Tag: 1.10~163 X-Git-Url: http://review.tizen.org/git/?a=commitdiff_plain;h=8730704d87dc27f8b9c0300f733d6ffdea8abf58;p=platform%2Fupstream%2Fconnman.git storage: Add function to remove provider files --- diff --git a/src/connman.h b/src/connman.h index 90ffd35..67c1636 100644 --- a/src/connman.h +++ b/src/connman.h @@ -212,6 +212,7 @@ GKeyFile *__connman_storage_open_service(const char *ident); int __connman_storage_save_service(GKeyFile *keyfile, const char *ident); GKeyFile *__connman_storage_load_provider(const char *identifier); void __connman_storage_save_provider(GKeyFile *keyfile, const char *identifier); +gboolean __connman_storage_remove_provider(const char *identifier); char **__connman_storage_get_providers(void); gboolean __connman_storage_remove_service(const char *service_id); diff --git a/src/storage.c b/src/storage.c index 8c06ffe..3c3ce41 100644 --- a/src/storage.c +++ b/src/storage.c @@ -372,6 +372,46 @@ void __connman_storage_save_provider(GKeyFile *keyfile, const char *identifier) g_free(pathname); } +static gboolean remove_all(const char *id) +{ + gboolean removed; + + remove_file(id, SETTINGS); + remove_file(id, "data"); + + removed = remove_dir(id); + if (removed == FALSE) + return FALSE; + + return TRUE; +} + +gboolean __connman_storage_remove_provider(const char *identifier) +{ + gboolean removed; + gchar *id; + + id = g_strdup_printf("%s_%s", "provider", identifier); + if (id == NULL) + return FALSE; + + if (remove_all(id) == TRUE) + DBG("Removed provider dir %s/%s", STORAGEDIR, id); + + g_free(id); + + id = g_strdup_printf("%s_%s", "vpn", identifier); + if (id == NULL) + return FALSE; + + if ((removed = remove_all(id)) == TRUE) + DBG("Removed vpn dir %s/%s", STORAGEDIR, id); + + g_free(id); + + return removed; +} + gchar **__connman_storage_get_providers(void) { GSList *list = NULL;