mirror of
https://gitlab.gnome.org/GNOME/libsecret.git
synced 2025-01-05 03:28:54 +00:00
Rework how the initialization work for various proxy objects
* Fix bugs and tests
This commit is contained in:
parent
f44aae6efa
commit
c6c6afa2cc
1
.gitignore
vendored
1
.gitignore
vendored
@ -40,6 +40,7 @@ stamp*
|
|||||||
!/egg/tests/test-*.c
|
!/egg/tests/test-*.c
|
||||||
|
|
||||||
/library/gsecret-dbus-generated.[ch]
|
/library/gsecret-dbus-generated.[ch]
|
||||||
|
/library/gsecret-enum-types.[ch]
|
||||||
/library/tests/test-*
|
/library/tests/test-*
|
||||||
!/library/tests/test-*.c
|
!/library/tests/test-*.c
|
||||||
|
|
||||||
|
@ -41,6 +41,8 @@ PKG_CHECK_MODULES(GLIB,
|
|||||||
LIBS="$LIBS $GLIB_LIBS"
|
LIBS="$LIBS $GLIB_LIBS"
|
||||||
CFLAGS="$CFLAGS $GLIB_CFLAGS"
|
CFLAGS="$CFLAGS $GLIB_CFLAGS"
|
||||||
|
|
||||||
|
AC_PATH_PROG(GLIB_MKENUMS, glib-mkenums)
|
||||||
|
|
||||||
# --------------------------------------------------------------------
|
# --------------------------------------------------------------------
|
||||||
# libgcrypt
|
# libgcrypt
|
||||||
#
|
#
|
||||||
|
@ -9,10 +9,22 @@ module_flags = \
|
|||||||
-no-undefined \
|
-no-undefined \
|
||||||
-export-symbols-regex '^gsecret_'
|
-export-symbols-regex '^gsecret_'
|
||||||
|
|
||||||
|
INCLUDES = \
|
||||||
|
-DGSECRET_COMPILATION
|
||||||
|
|
||||||
lib_LTLIBRARIES = libgsecret.la
|
lib_LTLIBRARIES = libgsecret.la
|
||||||
|
|
||||||
|
HEADER_FILES = \
|
||||||
|
gsecret-collection.h \
|
||||||
|
gsecret-item.h \
|
||||||
|
gsecret-password.h \
|
||||||
|
gsecret-prompt.h \
|
||||||
|
gsecret-service.h \
|
||||||
|
gsecret-value.h
|
||||||
|
|
||||||
BUILT_SOURCES = \
|
BUILT_SOURCES = \
|
||||||
gsecret-dbus-generated.c gsecret-dbus-generated.h
|
gsecret-dbus-generated.c gsecret-dbus-generated.h \
|
||||||
|
gsecret-enum-types.c gsecret-enum-types.h
|
||||||
|
|
||||||
libgsecret_la_SOURCES = \
|
libgsecret_la_SOURCES = \
|
||||||
gsecret-collection.h gsecret-collection.c \
|
gsecret-collection.h gsecret-collection.c \
|
||||||
@ -45,5 +57,15 @@ gsecret-dbus-generated.c: $(DBUS_XML_DEFINITIONS) Makefile.am
|
|||||||
$(AM_V_GEN) sed -i -e '1i #define GLIB_DISABLE_DEPRECATION_WARNINGS' gsecret-dbus-generated.c
|
$(AM_V_GEN) sed -i -e '1i #define GLIB_DISABLE_DEPRECATION_WARNINGS' gsecret-dbus-generated.c
|
||||||
gsecret-dbus-generated.h: gsecret-dbus-generated.c
|
gsecret-dbus-generated.h: gsecret-dbus-generated.c
|
||||||
|
|
||||||
|
gsecret-enum-types.h: gsecret-enum-types.h.template $(HEADER_FILES)
|
||||||
|
$(AM_V_GEN) $(GLIB_MKENUMS) --template $^ > $@
|
||||||
|
|
||||||
|
gsecret-enum-types.c: gsecret-enum-types.c.template $(HEADER_FILES)
|
||||||
|
$(AM_V_GEN) $(GLIB_MKENUMS) --template $^ > $@
|
||||||
|
|
||||||
|
EXTRA_DIST = \
|
||||||
|
gsecret-enum-types.h.template \
|
||||||
|
gsecret-enum-types.c.template
|
||||||
|
|
||||||
check-memory:
|
check-memory:
|
||||||
make -C tests check-memory
|
make -C tests check-memory
|
@ -42,7 +42,18 @@ struct _GSecretCollectionPrivate {
|
|||||||
GHashTable *items;
|
GHashTable *items;
|
||||||
};
|
};
|
||||||
|
|
||||||
G_DEFINE_TYPE (GSecretCollection, gsecret_collection, G_TYPE_DBUS_PROXY);
|
static GInitableIface *gsecret_collection_initable_parent_iface = NULL;
|
||||||
|
|
||||||
|
static GAsyncInitableIface *gsecret_collection_async_initable_parent_iface = NULL;
|
||||||
|
|
||||||
|
static void gsecret_collection_initable_iface (GInitableIface *iface);
|
||||||
|
|
||||||
|
static void gsecret_collection_async_initable_iface (GAsyncInitableIface *iface);
|
||||||
|
|
||||||
|
G_DEFINE_TYPE_WITH_CODE (GSecretCollection, gsecret_collection, G_TYPE_DBUS_PROXY,
|
||||||
|
G_IMPLEMENT_INTERFACE (G_TYPE_INITABLE, gsecret_collection_initable_iface);
|
||||||
|
G_IMPLEMENT_INTERFACE (G_TYPE_ASYNC_INITABLE, gsecret_collection_async_initable_iface);
|
||||||
|
);
|
||||||
|
|
||||||
static GHashTable *
|
static GHashTable *
|
||||||
items_table_new (void)
|
items_table_new (void)
|
||||||
@ -166,69 +177,63 @@ gsecret_collection_finalize (GObject *obj)
|
|||||||
G_OBJECT_CLASS (gsecret_collection_parent_class)->finalize (obj);
|
G_OBJECT_CLASS (gsecret_collection_parent_class)->finalize (obj);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
static GSecretItem *
|
||||||
|
collection_lookup_item (GSecretCollection *self,
|
||||||
|
const gchar *path)
|
||||||
|
{
|
||||||
|
GSecretItem *item = NULL;
|
||||||
|
|
||||||
|
g_mutex_lock (&self->pv->mutex);
|
||||||
|
|
||||||
|
item = g_hash_table_lookup (self->pv->items, path);
|
||||||
|
if (item != NULL)
|
||||||
|
g_object_ref (item);
|
||||||
|
|
||||||
|
g_mutex_unlock (&self->pv->mutex);
|
||||||
|
|
||||||
|
return item;
|
||||||
|
}
|
||||||
|
|
||||||
|
static void
|
||||||
|
collection_update_items (GSecretCollection *self,
|
||||||
|
GHashTable *items)
|
||||||
|
{
|
||||||
|
GHashTable *previous;
|
||||||
|
|
||||||
|
g_hash_table_ref (items);
|
||||||
|
|
||||||
|
g_mutex_lock (&self->pv->mutex);
|
||||||
|
previous = self->pv->items;
|
||||||
|
self->pv->items = items;
|
||||||
|
g_mutex_unlock (&self->pv->mutex);
|
||||||
|
|
||||||
|
g_hash_table_unref (previous);
|
||||||
|
}
|
||||||
|
|
||||||
typedef struct {
|
typedef struct {
|
||||||
GSecretCollection *collection;
|
|
||||||
GCancellable *cancellable;
|
GCancellable *cancellable;
|
||||||
GHashTable *items;
|
GHashTable *items;
|
||||||
gint items_loading;
|
gint items_loading;
|
||||||
} LoadClosure;
|
} ItemsClosure;
|
||||||
|
|
||||||
static void
|
static void
|
||||||
load_closure_free (gpointer data)
|
items_closure_free (gpointer data)
|
||||||
{
|
{
|
||||||
LoadClosure *closure = data;
|
ItemsClosure *closure = data;
|
||||||
g_object_unref (closure->collection);
|
|
||||||
g_clear_object (&closure->cancellable);
|
g_clear_object (&closure->cancellable);
|
||||||
g_hash_table_unref (closure->items);
|
g_hash_table_unref (closure->items);
|
||||||
g_slice_free (LoadClosure, closure);
|
g_slice_free (ItemsClosure, closure);
|
||||||
}
|
|
||||||
|
|
||||||
static GSimpleAsyncResult *
|
|
||||||
load_result_new (GCancellable *cancellable,
|
|
||||||
GAsyncReadyCallback callback,
|
|
||||||
gpointer user_data)
|
|
||||||
{
|
|
||||||
GSimpleAsyncResult *res;
|
|
||||||
LoadClosure *closure;
|
|
||||||
|
|
||||||
res = g_simple_async_result_new (NULL, callback, user_data, load_result_new);
|
|
||||||
closure = g_slice_new0 (LoadClosure);
|
|
||||||
closure->cancellable = cancellable ? g_object_ref (cancellable) : NULL;
|
|
||||||
closure->items = items_table_new ();
|
|
||||||
g_simple_async_result_set_op_res_gpointer (res, closure, load_closure_free);
|
|
||||||
|
|
||||||
return res;
|
|
||||||
}
|
}
|
||||||
|
|
||||||
static void
|
static void
|
||||||
load_items_complete (GSimpleAsyncResult *res)
|
on_load_item (GObject *source,
|
||||||
{
|
|
||||||
LoadClosure *closure = g_simple_async_result_get_op_res_gpointer (res);
|
|
||||||
GSecretCollection *self = closure->collection;
|
|
||||||
GHashTable *items;
|
|
||||||
|
|
||||||
g_assert (closure->items_loading == 0);
|
|
||||||
|
|
||||||
g_hash_table_ref (closure->items);
|
|
||||||
|
|
||||||
g_mutex_lock (&self->pv->mutex);
|
|
||||||
items = self->pv->items;
|
|
||||||
self->pv->items = closure->items;
|
|
||||||
g_mutex_unlock (&self->pv->mutex);
|
|
||||||
|
|
||||||
g_hash_table_unref (items);
|
|
||||||
|
|
||||||
g_simple_async_result_complete (res);
|
|
||||||
}
|
|
||||||
|
|
||||||
static void
|
|
||||||
on_item_loading (GObject *source,
|
|
||||||
GAsyncResult *result,
|
GAsyncResult *result,
|
||||||
gpointer user_data)
|
gpointer user_data)
|
||||||
{
|
{
|
||||||
GSimpleAsyncResult *res = G_SIMPLE_ASYNC_RESULT (user_data);
|
GSimpleAsyncResult *res = G_SIMPLE_ASYNC_RESULT (user_data);
|
||||||
LoadClosure *closure = g_simple_async_result_get_op_res_gpointer (res);
|
ItemsClosure *closure = g_simple_async_result_get_op_res_gpointer (res);
|
||||||
const gchar *item_path;
|
GSecretCollection *self = GSECRET_COLLECTION (g_async_result_get_source_object (user_data));
|
||||||
|
const gchar *path;
|
||||||
GError *error = NULL;
|
GError *error = NULL;
|
||||||
GSecretItem *item;
|
GSecretItem *item;
|
||||||
|
|
||||||
@ -240,57 +245,118 @@ on_item_loading (GObject *source,
|
|||||||
g_simple_async_result_take_error (res, error);
|
g_simple_async_result_take_error (res, error);
|
||||||
|
|
||||||
if (item != NULL) {
|
if (item != NULL) {
|
||||||
item_path = g_dbus_proxy_get_object_path (G_DBUS_PROXY (item));
|
path = g_dbus_proxy_get_object_path (G_DBUS_PROXY (item));
|
||||||
g_hash_table_insert (closure->items, g_strdup (item_path), item);
|
g_hash_table_insert (closure->items, g_strdup (path), item);
|
||||||
}
|
}
|
||||||
|
|
||||||
if (closure->items_loading == 0)
|
if (closure->items_loading == 0) {
|
||||||
load_items_complete (res);
|
collection_update_items (self, closure->items);
|
||||||
|
g_simple_async_result_complete_in_idle (res);
|
||||||
|
}
|
||||||
|
|
||||||
|
g_object_unref (self);
|
||||||
g_object_unref (res);
|
g_object_unref (res);
|
||||||
}
|
}
|
||||||
|
|
||||||
static void
|
static void
|
||||||
load_items_perform (GSecretCollection *self,
|
collection_load_items_async (GSecretCollection *self,
|
||||||
GSimpleAsyncResult *res,
|
GCancellable *cancellable,
|
||||||
GVariant *item_paths)
|
GAsyncReadyCallback callback,
|
||||||
|
gpointer user_data)
|
||||||
{
|
{
|
||||||
LoadClosure *closure = g_simple_async_result_get_op_res_gpointer (res);
|
ItemsClosure *closure;
|
||||||
GSecretItem *item;
|
GSecretItem *item;
|
||||||
|
GSimpleAsyncResult *res;
|
||||||
|
const gchar *path;
|
||||||
|
GVariant *paths;
|
||||||
GVariantIter iter;
|
GVariantIter iter;
|
||||||
gchar *item_path;
|
|
||||||
|
|
||||||
g_assert (GSECRET_IS_COLLECTION (self));
|
paths = g_dbus_proxy_get_cached_property (G_DBUS_PROXY (self), "Items");
|
||||||
g_assert (item_paths != NULL);
|
g_return_if_fail (paths != NULL);
|
||||||
g_assert (closure->collection == NULL);
|
|
||||||
|
|
||||||
closure->collection = g_object_ref (self);
|
res = g_simple_async_result_new (G_OBJECT (self), callback, user_data,
|
||||||
|
collection_load_items_async);
|
||||||
|
closure = g_slice_new0 (ItemsClosure);
|
||||||
|
closure->cancellable = cancellable ? g_object_ref (cancellable) : NULL;
|
||||||
|
closure->items = items_table_new ();
|
||||||
|
g_simple_async_result_set_op_res_gpointer (res, closure, items_closure_free);
|
||||||
|
|
||||||
g_variant_iter_init (&iter, item_paths);
|
g_variant_iter_init (&iter, paths);
|
||||||
while (g_variant_iter_loop (&iter, "o", &item_path)) {
|
while (g_variant_iter_loop (&iter, "&o", &path)) {
|
||||||
|
item = collection_lookup_item (self, path);
|
||||||
g_mutex_lock (&self->pv->mutex);
|
|
||||||
item = g_hash_table_lookup (self->pv->items, item_path);
|
|
||||||
if (item != NULL)
|
|
||||||
g_object_ref (item);
|
|
||||||
g_mutex_unlock (&self->pv->mutex);
|
|
||||||
|
|
||||||
|
/* No such collection yet create a new one */
|
||||||
if (item == NULL) {
|
if (item == NULL) {
|
||||||
// TODO: xxxxxxxxxxxx;
|
gsecret_item_new (self->pv->service, path, cancellable,
|
||||||
gsecret_item_new (self->pv->service, item_path,
|
on_load_item, g_object_ref (res));
|
||||||
closure->cancellable, on_item_loading,
|
|
||||||
g_object_ref (res));
|
|
||||||
closure->items_loading++;
|
closure->items_loading++;
|
||||||
|
|
||||||
} else {
|
} else {
|
||||||
g_hash_table_insert (closure->items,
|
g_hash_table_insert (closure->items, g_strdup (path), item);
|
||||||
g_strdup (item_path), item);
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
if (closure->items_loading == 0) {
|
||||||
|
collection_update_items (self, closure->items);
|
||||||
|
g_simple_async_result_complete_in_idle (res);
|
||||||
}
|
}
|
||||||
|
|
||||||
if (closure->items_loading == 0)
|
g_variant_unref (paths);
|
||||||
load_items_complete (res);
|
g_object_unref (res);
|
||||||
|
}
|
||||||
|
|
||||||
|
static gboolean
|
||||||
|
collection_load_items_finish (GSecretCollection *self,
|
||||||
|
GAsyncResult *result,
|
||||||
|
GError **error)
|
||||||
|
{
|
||||||
|
if (g_simple_async_result_propagate_error (G_SIMPLE_ASYNC_RESULT (result), error))
|
||||||
|
return FALSE;
|
||||||
|
|
||||||
|
return TRUE;
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
static gboolean
|
||||||
|
collection_load_items_sync (GSecretCollection *self,
|
||||||
|
GCancellable *cancellable,
|
||||||
|
GError **error)
|
||||||
|
{
|
||||||
|
GSecretItem *item;
|
||||||
|
GHashTable *items;
|
||||||
|
GVariant *paths;
|
||||||
|
GVariantIter iter;
|
||||||
|
const gchar *path;
|
||||||
|
gboolean ret = TRUE;
|
||||||
|
|
||||||
|
paths = g_dbus_proxy_get_cached_property (G_DBUS_PROXY (self), "Items");
|
||||||
|
g_return_val_if_fail (paths != NULL, FALSE);
|
||||||
|
|
||||||
|
items = items_table_new ();
|
||||||
|
|
||||||
|
g_variant_iter_init (&iter, paths);
|
||||||
|
while (g_variant_iter_next (&iter, "&o", &path)) {
|
||||||
|
item = collection_lookup_item (self, path);
|
||||||
|
|
||||||
|
/* No such collection yet create a new one */
|
||||||
|
if (item == NULL) {
|
||||||
|
item = gsecret_item_new_sync (self->pv->service, path,
|
||||||
|
cancellable, error);
|
||||||
|
if (item == NULL) {
|
||||||
|
ret = FALSE;
|
||||||
|
break;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
g_hash_table_insert (items, g_strdup (path), item);
|
||||||
|
}
|
||||||
|
|
||||||
|
if (ret)
|
||||||
|
collection_update_items (self, items);
|
||||||
|
|
||||||
|
g_hash_table_unref (items);
|
||||||
|
g_variant_unref (paths);
|
||||||
|
return ret;
|
||||||
}
|
}
|
||||||
|
|
||||||
static void
|
static void
|
||||||
@ -298,8 +364,6 @@ handle_property_changed (GSecretCollection *self,
|
|||||||
const gchar *property_name,
|
const gchar *property_name,
|
||||||
GVariant *value)
|
GVariant *value)
|
||||||
{
|
{
|
||||||
GSimpleAsyncResult *res;
|
|
||||||
|
|
||||||
if (g_str_equal (property_name, "Label"))
|
if (g_str_equal (property_name, "Label"))
|
||||||
g_object_notify (G_OBJECT (self), "label");
|
g_object_notify (G_OBJECT (self), "label");
|
||||||
|
|
||||||
@ -312,24 +376,8 @@ handle_property_changed (GSecretCollection *self,
|
|||||||
else if (g_str_equal (property_name, "Modified"))
|
else if (g_str_equal (property_name, "Modified"))
|
||||||
g_object_notify (G_OBJECT (self), "modified");
|
g_object_notify (G_OBJECT (self), "modified");
|
||||||
|
|
||||||
else if (g_str_equal (property_name, "Items") && !self->pv->constructing) {
|
else if (g_str_equal (property_name, "Items") && !self->pv->constructing)
|
||||||
res = load_result_new (self->pv->cancellable, NULL, NULL);
|
collection_load_items_async (self, self->pv->cancellable, NULL, NULL);
|
||||||
|
|
||||||
if (value == NULL)
|
|
||||||
value = g_dbus_proxy_get_cached_property (G_DBUS_PROXY (self), "Items");
|
|
||||||
else
|
|
||||||
g_variant_ref (value);
|
|
||||||
if (value == NULL) {
|
|
||||||
g_warning ("couldn't retrieve Collection Items property");
|
|
||||||
g_simple_async_result_complete (res);
|
|
||||||
} else {
|
|
||||||
// TODO: yyyy;
|
|
||||||
load_items_perform (self, res, value);
|
|
||||||
g_variant_unref (value);
|
|
||||||
}
|
|
||||||
|
|
||||||
g_object_unref (res);
|
|
||||||
}
|
|
||||||
}
|
}
|
||||||
|
|
||||||
static void
|
static void
|
||||||
@ -392,49 +440,147 @@ gsecret_collection_class_init (GSecretCollectionClass *klass)
|
|||||||
g_type_class_add_private (gobject_class, sizeof (GSecretCollectionPrivate));
|
g_type_class_add_private (gobject_class, sizeof (GSecretCollectionPrivate));
|
||||||
}
|
}
|
||||||
|
|
||||||
|
static gboolean
|
||||||
|
gsecret_collection_initable_init (GInitable *initable,
|
||||||
|
GCancellable *cancellable,
|
||||||
|
GError **error)
|
||||||
|
{
|
||||||
|
GSecretCollection *self;
|
||||||
|
GDBusProxy *proxy;
|
||||||
|
|
||||||
|
if (!gsecret_collection_initable_parent_iface->init (initable, cancellable, error))
|
||||||
|
return FALSE;
|
||||||
|
|
||||||
|
proxy = G_DBUS_PROXY (initable);
|
||||||
|
|
||||||
|
if (!_gsecret_util_have_cached_properties (proxy)) {
|
||||||
|
g_set_error (error, G_DBUS_ERROR, G_DBUS_ERROR_UNKNOWN_METHOD,
|
||||||
|
"No such secret collection at path: %s",
|
||||||
|
g_dbus_proxy_get_object_path (proxy));
|
||||||
|
return FALSE;
|
||||||
|
}
|
||||||
|
|
||||||
|
self = GSECRET_COLLECTION (initable);
|
||||||
|
|
||||||
|
if (!collection_load_items_sync (self, cancellable, error))
|
||||||
|
return FALSE;
|
||||||
|
|
||||||
|
return TRUE;
|
||||||
|
}
|
||||||
|
|
||||||
static void
|
static void
|
||||||
on_collection_new (GObject *source,
|
gsecret_collection_initable_iface (GInitableIface *iface)
|
||||||
|
{
|
||||||
|
gsecret_collection_initable_parent_iface = g_type_interface_peek_parent (iface);
|
||||||
|
|
||||||
|
iface->init = gsecret_collection_initable_init;
|
||||||
|
}
|
||||||
|
|
||||||
|
typedef struct {
|
||||||
|
GCancellable *cancellable;
|
||||||
|
} InitClosure;
|
||||||
|
|
||||||
|
static void
|
||||||
|
init_closure_free (gpointer data)
|
||||||
|
{
|
||||||
|
InitClosure *closure = data;
|
||||||
|
g_clear_object (&closure->cancellable);
|
||||||
|
g_slice_free (InitClosure, closure);
|
||||||
|
}
|
||||||
|
|
||||||
|
static void
|
||||||
|
on_init_items (GObject *source,
|
||||||
GAsyncResult *result,
|
GAsyncResult *result,
|
||||||
gpointer user_data)
|
gpointer user_data)
|
||||||
{
|
{
|
||||||
GSimpleAsyncResult *res = G_SIMPLE_ASYNC_RESULT (user_data);
|
GSimpleAsyncResult *res = G_SIMPLE_ASYNC_RESULT (user_data);
|
||||||
GSecretCollection *self;
|
GSecretCollection *self = GSECRET_COLLECTION (source);
|
||||||
GObject *source_object;
|
|
||||||
GError *error = NULL;
|
GError *error = NULL;
|
||||||
GVariant *item_paths;
|
|
||||||
GObject *object;
|
|
||||||
GDBusProxy *proxy;
|
|
||||||
|
|
||||||
source_object = g_async_result_get_source_object (result);
|
if (!collection_load_items_finish (self, result, &error))
|
||||||
object = g_async_initable_new_finish (G_ASYNC_INITABLE (source_object),
|
g_simple_async_result_take_error (res, error);
|
||||||
result, &error);
|
|
||||||
g_object_unref (source_object);
|
|
||||||
|
|
||||||
proxy = G_DBUS_PROXY (object);
|
g_simple_async_result_complete (res);
|
||||||
if (error == NULL && !_gsecret_util_have_cached_properties (proxy)) {
|
g_object_unref (res);
|
||||||
g_set_error (&error, G_DBUS_ERROR, G_DBUS_ERROR_UNKNOWN_METHOD,
|
}
|
||||||
"No such secret collection at path: %s", g_dbus_proxy_get_object_path (proxy));
|
|
||||||
}
|
|
||||||
|
|
||||||
if (error == NULL) {
|
static void
|
||||||
self = GSECRET_COLLECTION (object);
|
on_init_base (GObject *source,
|
||||||
self->pv->constructing = FALSE;
|
GAsyncResult *result,
|
||||||
|
gpointer user_data)
|
||||||
|
{
|
||||||
|
GSimpleAsyncResult *res = G_SIMPLE_ASYNC_RESULT (user_data);
|
||||||
|
GSecretCollection *self = GSECRET_COLLECTION (source);
|
||||||
|
InitClosure *closure = g_simple_async_result_get_op_res_gpointer (res);
|
||||||
|
GDBusProxy *proxy = G_DBUS_PROXY (self);
|
||||||
|
GError *error = NULL;
|
||||||
|
|
||||||
item_paths = g_dbus_proxy_get_cached_property (G_DBUS_PROXY (object), "Items");
|
if (!gsecret_collection_async_initable_parent_iface->init_finish (G_ASYNC_INITABLE (self),
|
||||||
g_return_if_fail (item_paths != NULL);
|
result, &error)) {
|
||||||
// TODO: yyyy;
|
|
||||||
load_items_perform (self, res, item_paths);
|
|
||||||
g_variant_unref (item_paths);
|
|
||||||
|
|
||||||
} else {
|
|
||||||
g_simple_async_result_take_error (res, error);
|
g_simple_async_result_take_error (res, error);
|
||||||
g_simple_async_result_complete (res);
|
g_simple_async_result_complete (res);
|
||||||
|
|
||||||
|
} else if (!_gsecret_util_have_cached_properties (proxy)) {
|
||||||
|
g_simple_async_result_set_error (res, G_DBUS_ERROR, G_DBUS_ERROR_UNKNOWN_METHOD,
|
||||||
|
"No such secret collection at path: %s",
|
||||||
|
g_dbus_proxy_get_object_path (proxy));
|
||||||
|
g_simple_async_result_complete (res);
|
||||||
|
|
||||||
|
} else {
|
||||||
|
collection_load_items_async (self, closure->cancellable,
|
||||||
|
on_init_items, g_object_ref (res));
|
||||||
}
|
}
|
||||||
|
|
||||||
g_clear_object (&object);
|
|
||||||
g_object_unref (res);
|
g_object_unref (res);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
static void
|
||||||
|
gsecret_collection_async_initable_init_async (GAsyncInitable *initable,
|
||||||
|
int io_priority,
|
||||||
|
GCancellable *cancellable,
|
||||||
|
GAsyncReadyCallback callback,
|
||||||
|
gpointer user_data)
|
||||||
|
{
|
||||||
|
GSimpleAsyncResult *res;
|
||||||
|
InitClosure *closure;
|
||||||
|
|
||||||
|
res = g_simple_async_result_new (G_OBJECT (initable), callback, user_data,
|
||||||
|
gsecret_collection_async_initable_init_async);
|
||||||
|
closure = g_slice_new0 (InitClosure);
|
||||||
|
closure->cancellable = cancellable ? g_object_ref (cancellable) : NULL;
|
||||||
|
g_simple_async_result_set_op_res_gpointer (res, closure, init_closure_free);
|
||||||
|
|
||||||
|
gsecret_collection_async_initable_parent_iface->init_async (initable, io_priority,
|
||||||
|
cancellable,
|
||||||
|
on_init_base,
|
||||||
|
g_object_ref (res));
|
||||||
|
|
||||||
|
g_object_unref (res);
|
||||||
|
}
|
||||||
|
|
||||||
|
static gboolean
|
||||||
|
gsecret_collection_async_initable_init_finish (GAsyncInitable *initable,
|
||||||
|
GAsyncResult *result,
|
||||||
|
GError **error)
|
||||||
|
{
|
||||||
|
g_return_val_if_fail (g_simple_async_result_is_valid (result, G_OBJECT (initable),
|
||||||
|
gsecret_collection_async_initable_init_async), FALSE);
|
||||||
|
|
||||||
|
if (g_simple_async_result_propagate_error (G_SIMPLE_ASYNC_RESULT (result), error))
|
||||||
|
return FALSE;
|
||||||
|
|
||||||
|
return TRUE;
|
||||||
|
}
|
||||||
|
|
||||||
|
static void
|
||||||
|
gsecret_collection_async_initable_iface (GAsyncInitableIface *iface)
|
||||||
|
{
|
||||||
|
gsecret_collection_async_initable_parent_iface = g_type_interface_peek_parent (iface);
|
||||||
|
|
||||||
|
iface->init_async = gsecret_collection_async_initable_init_async;
|
||||||
|
iface->init_finish = gsecret_collection_async_initable_init_finish;
|
||||||
|
}
|
||||||
|
|
||||||
void
|
void
|
||||||
gsecret_collection_new (GSecretService *service,
|
gsecret_collection_new (GSecretService *service,
|
||||||
const gchar *collection_path,
|
const gchar *collection_path,
|
||||||
@ -442,22 +588,16 @@ gsecret_collection_new (GSecretService *service,
|
|||||||
GAsyncReadyCallback callback,
|
GAsyncReadyCallback callback,
|
||||||
gpointer user_data)
|
gpointer user_data)
|
||||||
{
|
{
|
||||||
GSimpleAsyncResult *res;
|
|
||||||
GDBusProxy *proxy;
|
GDBusProxy *proxy;
|
||||||
|
|
||||||
g_return_if_fail (GSECRET_IS_SERVICE (service));
|
g_return_if_fail (GSECRET_IS_SERVICE (service));
|
||||||
g_return_if_fail (collection_path != NULL);
|
g_return_if_fail (collection_path != NULL);
|
||||||
g_return_if_fail (cancellable == NULL || G_IS_CANCELLABLE (cancellable));
|
g_return_if_fail (cancellable == NULL || G_IS_CANCELLABLE (cancellable));
|
||||||
|
|
||||||
res = load_result_new (cancellable, callback, user_data);
|
|
||||||
proxy = G_DBUS_PROXY (service);
|
proxy = G_DBUS_PROXY (service);
|
||||||
|
|
||||||
g_async_initable_new_async (GSECRET_SERVICE_GET_CLASS (service)->collection_gtype,
|
g_async_initable_new_async (GSECRET_SERVICE_GET_CLASS (service)->collection_gtype,
|
||||||
G_PRIORITY_DEFAULT,
|
G_PRIORITY_DEFAULT, cancellable, callback, user_data,
|
||||||
cancellable,
|
|
||||||
// TODO: zzzz;
|
|
||||||
on_collection_new,
|
|
||||||
g_object_ref (res),
|
|
||||||
"g-flags", G_DBUS_CALL_FLAGS_NONE,
|
"g-flags", G_DBUS_CALL_FLAGS_NONE,
|
||||||
"g-interface-info", _gsecret_gen_collection_interface_info (),
|
"g-interface-info", _gsecret_gen_collection_interface_info (),
|
||||||
"g-name", g_dbus_proxy_get_name (proxy),
|
"g-name", g_dbus_proxy_get_name (proxy),
|
||||||
@ -466,27 +606,27 @@ gsecret_collection_new (GSecretService *service,
|
|||||||
"g-interface-name", GSECRET_COLLECTION_INTERFACE,
|
"g-interface-name", GSECRET_COLLECTION_INTERFACE,
|
||||||
"service", service,
|
"service", service,
|
||||||
NULL);
|
NULL);
|
||||||
|
|
||||||
g_object_unref (res);
|
|
||||||
}
|
}
|
||||||
|
|
||||||
GSecretCollection *
|
GSecretCollection *
|
||||||
gsecret_collection_new_finish (GAsyncResult *result,
|
gsecret_collection_new_finish (GAsyncResult *result,
|
||||||
GError **error)
|
GError **error)
|
||||||
{
|
{
|
||||||
GSimpleAsyncResult *res;
|
GObject *source_object;
|
||||||
LoadClosure *closure;
|
GObject *object;
|
||||||
|
|
||||||
g_return_val_if_fail (g_simple_async_result_is_valid (result, NULL, load_result_new), NULL);
|
g_return_val_if_fail (G_IS_ASYNC_RESULT (result), NULL);
|
||||||
g_return_val_if_fail (error == NULL || *error == NULL, NULL);
|
g_return_val_if_fail (error == NULL || *error == NULL, NULL);
|
||||||
|
|
||||||
res = G_SIMPLE_ASYNC_RESULT (result);
|
source_object = g_async_result_get_source_object (result);
|
||||||
|
object = g_async_initable_new_finish (G_ASYNC_INITABLE (source_object),
|
||||||
|
result, error);
|
||||||
|
g_object_unref (source_object);
|
||||||
|
|
||||||
if (g_simple_async_result_propagate_error (res, error))
|
if (object == NULL)
|
||||||
return NULL;
|
return NULL;
|
||||||
|
|
||||||
closure = g_simple_async_result_get_op_res_gpointer (res);
|
return GSECRET_COLLECTION (object);
|
||||||
return g_object_ref (closure->collection);
|
|
||||||
}
|
}
|
||||||
|
|
||||||
GSecretCollection *
|
GSecretCollection *
|
||||||
@ -495,29 +635,25 @@ gsecret_collection_new_sync (GSecretService *service,
|
|||||||
GCancellable *cancellable,
|
GCancellable *cancellable,
|
||||||
GError **error)
|
GError **error)
|
||||||
{
|
{
|
||||||
GSecretSync *sync;
|
GDBusProxy *proxy;
|
||||||
GSecretCollection *collection;
|
|
||||||
|
|
||||||
g_return_val_if_fail (GSECRET_IS_SERVICE (service), NULL);
|
g_return_val_if_fail (GSECRET_IS_SERVICE (service), NULL);
|
||||||
g_return_val_if_fail (collection_path != NULL, NULL);
|
g_return_val_if_fail (collection_path != NULL, NULL);
|
||||||
g_return_val_if_fail (cancellable == NULL || G_IS_CANCELLABLE (cancellable), NULL);
|
g_return_val_if_fail (cancellable == NULL || G_IS_CANCELLABLE (cancellable), NULL);
|
||||||
g_return_val_if_fail (error == NULL || *error == NULL, NULL);
|
g_return_val_if_fail (error == NULL || *error == NULL, NULL);
|
||||||
|
|
||||||
sync = _gsecret_sync_new ();
|
proxy = G_DBUS_PROXY (service);
|
||||||
g_main_context_push_thread_default (sync->context);
|
|
||||||
|
|
||||||
// TODO: xxxxx;
|
return g_initable_new (GSECRET_SERVICE_GET_CLASS (service)->collection_gtype,
|
||||||
gsecret_collection_new (service, collection_path, cancellable,
|
cancellable, error,
|
||||||
_gsecret_sync_on_result, sync);
|
"g-flags", G_DBUS_CALL_FLAGS_NONE,
|
||||||
|
"g-interface-info", _gsecret_gen_collection_interface_info (),
|
||||||
g_main_loop_run (sync->loop);
|
"g-name", g_dbus_proxy_get_name (proxy),
|
||||||
|
"g-connection", g_dbus_proxy_get_connection (proxy),
|
||||||
collection = gsecret_collection_new_finish (sync->result, error);
|
"g-object-path", collection_path,
|
||||||
|
"g-interface-name", GSECRET_COLLECTION_INTERFACE,
|
||||||
g_main_context_pop_thread_default (sync->context);
|
"service", service,
|
||||||
_gsecret_sync_free (sync);
|
NULL);
|
||||||
|
|
||||||
return collection;
|
|
||||||
}
|
}
|
||||||
|
|
||||||
void
|
void
|
||||||
|
43
library/gsecret-enum-types.c.template
Normal file
43
library/gsecret-enum-types.c.template
Normal file
@ -0,0 +1,43 @@
|
|||||||
|
/*** BEGIN file-header ***/
|
||||||
|
|
||||||
|
#include <glib-object.h>
|
||||||
|
|
||||||
|
#ifndef GSECRET_COMPILATION
|
||||||
|
#define GSECRET_COMPILATION
|
||||||
|
#endif
|
||||||
|
|
||||||
|
/*** END file-header ***/
|
||||||
|
|
||||||
|
/*** BEGIN file-production ***/
|
||||||
|
#include "@filename@"
|
||||||
|
/* enumerations from "@filename@" */
|
||||||
|
/*** END file-production ***/
|
||||||
|
|
||||||
|
/*** BEGIN value-header ***/
|
||||||
|
GType @enum_name@_get_type (void) G_GNUC_CONST;
|
||||||
|
|
||||||
|
GType
|
||||||
|
@enum_name@_get_type (void)
|
||||||
|
{
|
||||||
|
static GType etype = 0;
|
||||||
|
if (G_UNLIKELY(etype == 0)) {
|
||||||
|
static const G@Type@Value values[] = {
|
||||||
|
/*** END value-header ***/
|
||||||
|
|
||||||
|
/*** BEGIN value-production ***/
|
||||||
|
{ @VALUENAME@, "@VALUENAME@", "@valuenick@" },
|
||||||
|
/*** END value-production ***/
|
||||||
|
|
||||||
|
/*** BEGIN value-tail ***/
|
||||||
|
{ 0, NULL, NULL }
|
||||||
|
};
|
||||||
|
etype = g_@type@_register_static (g_intern_static_string ("@EnumName@"), values);
|
||||||
|
}
|
||||||
|
return etype;
|
||||||
|
}
|
||||||
|
|
||||||
|
/*** END value-tail ***/
|
||||||
|
|
||||||
|
/*** BEGIN file-tail ***/
|
||||||
|
/**/
|
||||||
|
/*** END file-tail ***/
|
28
library/gsecret-enum-types.h.template
Normal file
28
library/gsecret-enum-types.h.template
Normal file
@ -0,0 +1,28 @@
|
|||||||
|
/*** BEGIN file-header ***/
|
||||||
|
#if !defined (__GSECRET_INSIDE_HEADER__) && !defined (GSECRET_COMPILATION)
|
||||||
|
#error "Only <gsecret/gsecret.h> can be included directly."
|
||||||
|
#endif
|
||||||
|
|
||||||
|
#ifndef __GSECRET_ENUM_TYPES_H__
|
||||||
|
#define __GSECRET_ENUM_TYPES_H__
|
||||||
|
|
||||||
|
#include <glib-object.h>
|
||||||
|
|
||||||
|
G_BEGIN_DECLS
|
||||||
|
/*** END file-header ***/
|
||||||
|
|
||||||
|
/*** BEGIN file-production ***/
|
||||||
|
|
||||||
|
/* enumerations from "@filename@" */
|
||||||
|
/*** END file-production ***/
|
||||||
|
|
||||||
|
/*** BEGIN value-header ***/
|
||||||
|
GType @enum_name@_get_type (void) G_GNUC_CONST;
|
||||||
|
#define @ENUMPREFIX@_TYPE_@ENUMSHORT@ (@enum_name@_get_type ())
|
||||||
|
/*** END value-header ***/
|
||||||
|
|
||||||
|
/*** BEGIN file-tail ***/
|
||||||
|
G_END_DECLS
|
||||||
|
|
||||||
|
#endif /* __GSECRET_ENUM_TYPES_H__ */
|
||||||
|
/*** END file-tail ***/
|
@ -37,7 +37,18 @@ typedef struct _GSecretItemPrivate {
|
|||||||
GCancellable *cancellable;
|
GCancellable *cancellable;
|
||||||
} GSecretItemPrivate;
|
} GSecretItemPrivate;
|
||||||
|
|
||||||
G_DEFINE_TYPE (GSecretItem, gsecret_item, G_TYPE_DBUS_PROXY);
|
static GInitableIface *gsecret_item_initable_parent_iface = NULL;
|
||||||
|
|
||||||
|
static GAsyncInitableIface *gsecret_item_async_initable_parent_iface = NULL;
|
||||||
|
|
||||||
|
static void gsecret_item_initable_iface (GInitableIface *iface);
|
||||||
|
|
||||||
|
static void gsecret_item_async_initable_iface (GAsyncInitableIface *iface);
|
||||||
|
|
||||||
|
G_DEFINE_TYPE_WITH_CODE (GSecretItem, gsecret_item, G_TYPE_DBUS_PROXY,
|
||||||
|
G_IMPLEMENT_INTERFACE (G_TYPE_INITABLE, gsecret_item_initable_iface);
|
||||||
|
G_IMPLEMENT_INTERFACE (G_TYPE_ASYNC_INITABLE, gsecret_item_async_initable_iface);
|
||||||
|
);
|
||||||
|
|
||||||
static void
|
static void
|
||||||
gsecret_item_init (GSecretItem *self)
|
gsecret_item_init (GSecretItem *self)
|
||||||
@ -248,20 +259,102 @@ gsecret_item_class_init (GSecretItemClass *klass)
|
|||||||
g_type_class_add_private (gobject_class, sizeof (GSecretItemPrivate));
|
g_type_class_add_private (gobject_class, sizeof (GSecretItemPrivate));
|
||||||
}
|
}
|
||||||
|
|
||||||
#if 0
|
static gboolean
|
||||||
static void
|
gsecret_item_initable_init (GInitable *initable,
|
||||||
all_properties_changed (GSecretItem *item)
|
GCancellable *cancellable,
|
||||||
|
GError **error)
|
||||||
{
|
{
|
||||||
GObject *obj = G_OBJECT (item);
|
GDBusProxy *proxy;
|
||||||
gchar **property_names;
|
|
||||||
guint i;
|
|
||||||
|
|
||||||
property_names = g_dbus_proxy_get_cached_property_names (G_DBUS_PROXY (item));
|
if (!gsecret_item_initable_parent_iface->init (initable, cancellable, error))
|
||||||
for (i = 0; property_names != NULL && property_names[i] != NULL; i++)
|
return FALSE;
|
||||||
handle_property_changed (obj, property_names[i]);
|
|
||||||
g_strfreev (property_names);
|
proxy = G_DBUS_PROXY (initable);
|
||||||
|
|
||||||
|
if (!_gsecret_util_have_cached_properties (proxy)) {
|
||||||
|
g_set_error (error, G_DBUS_ERROR, G_DBUS_ERROR_UNKNOWN_METHOD,
|
||||||
|
"No such secret item at path: %s",
|
||||||
|
g_dbus_proxy_get_object_path (proxy));
|
||||||
|
return FALSE;
|
||||||
|
}
|
||||||
|
|
||||||
|
return TRUE;
|
||||||
|
}
|
||||||
|
|
||||||
|
static void
|
||||||
|
gsecret_item_initable_iface (GInitableIface *iface)
|
||||||
|
{
|
||||||
|
gsecret_item_initable_parent_iface = g_type_interface_peek_parent (iface);
|
||||||
|
|
||||||
|
iface->init = gsecret_item_initable_init;
|
||||||
|
}
|
||||||
|
|
||||||
|
static void
|
||||||
|
on_init_base (GObject *source,
|
||||||
|
GAsyncResult *result,
|
||||||
|
gpointer user_data)
|
||||||
|
{
|
||||||
|
GSimpleAsyncResult *res = G_SIMPLE_ASYNC_RESULT (user_data);
|
||||||
|
GSecretItem *self = GSECRET_ITEM (source);
|
||||||
|
GDBusProxy *proxy = G_DBUS_PROXY (self);
|
||||||
|
GError *error = NULL;
|
||||||
|
|
||||||
|
if (!gsecret_item_async_initable_parent_iface->init_finish (G_ASYNC_INITABLE (self),
|
||||||
|
result, &error)) {
|
||||||
|
g_simple_async_result_take_error (res, error);
|
||||||
|
|
||||||
|
} else if (!_gsecret_util_have_cached_properties (proxy)) {
|
||||||
|
g_simple_async_result_set_error (res, G_DBUS_ERROR, G_DBUS_ERROR_UNKNOWN_METHOD,
|
||||||
|
"No such secret item at path: %s",
|
||||||
|
g_dbus_proxy_get_object_path (proxy));
|
||||||
|
}
|
||||||
|
|
||||||
|
g_simple_async_result_complete (res);
|
||||||
|
g_object_unref (res);
|
||||||
|
}
|
||||||
|
|
||||||
|
static void
|
||||||
|
gsecret_item_async_initable_init_async (GAsyncInitable *initable,
|
||||||
|
int io_priority,
|
||||||
|
GCancellable *cancellable,
|
||||||
|
GAsyncReadyCallback callback,
|
||||||
|
gpointer user_data)
|
||||||
|
{
|
||||||
|
GSimpleAsyncResult *res;
|
||||||
|
|
||||||
|
res = g_simple_async_result_new (G_OBJECT (initable), callback, user_data,
|
||||||
|
gsecret_item_async_initable_init_async);
|
||||||
|
|
||||||
|
gsecret_item_async_initable_parent_iface->init_async (initable, io_priority,
|
||||||
|
cancellable,
|
||||||
|
on_init_base,
|
||||||
|
g_object_ref (res));
|
||||||
|
|
||||||
|
g_object_unref (res);
|
||||||
|
}
|
||||||
|
|
||||||
|
static gboolean
|
||||||
|
gsecret_item_async_initable_init_finish (GAsyncInitable *initable,
|
||||||
|
GAsyncResult *result,
|
||||||
|
GError **error)
|
||||||
|
{
|
||||||
|
g_return_val_if_fail (g_simple_async_result_is_valid (result, G_OBJECT (initable),
|
||||||
|
gsecret_item_async_initable_init_async), FALSE);
|
||||||
|
|
||||||
|
if (g_simple_async_result_propagate_error (G_SIMPLE_ASYNC_RESULT (result), error))
|
||||||
|
return FALSE;
|
||||||
|
|
||||||
|
return TRUE;
|
||||||
|
}
|
||||||
|
|
||||||
|
static void
|
||||||
|
gsecret_item_async_initable_iface (GAsyncInitableIface *iface)
|
||||||
|
{
|
||||||
|
gsecret_item_async_initable_parent_iface = g_type_interface_peek_parent (iface);
|
||||||
|
|
||||||
|
iface->init_async = gsecret_item_async_initable_init_async;
|
||||||
|
iface->init_finish = gsecret_item_async_initable_init_finish;
|
||||||
}
|
}
|
||||||
#endif
|
|
||||||
|
|
||||||
void
|
void
|
||||||
gsecret_item_new (GSecretService *service,
|
gsecret_item_new (GSecretService *service,
|
||||||
@ -279,10 +372,7 @@ gsecret_item_new (GSecretService *service,
|
|||||||
proxy = G_DBUS_PROXY (service);
|
proxy = G_DBUS_PROXY (service);
|
||||||
|
|
||||||
g_async_initable_new_async (GSECRET_SERVICE_GET_CLASS (service)->item_gtype,
|
g_async_initable_new_async (GSECRET_SERVICE_GET_CLASS (service)->item_gtype,
|
||||||
G_PRIORITY_DEFAULT,
|
G_PRIORITY_DEFAULT, cancellable, callback, user_data,
|
||||||
cancellable,
|
|
||||||
callback,
|
|
||||||
user_data,
|
|
||||||
"g-flags", G_DBUS_CALL_FLAGS_NONE,
|
"g-flags", G_DBUS_CALL_FLAGS_NONE,
|
||||||
"g-interface-info", _gsecret_gen_item_interface_info (),
|
"g-interface-info", _gsecret_gen_item_interface_info (),
|
||||||
"g-name", g_dbus_proxy_get_name (proxy),
|
"g-name", g_dbus_proxy_get_name (proxy),
|
||||||
@ -299,7 +389,6 @@ gsecret_item_new_finish (GAsyncResult *result,
|
|||||||
{
|
{
|
||||||
GObject *object;
|
GObject *object;
|
||||||
GObject *source_object;
|
GObject *source_object;
|
||||||
GDBusProxy *proxy;
|
|
||||||
|
|
||||||
source_object = g_async_result_get_source_object (result);
|
source_object = g_async_result_get_source_object (result);
|
||||||
object = g_async_initable_new_finish (G_ASYNC_INITABLE (source_object),
|
object = g_async_initable_new_finish (G_ASYNC_INITABLE (source_object),
|
||||||
@ -309,14 +398,6 @@ gsecret_item_new_finish (GAsyncResult *result,
|
|||||||
if (object == NULL)
|
if (object == NULL)
|
||||||
return NULL;
|
return NULL;
|
||||||
|
|
||||||
proxy = G_DBUS_PROXY (object);
|
|
||||||
if (!_gsecret_util_have_cached_properties (proxy)) {
|
|
||||||
g_set_error (error, G_DBUS_ERROR, G_DBUS_ERROR_UNKNOWN_METHOD,
|
|
||||||
"No such secret item at path: %s", g_dbus_proxy_get_object_path (proxy));
|
|
||||||
g_object_unref (object);
|
|
||||||
return NULL;
|
|
||||||
}
|
|
||||||
|
|
||||||
return GSECRET_ITEM (object);
|
return GSECRET_ITEM (object);
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -326,29 +407,25 @@ gsecret_item_new_sync (GSecretService *service,
|
|||||||
GCancellable *cancellable,
|
GCancellable *cancellable,
|
||||||
GError **error)
|
GError **error)
|
||||||
{
|
{
|
||||||
GSecretSync *sync;
|
GDBusProxy *proxy;
|
||||||
GSecretItem *item;
|
|
||||||
|
|
||||||
g_return_val_if_fail (GSECRET_IS_SERVICE (service), NULL);
|
g_return_val_if_fail (GSECRET_IS_SERVICE (service), NULL);
|
||||||
g_return_val_if_fail (item_path != NULL, NULL);
|
g_return_val_if_fail (item_path != NULL, NULL);
|
||||||
g_return_val_if_fail (cancellable == NULL || G_IS_CANCELLABLE (cancellable), NULL);
|
g_return_val_if_fail (cancellable == NULL || G_IS_CANCELLABLE (cancellable), NULL);
|
||||||
g_return_val_if_fail (error == NULL || *error == NULL, NULL);
|
g_return_val_if_fail (error == NULL || *error == NULL, NULL);
|
||||||
|
|
||||||
sync = _gsecret_sync_new ();
|
proxy = G_DBUS_PROXY (service);
|
||||||
g_main_context_push_thread_default (sync->context);
|
|
||||||
|
|
||||||
// TODO: xxxxx;
|
return g_initable_new (GSECRET_SERVICE_GET_CLASS (service)->item_gtype,
|
||||||
gsecret_item_new (service, item_path, cancellable,
|
cancellable, error,
|
||||||
_gsecret_sync_on_result, sync);
|
"g-flags", G_DBUS_CALL_FLAGS_NONE,
|
||||||
|
"g-interface-info", _gsecret_gen_item_interface_info (),
|
||||||
g_main_loop_run (sync->loop);
|
"g-name", g_dbus_proxy_get_name (proxy),
|
||||||
|
"g-connection", g_dbus_proxy_get_connection (proxy),
|
||||||
item = gsecret_item_new_finish (sync->result, error);
|
"g-object-path", item_path,
|
||||||
|
"g-interface-name", GSECRET_ITEM_INTERFACE,
|
||||||
g_main_context_pop_thread_default (sync->context);
|
"service", service,
|
||||||
_gsecret_sync_free (sync);
|
NULL);
|
||||||
|
|
||||||
return item;
|
|
||||||
}
|
}
|
||||||
|
|
||||||
void
|
void
|
||||||
|
@ -68,7 +68,7 @@ on_store_connected (GObject *source,
|
|||||||
GSecretService *service;
|
GSecretService *service;
|
||||||
GError *error = NULL;
|
GError *error = NULL;
|
||||||
|
|
||||||
service = _gsecret_service_bare_connect_finish (result, &error);
|
service = gsecret_service_get_finish (result, &error);
|
||||||
if (error == NULL) {
|
if (error == NULL) {
|
||||||
gsecret_service_storev (service, closure->schema,
|
gsecret_service_storev (service, closure->schema,
|
||||||
closure->attributes,
|
closure->attributes,
|
||||||
@ -147,7 +147,7 @@ gsecret_password_storev (const GSecretSchema *schema,
|
|||||||
closure->cancellable = cancellable ? g_object_ref (cancellable) : NULL;
|
closure->cancellable = cancellable ? g_object_ref (cancellable) : NULL;
|
||||||
g_simple_async_result_set_op_res_gpointer (res, closure, store_closure_free);
|
g_simple_async_result_set_op_res_gpointer (res, closure, store_closure_free);
|
||||||
|
|
||||||
_gsecret_service_bare_connect (NULL, TRUE, cancellable,
|
gsecret_service_get (GSECRET_SERVICE_OPEN_SESSION, cancellable,
|
||||||
on_store_connected, g_object_ref (res));
|
on_store_connected, g_object_ref (res));
|
||||||
|
|
||||||
g_object_unref (res);
|
g_object_unref (res);
|
||||||
@ -306,7 +306,7 @@ on_lookup_connected (GObject *source,
|
|||||||
GSecretService *service;
|
GSecretService *service;
|
||||||
GError *error = NULL;
|
GError *error = NULL;
|
||||||
|
|
||||||
service = _gsecret_service_bare_connect_finish (result, &error);
|
service = gsecret_service_get_finish (result, &error);
|
||||||
if (error != NULL) {
|
if (error != NULL) {
|
||||||
g_simple_async_result_take_error (res, error);
|
g_simple_async_result_take_error (res, error);
|
||||||
g_simple_async_result_complete (res);
|
g_simple_async_result_complete (res);
|
||||||
@ -338,7 +338,7 @@ gsecret_password_lookupv (GHashTable *attributes,
|
|||||||
closure->cancellable = cancellable ? g_object_ref (cancellable) : NULL;
|
closure->cancellable = cancellable ? g_object_ref (cancellable) : NULL;
|
||||||
g_simple_async_result_set_op_res_gpointer (res, closure, lookup_closure_free);
|
g_simple_async_result_set_op_res_gpointer (res, closure, lookup_closure_free);
|
||||||
|
|
||||||
_gsecret_service_bare_connect (NULL, TRUE, cancellable,
|
gsecret_service_get (GSECRET_SERVICE_OPEN_SESSION, cancellable,
|
||||||
on_lookup_connected, g_object_ref (res));
|
on_lookup_connected, g_object_ref (res));
|
||||||
|
|
||||||
g_object_unref (res);
|
g_object_unref (res);
|
||||||
@ -490,7 +490,7 @@ on_delete_connect (GObject *source,
|
|||||||
GSecretService *service;
|
GSecretService *service;
|
||||||
GError *error = NULL;
|
GError *error = NULL;
|
||||||
|
|
||||||
service = _gsecret_service_bare_connect_finish (result, &error);
|
service = gsecret_service_get_finish (result, &error);
|
||||||
if (error == NULL) {
|
if (error == NULL) {
|
||||||
gsecret_service_removev (service, closure->attributes,
|
gsecret_service_removev (service, closure->attributes,
|
||||||
closure->cancellable, on_delete_complete,
|
closure->cancellable, on_delete_complete,
|
||||||
@ -524,9 +524,8 @@ gsecret_password_removev (GHashTable *attributes,
|
|||||||
closure->cancellable = cancellable ? g_object_ref (cancellable) : NULL;
|
closure->cancellable = cancellable ? g_object_ref (cancellable) : NULL;
|
||||||
g_simple_async_result_set_op_res_gpointer (res, closure, delete_closure_free);
|
g_simple_async_result_set_op_res_gpointer (res, closure, delete_closure_free);
|
||||||
|
|
||||||
_gsecret_service_bare_connect (NULL, FALSE, cancellable,
|
gsecret_service_get (GSECRET_SERVICE_NONE, cancellable,
|
||||||
on_delete_connect,
|
on_delete_connect, g_object_ref (res));
|
||||||
g_object_ref (res));
|
|
||||||
|
|
||||||
g_object_unref (res);
|
g_object_unref (res);
|
||||||
}
|
}
|
||||||
|
@ -99,6 +99,7 @@ gboolean _gsecret_util_have_cached_properties (GDBusProxy *prox
|
|||||||
|
|
||||||
void _gsecret_service_set_default_bus_name (const gchar *bus_name);
|
void _gsecret_service_set_default_bus_name (const gchar *bus_name);
|
||||||
|
|
||||||
|
#if 0
|
||||||
GSecretService * _gsecret_service_bare_instance (GDBusConnection *connection,
|
GSecretService * _gsecret_service_bare_instance (GDBusConnection *connection,
|
||||||
const gchar *bus_name);
|
const gchar *bus_name);
|
||||||
|
|
||||||
@ -110,6 +111,7 @@ void _gsecret_service_bare_connect (const gchar *bus
|
|||||||
|
|
||||||
GSecretService * _gsecret_service_bare_connect_finish (GAsyncResult *result,
|
GSecretService * _gsecret_service_bare_connect_finish (GAsyncResult *result,
|
||||||
GError **error);
|
GError **error);
|
||||||
|
#endif
|
||||||
|
|
||||||
GSecretSession * _gsecret_service_get_session (GSecretService *self);
|
GSecretSession * _gsecret_service_get_session (GSecretService *self);
|
||||||
|
|
||||||
@ -135,7 +137,7 @@ void _gsecret_session_open (GSecretService *
|
|||||||
GAsyncReadyCallback callback,
|
GAsyncReadyCallback callback,
|
||||||
gpointer user_data);
|
gpointer user_data);
|
||||||
|
|
||||||
GSecretSession * _gsecret_session_open_finish (GAsyncResult *result,
|
gboolean _gsecret_session_open_finish (GAsyncResult *result,
|
||||||
GError **error);
|
GError **error);
|
||||||
|
|
||||||
GVariant * _gsecret_session_encode_secret (GSecretSession *session,
|
GVariant * _gsecret_session_encode_secret (GSecretSession *session,
|
||||||
|
File diff suppressed because it is too large
Load Diff
@ -22,6 +22,12 @@
|
|||||||
|
|
||||||
G_BEGIN_DECLS
|
G_BEGIN_DECLS
|
||||||
|
|
||||||
|
typedef enum {
|
||||||
|
GSECRET_SERVICE_NONE,
|
||||||
|
GSECRET_SERVICE_OPEN_SESSION = 1 << 1,
|
||||||
|
GSECRET_SERVICE_LOAD_COLLECTIONS = 1 << 2,
|
||||||
|
} GSecretServiceFlags;
|
||||||
|
|
||||||
#define GSECRET_TYPE_SERVICE (gsecret_service_get_type ())
|
#define GSECRET_TYPE_SERVICE (gsecret_service_get_type ())
|
||||||
#define GSECRET_SERVICE(inst) (G_TYPE_CHECK_INSTANCE_CAST ((inst), GSECRET_TYPE_SERVICE, GSecretService))
|
#define GSECRET_SERVICE(inst) (G_TYPE_CHECK_INSTANCE_CAST ((inst), GSECRET_TYPE_SERVICE, GSecretService))
|
||||||
#define GSECRET_SERVICE_CLASS(class) (G_TYPE_CHECK_CLASS_CAST ((class), GSECRET_TYPE_SERVICE, GSecretServiceClass))
|
#define GSECRET_SERVICE_CLASS(class) (G_TYPE_CHECK_CLASS_CAST ((class), GSECRET_TYPE_SERVICE, GSecretServiceClass))
|
||||||
@ -63,16 +69,34 @@ struct _GSecretServiceClass {
|
|||||||
|
|
||||||
GType gsecret_service_get_type (void) G_GNUC_CONST;
|
GType gsecret_service_get_type (void) G_GNUC_CONST;
|
||||||
|
|
||||||
void gsecret_service_get (GCancellable *cancellable,
|
void gsecret_service_get (GSecretServiceFlags flags,
|
||||||
|
GCancellable *cancellable,
|
||||||
GAsyncReadyCallback callback,
|
GAsyncReadyCallback callback,
|
||||||
gpointer user_data);
|
gpointer user_data);
|
||||||
|
|
||||||
GSecretService * gsecret_service_get_finish (GAsyncResult *result,
|
GSecretService * gsecret_service_get_finish (GAsyncResult *result,
|
||||||
GError **error);
|
GError **error);
|
||||||
|
|
||||||
GSecretService * gsecret_service_get_sync (GCancellable *cancellable,
|
GSecretService * gsecret_service_get_sync (GSecretServiceFlags flags,
|
||||||
|
GCancellable *cancellable,
|
||||||
GError **error);
|
GError **error);
|
||||||
|
|
||||||
|
void gsecret_service_new (const gchar *service_bus_name,
|
||||||
|
GSecretServiceFlags flags,
|
||||||
|
GCancellable *cancellable,
|
||||||
|
GAsyncReadyCallback callback,
|
||||||
|
gpointer user_data);
|
||||||
|
|
||||||
|
GSecretService * gsecret_service_new_finish (GAsyncResult *result,
|
||||||
|
GError **error);
|
||||||
|
|
||||||
|
GSecretService * gsecret_service_new_sync (const gchar *service_bus_name,
|
||||||
|
GSecretServiceFlags flags,
|
||||||
|
GCancellable *cancellable,
|
||||||
|
GError **error);
|
||||||
|
|
||||||
|
GSecretServiceFlags gsecret_service_get_flags (GSecretService *self);
|
||||||
|
|
||||||
const gchar * gsecret_service_get_session_algorithms (GSecretService *self);
|
const gchar * gsecret_service_get_session_algorithms (GSecretService *self);
|
||||||
|
|
||||||
const gchar * gsecret_service_get_session_path (GSecretService *self);
|
const gchar * gsecret_service_get_session_path (GSecretService *self);
|
||||||
|
@ -334,20 +334,14 @@ _gsecret_session_open (GSecretService *service,
|
|||||||
g_object_unref (res);
|
g_object_unref (res);
|
||||||
}
|
}
|
||||||
|
|
||||||
GSecretSession *
|
gboolean
|
||||||
_gsecret_session_open_finish (GAsyncResult *result,
|
_gsecret_session_open_finish (GAsyncResult *result,
|
||||||
GError **error)
|
GError **error)
|
||||||
{
|
{
|
||||||
OpenSessionClosure *closure;
|
|
||||||
GSecretSession *session;
|
|
||||||
|
|
||||||
if (g_simple_async_result_propagate_error (G_SIMPLE_ASYNC_RESULT (result), error))
|
if (g_simple_async_result_propagate_error (G_SIMPLE_ASYNC_RESULT (result), error))
|
||||||
return NULL;
|
return FALSE;
|
||||||
|
|
||||||
closure = g_simple_async_result_get_op_res_gpointer (G_SIMPLE_ASYNC_RESULT (result));
|
return TRUE;
|
||||||
session = closure->session;
|
|
||||||
closure->session = NULL;
|
|
||||||
return session;
|
|
||||||
}
|
}
|
||||||
|
|
||||||
#ifdef WITH_GCRYPT
|
#ifdef WITH_GCRYPT
|
||||||
|
@ -29,7 +29,6 @@
|
|||||||
#include <stdlib.h>
|
#include <stdlib.h>
|
||||||
|
|
||||||
typedef struct {
|
typedef struct {
|
||||||
GDBusConnection *connection;
|
|
||||||
GSecretService *service;
|
GSecretService *service;
|
||||||
} Test;
|
} Test;
|
||||||
|
|
||||||
@ -43,26 +42,18 @@ setup (Test *test,
|
|||||||
mock_service_start (mock_script, &error);
|
mock_service_start (mock_script, &error);
|
||||||
g_assert_no_error (error);
|
g_assert_no_error (error);
|
||||||
|
|
||||||
test->connection = g_bus_get_sync (G_BUS_TYPE_SESSION, NULL, &error);
|
test->service = gsecret_service_get_sync (GSECRET_SERVICE_NONE, NULL, &error);
|
||||||
g_assert_no_error (error);
|
g_assert_no_error (error);
|
||||||
|
|
||||||
test->service = _gsecret_service_bare_instance (test->connection, NULL);
|
|
||||||
}
|
}
|
||||||
|
|
||||||
static void
|
static void
|
||||||
teardown (Test *test,
|
teardown (Test *test,
|
||||||
gconstpointer unused)
|
gconstpointer unused)
|
||||||
{
|
{
|
||||||
GError *error = NULL;
|
|
||||||
|
|
||||||
g_object_unref (test->service);
|
g_object_unref (test->service);
|
||||||
egg_assert_not_object (test->service);
|
egg_assert_not_object (test->service);
|
||||||
|
|
||||||
mock_service_stop ();
|
mock_service_stop ();
|
||||||
|
|
||||||
g_dbus_connection_flush_sync (test->connection, NULL, &error);
|
|
||||||
g_assert_no_error (error);
|
|
||||||
g_object_unref (test->connection);
|
|
||||||
}
|
}
|
||||||
|
|
||||||
static void
|
static void
|
||||||
|
@ -29,7 +29,6 @@
|
|||||||
#include <stdlib.h>
|
#include <stdlib.h>
|
||||||
|
|
||||||
typedef struct {
|
typedef struct {
|
||||||
GDBusConnection *connection;
|
|
||||||
GSecretService *service;
|
GSecretService *service;
|
||||||
} Test;
|
} Test;
|
||||||
|
|
||||||
@ -43,26 +42,18 @@ setup (Test *test,
|
|||||||
mock_service_start (mock_script, &error);
|
mock_service_start (mock_script, &error);
|
||||||
g_assert_no_error (error);
|
g_assert_no_error (error);
|
||||||
|
|
||||||
test->connection = g_bus_get_sync (G_BUS_TYPE_SESSION, NULL, &error);
|
test->service = gsecret_service_get_sync (GSECRET_SERVICE_NONE, NULL, &error);
|
||||||
g_assert_no_error (error);
|
g_assert_no_error (error);
|
||||||
|
|
||||||
test->service = _gsecret_service_bare_instance (test->connection, NULL);
|
|
||||||
}
|
}
|
||||||
|
|
||||||
static void
|
static void
|
||||||
teardown (Test *test,
|
teardown (Test *test,
|
||||||
gconstpointer unused)
|
gconstpointer unused)
|
||||||
{
|
{
|
||||||
GError *error = NULL;
|
|
||||||
|
|
||||||
g_object_unref (test->service);
|
g_object_unref (test->service);
|
||||||
egg_assert_not_object (test->service);
|
egg_assert_not_object (test->service);
|
||||||
|
|
||||||
mock_service_stop ();
|
mock_service_stop ();
|
||||||
|
|
||||||
g_dbus_connection_flush_sync (test->connection, NULL, &error);
|
|
||||||
g_assert_no_error (error);
|
|
||||||
g_object_unref (test->connection);
|
|
||||||
}
|
}
|
||||||
|
|
||||||
static void
|
static void
|
||||||
@ -87,7 +78,6 @@ on_notify_stop (GObject *obj,
|
|||||||
g_assert (*sigs > 0);
|
g_assert (*sigs > 0);
|
||||||
if (--(*sigs) == 0)
|
if (--(*sigs) == 0)
|
||||||
egg_test_wait_stop ();
|
egg_test_wait_stop ();
|
||||||
g_printerr ("sigs: %u\n", *sigs);
|
|
||||||
}
|
}
|
||||||
|
|
||||||
static void
|
static void
|
||||||
@ -520,15 +510,14 @@ main (int argc, char **argv)
|
|||||||
g_test_add ("/item/properties", Test, "mock-service-normal.py", setup, test_properties, teardown);
|
g_test_add ("/item/properties", Test, "mock-service-normal.py", setup, test_properties, teardown);
|
||||||
g_test_add ("/item/set-label-sync", Test, "mock-service-normal.py", setup, test_set_label_sync, teardown);
|
g_test_add ("/item/set-label-sync", Test, "mock-service-normal.py", setup, test_set_label_sync, teardown);
|
||||||
g_test_add ("/item/set-label-async", Test, "mock-service-normal.py", setup, test_set_label_async, teardown);
|
g_test_add ("/item/set-label-async", Test, "mock-service-normal.py", setup, test_set_label_async, teardown);
|
||||||
|
g_test_add ("/item/set-label-prop", Test, "mock-service-normal.py", setup, test_set_label_prop, teardown);
|
||||||
g_test_add ("/item/set-attributes-sync", Test, "mock-service-normal.py", setup, test_set_attributes_sync, teardown);
|
g_test_add ("/item/set-attributes-sync", Test, "mock-service-normal.py", setup, test_set_attributes_sync, teardown);
|
||||||
g_test_add ("/item/set-attributes-async", Test, "mock-service-normal.py", setup, test_set_attributes_async, teardown);
|
g_test_add ("/item/set-attributes-async", Test, "mock-service-normal.py", setup, test_set_attributes_async, teardown);
|
||||||
|
g_test_add ("/item/set-attributes-prop", Test, "mock-service-normal.py", setup, test_set_attributes_prop, teardown);
|
||||||
g_test_add ("/item/get-secret-sync", Test, "mock-service-normal.py", setup, test_get_secret_sync, teardown);
|
g_test_add ("/item/get-secret-sync", Test, "mock-service-normal.py", setup, test_get_secret_sync, teardown);
|
||||||
g_test_add ("/item/get-secret-async", Test, "mock-service-normal.py", setup, test_get_secret_async, teardown);
|
g_test_add ("/item/get-secret-async", Test, "mock-service-normal.py", setup, test_get_secret_async, teardown);
|
||||||
g_test_add ("/item/delete-sync", Test, "mock-service-normal.py", setup, test_delete_sync, teardown);
|
g_test_add ("/item/delete-sync", Test, "mock-service-normal.py", setup, test_delete_sync, teardown);
|
||||||
g_test_add ("/item/delete-async", Test, "mock-service-normal.py", setup, test_delete_async, teardown);
|
g_test_add ("/item/delete-async", Test, "mock-service-normal.py", setup, test_delete_async, teardown);
|
||||||
|
|
||||||
g_test_add ("/item/set-attributes-prop", Test, "mock-service-normal.py", setup, test_set_attributes_prop, teardown);
|
|
||||||
g_test_add ("/item/set-label-prop", Test, "mock-service-normal.py", setup, test_set_label_prop, teardown);
|
|
||||||
|
|
||||||
return egg_tests_run_with_loop ();
|
return egg_tests_run_with_loop ();
|
||||||
}
|
}
|
||||||
|
@ -30,7 +30,6 @@
|
|||||||
#include <stdlib.h>
|
#include <stdlib.h>
|
||||||
|
|
||||||
typedef struct {
|
typedef struct {
|
||||||
GDBusConnection *connection;
|
|
||||||
GSecretService *service;
|
GSecretService *service;
|
||||||
} Test;
|
} Test;
|
||||||
|
|
||||||
@ -44,26 +43,18 @@ setup (Test *test,
|
|||||||
mock_service_start (mock_script, &error);
|
mock_service_start (mock_script, &error);
|
||||||
g_assert_no_error (error);
|
g_assert_no_error (error);
|
||||||
|
|
||||||
test->connection = g_bus_get_sync (G_BUS_TYPE_SESSION, NULL, &error);
|
test->service = gsecret_service_get_sync (GSECRET_SERVICE_NONE, NULL, &error);
|
||||||
g_assert_no_error (error);
|
g_assert_no_error (error);
|
||||||
|
|
||||||
test->service = _gsecret_service_bare_instance (test->connection, NULL);
|
|
||||||
}
|
}
|
||||||
|
|
||||||
static void
|
static void
|
||||||
teardown (Test *test,
|
teardown (Test *test,
|
||||||
gconstpointer unused)
|
gconstpointer unused)
|
||||||
{
|
{
|
||||||
GError *error = NULL;
|
|
||||||
|
|
||||||
g_object_unref (test->service);
|
g_object_unref (test->service);
|
||||||
egg_assert_not_object (test->service);
|
egg_assert_not_object (test->service);
|
||||||
|
|
||||||
mock_service_stop ();
|
mock_service_stop ();
|
||||||
|
|
||||||
g_dbus_connection_flush_sync (test->connection, NULL, &error);
|
|
||||||
g_assert_no_error (error);
|
|
||||||
g_object_unref (test->connection);
|
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
|
@ -25,8 +25,6 @@
|
|||||||
#include <errno.h>
|
#include <errno.h>
|
||||||
#include <stdlib.h>
|
#include <stdlib.h>
|
||||||
|
|
||||||
static gchar *MOCK_NAME = "org.mock.Service";
|
|
||||||
|
|
||||||
static const GSecretSchema DELETE_SCHEMA = {
|
static const GSecretSchema DELETE_SCHEMA = {
|
||||||
"org.mock.schema.Delete",
|
"org.mock.schema.Delete",
|
||||||
{
|
{
|
||||||
@ -37,8 +35,6 @@ static const GSecretSchema DELETE_SCHEMA = {
|
|||||||
};
|
};
|
||||||
|
|
||||||
typedef struct {
|
typedef struct {
|
||||||
GPid pid;
|
|
||||||
GDBusConnection *connection;
|
|
||||||
GSecretService *service;
|
GSecretService *service;
|
||||||
} Test;
|
} Test;
|
||||||
|
|
||||||
@ -61,10 +57,8 @@ setup (Test *test,
|
|||||||
|
|
||||||
setup_mock (test, data);
|
setup_mock (test, data);
|
||||||
|
|
||||||
test->connection = g_bus_get_sync (G_BUS_TYPE_SESSION, NULL, &error);
|
test->service = gsecret_service_get_sync (GSECRET_SERVICE_NONE, NULL, &error);
|
||||||
g_assert_no_error (error);
|
g_assert_no_error (error);
|
||||||
|
|
||||||
test->service = _gsecret_service_bare_instance (test->connection, NULL);
|
|
||||||
}
|
}
|
||||||
|
|
||||||
static void
|
static void
|
||||||
@ -83,8 +77,6 @@ teardown (Test *test,
|
|||||||
g_object_unref (test->service);
|
g_object_unref (test->service);
|
||||||
egg_assert_not_object (test->service);
|
egg_assert_not_object (test->service);
|
||||||
|
|
||||||
g_clear_object (&test->connection);
|
|
||||||
|
|
||||||
teardown_mock (test, unused);
|
teardown_mock (test, unused);
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -107,15 +99,14 @@ test_instance (void)
|
|||||||
GSecretService *service2;
|
GSecretService *service2;
|
||||||
GSecretService *service3;
|
GSecretService *service3;
|
||||||
GError *error = NULL;
|
GError *error = NULL;
|
||||||
GDBusConnection *connection;
|
|
||||||
|
|
||||||
connection = g_bus_get_sync (G_BUS_TYPE_SESSION, NULL, &error);
|
|
||||||
g_assert_no_error (error);
|
|
||||||
|
|
||||||
/* Both these sohuld point to the same thing */
|
/* Both these sohuld point to the same thing */
|
||||||
|
|
||||||
service1 = _gsecret_service_bare_instance (connection, MOCK_NAME);
|
service1 = gsecret_service_get_sync (GSECRET_SERVICE_NONE, NULL, &error);
|
||||||
service2 = _gsecret_service_bare_instance (connection, MOCK_NAME);
|
g_assert_no_error (error);
|
||||||
|
|
||||||
|
service2 = gsecret_service_get_sync (GSECRET_SERVICE_NONE, NULL, &error);
|
||||||
|
g_assert_no_error (error);
|
||||||
|
|
||||||
g_assert (GSECRET_IS_SERVICE (service1));
|
g_assert (GSECRET_IS_SERVICE (service1));
|
||||||
g_assert (service1 == service2);
|
g_assert (service1 == service2);
|
||||||
@ -127,17 +118,16 @@ test_instance (void)
|
|||||||
egg_assert_not_object (service2);
|
egg_assert_not_object (service2);
|
||||||
|
|
||||||
/* Services were unreffed, so this should create a new one */
|
/* Services were unreffed, so this should create a new one */
|
||||||
service3 = _gsecret_service_bare_instance (connection, MOCK_NAME);
|
service3 = gsecret_service_get_sync (GSECRET_SERVICE_NONE, NULL, &error);
|
||||||
g_assert (GSECRET_IS_SERVICE (service3));
|
g_assert (GSECRET_IS_SERVICE (service3));
|
||||||
|
g_assert_no_error (error);
|
||||||
|
|
||||||
g_object_unref (service3);
|
g_object_unref (service3);
|
||||||
egg_assert_not_object (service3);
|
egg_assert_not_object (service3);
|
||||||
|
|
||||||
g_object_unref (connection);
|
|
||||||
}
|
}
|
||||||
|
|
||||||
static void
|
static void
|
||||||
test_connect_sync (Test *test,
|
test_connect_async (Test *test,
|
||||||
gconstpointer used)
|
gconstpointer used)
|
||||||
{
|
{
|
||||||
GError *error = NULL;
|
GError *error = NULL;
|
||||||
@ -146,12 +136,12 @@ test_connect_sync (Test *test,
|
|||||||
const gchar *path;
|
const gchar *path;
|
||||||
|
|
||||||
/* Passing false, not session */
|
/* Passing false, not session */
|
||||||
_gsecret_service_bare_connect (MOCK_NAME, FALSE, NULL, on_complete_get_result, &result);
|
gsecret_service_get (GSECRET_SERVICE_NONE, NULL, on_complete_get_result, &result);
|
||||||
g_assert (result == NULL);
|
g_assert (result == NULL);
|
||||||
|
|
||||||
egg_test_wait ();
|
egg_test_wait ();
|
||||||
|
|
||||||
service = _gsecret_service_bare_connect_finish (result, &error);
|
service = gsecret_service_get_finish (result, &error);
|
||||||
g_assert (GSECRET_IS_SERVICE (service));
|
g_assert (GSECRET_IS_SERVICE (service));
|
||||||
g_assert_no_error (error);
|
g_assert_no_error (error);
|
||||||
g_object_unref (result);
|
g_object_unref (result);
|
||||||
@ -164,7 +154,7 @@ test_connect_sync (Test *test,
|
|||||||
}
|
}
|
||||||
|
|
||||||
static void
|
static void
|
||||||
test_connect_ensure_sync (Test *test,
|
test_connect_ensure_async (Test *test,
|
||||||
gconstpointer used)
|
gconstpointer used)
|
||||||
{
|
{
|
||||||
GError *error = NULL;
|
GError *error = NULL;
|
||||||
@ -173,12 +163,12 @@ test_connect_ensure_sync (Test *test,
|
|||||||
const gchar *path;
|
const gchar *path;
|
||||||
|
|
||||||
/* Passing true, ensures session is established */
|
/* Passing true, ensures session is established */
|
||||||
_gsecret_service_bare_connect (MOCK_NAME, TRUE, NULL, on_complete_get_result, &result);
|
gsecret_service_get (GSECRET_SERVICE_OPEN_SESSION, NULL, on_complete_get_result, &result);
|
||||||
g_assert (result == NULL);
|
g_assert (result == NULL);
|
||||||
|
|
||||||
egg_test_wait ();
|
egg_test_wait ();
|
||||||
|
|
||||||
service = _gsecret_service_bare_connect_finish (result, &error);
|
service = gsecret_service_get_finish (result, &error);
|
||||||
g_assert_no_error (error);
|
g_assert_no_error (error);
|
||||||
g_assert (GSECRET_IS_SERVICE (service));
|
g_assert (GSECRET_IS_SERVICE (service));
|
||||||
g_object_unref (result);
|
g_object_unref (result);
|
||||||
@ -593,8 +583,8 @@ main (int argc, char **argv)
|
|||||||
|
|
||||||
g_test_add_func ("/service/instance", test_instance);
|
g_test_add_func ("/service/instance", test_instance);
|
||||||
|
|
||||||
g_test_add ("/service/connect-sync", Test, "mock-service-normal.py", setup_mock, test_connect_sync, teardown_mock);
|
g_test_add ("/service/connect-sync", Test, "mock-service-normal.py", setup_mock, test_connect_async, teardown_mock);
|
||||||
g_test_add ("/service/connect-ensure-sync", Test, "mock-service-normal.py", setup_mock, test_connect_ensure_sync, teardown_mock);
|
g_test_add ("/service/connect-ensure-sync", Test, "mock-service-normal.py", setup_mock, test_connect_ensure_async, teardown_mock);
|
||||||
|
|
||||||
g_test_add ("/service/search-for-paths", Test, "mock-service-normal.py", setup, test_search_paths, teardown);
|
g_test_add ("/service/search-for-paths", Test, "mock-service-normal.py", setup, test_search_paths, teardown);
|
||||||
g_test_add ("/service/search-for-paths-async", Test, "mock-service-normal.py", setup, test_search_paths_async, teardown);
|
g_test_add ("/service/search-for-paths-async", Test, "mock-service-normal.py", setup, test_search_paths_async, teardown);
|
||||||
|
@ -27,8 +27,6 @@
|
|||||||
#include <stdlib.h>
|
#include <stdlib.h>
|
||||||
|
|
||||||
typedef struct {
|
typedef struct {
|
||||||
GPid pid;
|
|
||||||
GDBusConnection *connection;
|
|
||||||
GSecretService *service;
|
GSecretService *service;
|
||||||
} Test;
|
} Test;
|
||||||
|
|
||||||
@ -42,26 +40,18 @@ setup (Test *test,
|
|||||||
mock_service_start (mock_script, &error);
|
mock_service_start (mock_script, &error);
|
||||||
g_assert_no_error (error);
|
g_assert_no_error (error);
|
||||||
|
|
||||||
test->connection = g_bus_get_sync (G_BUS_TYPE_SESSION, NULL, &error);
|
test->service = gsecret_service_get_sync (GSECRET_SERVICE_NONE, NULL, &error);
|
||||||
g_assert_no_error (error);
|
g_assert_no_error (error);
|
||||||
|
|
||||||
test->service = _gsecret_service_bare_instance (test->connection, NULL);
|
|
||||||
}
|
}
|
||||||
|
|
||||||
static void
|
static void
|
||||||
teardown (Test *test,
|
teardown (Test *test,
|
||||||
gconstpointer unused)
|
gconstpointer unused)
|
||||||
{
|
{
|
||||||
GError *error = NULL;
|
|
||||||
|
|
||||||
g_object_unref (test->service);
|
g_object_unref (test->service);
|
||||||
egg_assert_not_object (test->service);
|
egg_assert_not_object (test->service);
|
||||||
|
|
||||||
mock_service_stop ();
|
mock_service_stop ();
|
||||||
|
|
||||||
g_dbus_connection_flush_sync (test->connection, NULL, &error);
|
|
||||||
g_assert_no_error (error);
|
|
||||||
g_object_unref (test->connection);
|
|
||||||
}
|
}
|
||||||
|
|
||||||
static void
|
static void
|
||||||
|
@ -1,2 +1,2 @@
|
|||||||
library/gsecret-item.c
|
library/gsecret-item.c
|
||||||
library/gsecret-service.c
|
library/gsecret-session.c
|
||||||
|
Loading…
Reference in New Issue
Block a user