mirror of
https://gitlab.gnome.org/GNOME/libsecret.git
synced 2025-01-11 14:38:51 +00:00
secret-prompt: Use string window ids
This is more portable and exposes what's actually in the Secret Service API. This change was made before going stable with the prompting functions.
This commit is contained in:
parent
d743d4dbcc
commit
71e2791ea3
@ -125,7 +125,7 @@ _secret_prompt_instance (SecretService *service,
|
|||||||
/**
|
/**
|
||||||
* secret_prompt_run:
|
* secret_prompt_run:
|
||||||
* @self: a prompt
|
* @self: a prompt
|
||||||
* @window_id: XWindow id for parent window to be transient for
|
* @window_id: (allow-none): string form of XWindow id for parent window to be transient for
|
||||||
* @cancellable: optional cancellation object
|
* @cancellable: optional cancellation object
|
||||||
* @return_type: the variant type of the prompt result
|
* @return_type: the variant type of the prompt result
|
||||||
* @error: location to place an error on failure
|
* @error: location to place an error on failure
|
||||||
@ -135,10 +135,11 @@ _secret_prompt_instance (SecretService *service,
|
|||||||
* action the prompt is completing, and is defined in the Secret Service DBus
|
* action the prompt is completing, and is defined in the Secret Service DBus
|
||||||
* API specification.
|
* API specification.
|
||||||
*
|
*
|
||||||
* If @window_id is non-zero then it is used as an XWindow id. The Secret
|
* If @window_id is non-null then it is used as an XWindow id on Linux. The API
|
||||||
* Service can make its prompt transient for the window with this id. In some
|
* expects this id to be converted to a string using the <literal>%d</literal>
|
||||||
* Secret Service implementations this is not possible, so the behavior
|
* printf format. The Secret Service can make its prompt transient for the window
|
||||||
* depending on this should degrade gracefully.
|
* with this id. In some Secret Service implementations this is not possible, so
|
||||||
|
* the behavior depending on this should degrade gracefully.
|
||||||
*
|
*
|
||||||
* This runs the dialog in a recursive mainloop. When run from a user interface
|
* This runs the dialog in a recursive mainloop. When run from a user interface
|
||||||
* thread, this means the user interface will remain responsive. Care should be
|
* thread, this means the user interface will remain responsive. Care should be
|
||||||
@ -149,7 +150,7 @@ _secret_prompt_instance (SecretService *service,
|
|||||||
*/
|
*/
|
||||||
GVariant *
|
GVariant *
|
||||||
secret_prompt_run (SecretPrompt *self,
|
secret_prompt_run (SecretPrompt *self,
|
||||||
gulong window_id,
|
const gchar *window_id,
|
||||||
GCancellable *cancellable,
|
GCancellable *cancellable,
|
||||||
const GVariantType *return_type,
|
const GVariantType *return_type,
|
||||||
GError **error)
|
GError **error)
|
||||||
@ -184,7 +185,7 @@ secret_prompt_run (SecretPrompt *self,
|
|||||||
/**
|
/**
|
||||||
* secret_prompt_perform_sync:
|
* secret_prompt_perform_sync:
|
||||||
* @self: a prompt
|
* @self: a prompt
|
||||||
* @window_id: XWindow id for parent window to be transient for
|
* @window_id: (allow-none): string form of XWindow id for parent window to be transient for
|
||||||
* @cancellable: optional cancellation object
|
* @cancellable: optional cancellation object
|
||||||
* @return_type: the variant type of the prompt result
|
* @return_type: the variant type of the prompt result
|
||||||
* @error: location to place an error on failure
|
* @error: location to place an error on failure
|
||||||
@ -194,10 +195,11 @@ secret_prompt_run (SecretPrompt *self,
|
|||||||
* action the prompt is completing, and is defined in the Secret Service DBus
|
* action the prompt is completing, and is defined in the Secret Service DBus
|
||||||
* API specification.
|
* API specification.
|
||||||
*
|
*
|
||||||
* If @window_id is non-zero then it is used as an XWindow id. The Secret
|
* If @window_id is non-null then it is used as an XWindow id on Linux. The API
|
||||||
* Service can make its prompt transient for the window with this id. In some
|
* expects this id to be converted to a string using the <literal>%d</literal>
|
||||||
* Secret Service implementations this is not possible, so the behavior
|
* printf format. The Secret Service can make its prompt transient for the window
|
||||||
* depending on this should degrade gracefully.
|
* with this id. In some Secret Service implementations this is not possible,
|
||||||
|
* so the behavior depending on this should degrade gracefully.
|
||||||
*
|
*
|
||||||
* This method may block indefinitely and should not be used in user interface
|
* This method may block indefinitely and should not be used in user interface
|
||||||
* threads.
|
* threads.
|
||||||
@ -206,7 +208,7 @@ secret_prompt_run (SecretPrompt *self,
|
|||||||
*/
|
*/
|
||||||
GVariant *
|
GVariant *
|
||||||
secret_prompt_perform_sync (SecretPrompt *self,
|
secret_prompt_perform_sync (SecretPrompt *self,
|
||||||
gulong window_id,
|
const gchar *window_id,
|
||||||
GCancellable *cancellable,
|
GCancellable *cancellable,
|
||||||
const GVariantType *return_type,
|
const GVariantType *return_type,
|
||||||
GError **error)
|
GError **error)
|
||||||
@ -411,7 +413,7 @@ on_prompt_cancelled (GCancellable *cancellable,
|
|||||||
/**
|
/**
|
||||||
* secret_prompt_perform:
|
* secret_prompt_perform:
|
||||||
* @self: a prompt
|
* @self: a prompt
|
||||||
* @window_id: XWindow id for parent window to be transient for
|
* @window_id: (allow-none): string form of XWindow id for parent window to be transient for
|
||||||
* @return_type: the variant type of the prompt result
|
* @return_type: the variant type of the prompt result
|
||||||
* @cancellable: optional cancellation object
|
* @cancellable: optional cancellation object
|
||||||
* @callback: called when the operation completes
|
* @callback: called when the operation completes
|
||||||
@ -420,16 +422,17 @@ on_prompt_cancelled (GCancellable *cancellable,
|
|||||||
* Runs a prompt and performs the prompting. Returns %TRUE if the prompt
|
* Runs a prompt and performs the prompting. Returns %TRUE if the prompt
|
||||||
* was completed and not dismissed.
|
* was completed and not dismissed.
|
||||||
*
|
*
|
||||||
* If @window_id is non-zero then it is used as an XWindow id. The Secret
|
* If @window_id is non-null then it is used as an XWindow id on Linux. The API
|
||||||
* Service can make its prompt transient for the window with this id. In some
|
* expects this id to be converted to a string using the <literal>%d</literal>
|
||||||
* Secret Service implementations this is not possible, so the behavior
|
* printf format. The Secret Service can make its prompt transient for the window
|
||||||
* depending on this should degrade gracefully.
|
* with this id. In some Secret Service implementations this is not possible, so
|
||||||
|
* the behavior depending on this should degrade gracefully.
|
||||||
*
|
*
|
||||||
* This method will return immediately and complete asynchronously.
|
* This method will return immediately and complete asynchronously.
|
||||||
*/
|
*/
|
||||||
void
|
void
|
||||||
secret_prompt_perform (SecretPrompt *self,
|
secret_prompt_perform (SecretPrompt *self,
|
||||||
gulong window_id,
|
const gchar *window_id,
|
||||||
const GVariantType *return_type,
|
const GVariantType *return_type,
|
||||||
GCancellable *cancellable,
|
GCancellable *cancellable,
|
||||||
GAsyncReadyCallback callback,
|
GAsyncReadyCallback callback,
|
||||||
@ -441,7 +444,6 @@ secret_prompt_perform (SecretPrompt *self,
|
|||||||
const gchar *object_path;
|
const gchar *object_path;
|
||||||
gboolean prompted;
|
gboolean prompted;
|
||||||
GDBusProxy *proxy;
|
GDBusProxy *proxy;
|
||||||
gchar *window;
|
|
||||||
|
|
||||||
g_return_if_fail (SECRET_IS_PROMPT (self));
|
g_return_if_fail (SECRET_IS_PROMPT (self));
|
||||||
g_return_if_fail (cancellable == NULL || G_IS_CANCELLABLE (cancellable));
|
g_return_if_fail (cancellable == NULL || G_IS_CANCELLABLE (cancellable));
|
||||||
@ -463,10 +465,8 @@ secret_prompt_perform (SecretPrompt *self,
|
|||||||
closure->return_type = return_type ? g_variant_type_copy (return_type) : NULL;
|
closure->return_type = return_type ? g_variant_type_copy (return_type) : NULL;
|
||||||
g_simple_async_result_set_op_res_gpointer (res, closure, perform_closure_free);
|
g_simple_async_result_set_op_res_gpointer (res, closure, perform_closure_free);
|
||||||
|
|
||||||
if (window_id == 0)
|
if (window_id == NULL)
|
||||||
window = g_strdup ("");
|
window_id = "";
|
||||||
else
|
|
||||||
window = g_strdup_printf ("%lu", window_id);
|
|
||||||
|
|
||||||
owner_name = g_dbus_proxy_get_name_owner (proxy);
|
owner_name = g_dbus_proxy_get_name_owner (proxy);
|
||||||
object_path = g_dbus_proxy_get_object_path (proxy);
|
object_path = g_dbus_proxy_get_object_path (proxy);
|
||||||
@ -492,11 +492,10 @@ secret_prompt_perform (SecretPrompt *self,
|
|||||||
res, NULL);
|
res, NULL);
|
||||||
}
|
}
|
||||||
|
|
||||||
g_dbus_proxy_call (proxy, "Prompt", g_variant_new ("(s)", window),
|
g_dbus_proxy_call (proxy, "Prompt", g_variant_new ("(s)", window_id),
|
||||||
G_DBUS_CALL_FLAGS_NO_AUTO_START, -1,
|
G_DBUS_CALL_FLAGS_NO_AUTO_START, -1,
|
||||||
closure->call_cancellable, on_prompt_prompted, g_object_ref (res));
|
closure->call_cancellable, on_prompt_prompted, g_object_ref (res));
|
||||||
|
|
||||||
g_free (window);
|
|
||||||
g_object_unref (res);
|
g_object_unref (res);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -53,19 +53,19 @@ struct _SecretPromptClass {
|
|||||||
GType secret_prompt_get_type (void) G_GNUC_CONST;
|
GType secret_prompt_get_type (void) G_GNUC_CONST;
|
||||||
|
|
||||||
GVariant * secret_prompt_run (SecretPrompt *self,
|
GVariant * secret_prompt_run (SecretPrompt *self,
|
||||||
gulong window_id,
|
const gchar *window_id,
|
||||||
GCancellable *cancellable,
|
GCancellable *cancellable,
|
||||||
const GVariantType *return_type,
|
const GVariantType *return_type,
|
||||||
GError **error);
|
GError **error);
|
||||||
|
|
||||||
GVariant * secret_prompt_perform_sync (SecretPrompt *self,
|
GVariant * secret_prompt_perform_sync (SecretPrompt *self,
|
||||||
gulong window_id,
|
const gchar *window_id,
|
||||||
GCancellable *cancellable,
|
GCancellable *cancellable,
|
||||||
const GVariantType *return_type,
|
const GVariantType *return_type,
|
||||||
GError **error);
|
GError **error);
|
||||||
|
|
||||||
void secret_prompt_perform (SecretPrompt *self,
|
void secret_prompt_perform (SecretPrompt *self,
|
||||||
gulong window_id,
|
const gchar *window_id,
|
||||||
const GVariantType *return_type,
|
const GVariantType *return_type,
|
||||||
GCancellable *cancellable,
|
GCancellable *cancellable,
|
||||||
GAsyncReadyCallback callback,
|
GAsyncReadyCallback callback,
|
||||||
|
@ -304,7 +304,7 @@ secret_service_real_prompt_sync (SecretService *self,
|
|||||||
const GVariantType *return_type,
|
const GVariantType *return_type,
|
||||||
GError **error)
|
GError **error)
|
||||||
{
|
{
|
||||||
return secret_prompt_perform_sync (prompt, 0, cancellable, return_type, error);
|
return secret_prompt_perform_sync (prompt, NULL, cancellable, return_type, error);
|
||||||
}
|
}
|
||||||
|
|
||||||
static void
|
static void
|
||||||
@ -1650,7 +1650,7 @@ secret_service_load_collections_sync (SecretService *self,
|
|||||||
*
|
*
|
||||||
* Override the #SecretServiceClass <literal>prompt_sync</literal> virtual method
|
* Override the #SecretServiceClass <literal>prompt_sync</literal> virtual method
|
||||||
* to change the behavior of the propmting. The default behavior is to simply
|
* to change the behavior of the propmting. The default behavior is to simply
|
||||||
* run secret_prompt_perform_sync() on the prompt.
|
* run secret_prompt_perform_sync() on the prompt with a %NULL <literal>window_id</literal>.
|
||||||
*
|
*
|
||||||
* Returns: (transfer full): %NULL if the prompt was dismissed or an error occurred,
|
* Returns: (transfer full): %NULL if the prompt was dismissed or an error occurred,
|
||||||
* a variant result if the prompt was successful
|
* a variant result if the prompt was successful
|
||||||
|
@ -94,7 +94,7 @@ test_perform_sync (Test *test,
|
|||||||
|
|
||||||
prompt = _secret_prompt_instance (test->service, "/org/freedesktop/secrets/prompts/simple");
|
prompt = _secret_prompt_instance (test->service, "/org/freedesktop/secrets/prompts/simple");
|
||||||
|
|
||||||
retval = secret_prompt_perform_sync (prompt, 0, NULL, NULL, &error);
|
retval = secret_prompt_perform_sync (prompt, NULL, NULL, NULL, &error);
|
||||||
g_assert_no_error (error);
|
g_assert_no_error (error);
|
||||||
g_assert (retval != NULL);
|
g_assert (retval != NULL);
|
||||||
g_variant_unref (retval);
|
g_variant_unref (retval);
|
||||||
@ -215,7 +215,7 @@ test_perform_fail (Test *test,
|
|||||||
prompt = _secret_prompt_instance (test->service, "/org/freedesktop/secrets/prompts/error");
|
prompt = _secret_prompt_instance (test->service, "/org/freedesktop/secrets/prompts/error");
|
||||||
g_object_add_weak_pointer (G_OBJECT (prompt), (gpointer *)&prompt);
|
g_object_add_weak_pointer (G_OBJECT (prompt), (gpointer *)&prompt);
|
||||||
|
|
||||||
retval = secret_prompt_perform_sync (prompt, 0, NULL, NULL, &error);
|
retval = secret_prompt_perform_sync (prompt, NULL, NULL, NULL, &error);
|
||||||
g_assert_error (error, G_DBUS_ERROR, G_DBUS_ERROR_NOT_SUPPORTED);
|
g_assert_error (error, G_DBUS_ERROR, G_DBUS_ERROR_NOT_SUPPORTED);
|
||||||
g_assert (retval == NULL);
|
g_assert (retval == NULL);
|
||||||
|
|
||||||
@ -234,7 +234,7 @@ test_perform_vanish (Test *test,
|
|||||||
prompt = _secret_prompt_instance (test->service, "/org/freedesktop/secrets/prompts/vanish");
|
prompt = _secret_prompt_instance (test->service, "/org/freedesktop/secrets/prompts/vanish");
|
||||||
g_object_add_weak_pointer (G_OBJECT (prompt), (gpointer *)&prompt);
|
g_object_add_weak_pointer (G_OBJECT (prompt), (gpointer *)&prompt);
|
||||||
|
|
||||||
retval = secret_prompt_perform_sync (prompt, 0, NULL, NULL, &error);
|
retval = secret_prompt_perform_sync (prompt, NULL, NULL, NULL, &error);
|
||||||
g_assert_no_error (error);
|
g_assert_no_error (error);
|
||||||
g_assert (retval == NULL);
|
g_assert (retval == NULL);
|
||||||
|
|
||||||
@ -274,7 +274,7 @@ test_prompt_window_id (Test *test,
|
|||||||
prompt = _secret_prompt_instance (test->service, "/org/freedesktop/secrets/prompts/window");
|
prompt = _secret_prompt_instance (test->service, "/org/freedesktop/secrets/prompts/window");
|
||||||
g_object_add_weak_pointer (G_OBJECT (prompt), (gpointer *)&prompt);
|
g_object_add_weak_pointer (G_OBJECT (prompt), (gpointer *)&prompt);
|
||||||
|
|
||||||
retval = secret_prompt_perform_sync (prompt, 555, NULL, G_VARIANT_TYPE_STRING, &error);
|
retval = secret_prompt_perform_sync (prompt, "555", NULL, G_VARIANT_TYPE_STRING, &error);
|
||||||
g_assert_no_error (error);
|
g_assert_no_error (error);
|
||||||
g_assert (retval != NULL);
|
g_assert (retval != NULL);
|
||||||
g_assert_cmpstr (g_variant_get_string (retval, NULL), ==, "555");
|
g_assert_cmpstr (g_variant_get_string (retval, NULL), ==, "555");
|
||||||
|
Loading…
Reference in New Issue
Block a user