[glib/sandboxed-dbus-activation: 2/3] Add a wrapper for the AddFull document portal api
- From: Matthias Clasen <matthiasc src gnome org>
- To: commits-list gnome org
- Cc:
- Subject: [glib/sandboxed-dbus-activation: 2/3] Add a wrapper for the AddFull document portal api
- Date: Fri, 26 May 2017 17:17:37 +0000 (UTC)
commit 1e6d5e7d7a0256c6138c421d0c8096c2f7747d43
Author: Matthias Clasen <mclasen redhat com>
Date: Tue May 23 22:08:01 2017 -0400
Add a wrapper for the AddFull document portal api
This is a wrapper which takes a list of uris and rewrites
them by calling AddFull with the file:// uris.
gio/gdocumentportal.c | 115 +++++++++++++++++++++++++++++++++++++++++++++++++
gio/gdocumentportal.h | 4 ++
2 files changed, 119 insertions(+), 0 deletions(-)
---
diff --git a/gio/gdocumentportal.c b/gio/gdocumentportal.c
index 7522d0b..dacec6f 100644
--- a/gio/gdocumentportal.c
+++ b/gio/gdocumentportal.c
@@ -21,6 +21,7 @@
#include <sys/stat.h>
#include <fcntl.h>
#include <errno.h>
+#include <string.h>
#include "gdocumentportal.h"
#include "xdp-dbus.h"
@@ -159,3 +160,117 @@ g_document_portal_add_document (GFile *file,
return doc_uri;
}
+
+GList *
+g_document_portal_add_documents (GList *uris,
+ const char *app_id,
+ GError **error)
+{
+ int length;
+ GList *ruris = NULL;
+ gboolean *as_is;
+ GVariantBuilder builder;
+ GUnixFDList *fd_list = NULL;
+ GList *l;
+ int i, j;
+ const char *permissions[] = { "read", "write", NULL };
+ char **doc_ids = NULL;
+ GVariant *extra_out = NULL;
+
+ if (!init_document_portal ())
+ {
+ g_set_error (error, G_IO_ERROR, G_IO_ERROR_FAILED,
+ "Document portal is not available");
+ return NULL;
+ }
+
+ length = g_list_length (uris);
+ as_is = g_new0 (gboolean, length);
+
+ g_variant_builder_init (&builder, G_VARIANT_TYPE ("ah"));
+
+ fd_list = g_unix_fd_list_new ();
+ for (l = uris, i = 0; l; l = l->next, i++)
+ {
+ const char *uri = l->data;
+ int idx = -1;
+ g_autofree char *path = NULL;
+
+ path = g_filename_from_uri (uri, NULL, NULL);
+ if (path != NULL)
+ {
+ int fd;
+
+ fd = open (path, O_CLOEXEC | O_PATH);
+ if (fd >= 0)
+ {
+ idx = g_unix_fd_list_append (fd_list, fd, NULL);
+ close (fd);
+ }
+ }
+
+ if (idx != -1)
+ g_variant_builder_add (&builder, "h", idx);
+ else
+ as_is[i] = TRUE;
+ }
+
+ g_variant_builder_add (&builder, "u", 1 << 2); /* as-needed-by-app */
+ g_variant_builder_add (&builder, "s", app_id);
+ g_variant_builder_add (&builder, "^as", permissions);
+
+ if (g_unix_fd_list_get_length (fd_list) > 0)
+ {
+ if (!gxdp_documents_call_add_full_sync (documents,
+ g_variant_builder_end (&builder),
+ 1 << 2, // as-needed-by-app
+ app_id,
+ permissions,
+ fd_list,
+ &doc_ids,
+ &extra_out,
+ NULL,
+ NULL,
+ error))
+ goto out;
+
+ for (l = uris, i = 0, j = 0; l; l = l->next, i++)
+ {
+ char *uri = l->data;
+ char *ruri;
+
+ if (as_is[i]) /* use as-is, not a file uri */
+ {
+ ruri = g_strdup (uri);
+ }
+ else if (strcmp (doc_ids[j], "") == 0) /* not rewritten */
+ {
+ ruri = g_strdup (uri);
+ j++;
+ }
+ else
+ {
+ char *basename = g_path_get_basename (uri + strlen ("file:"));
+ char *doc_path = g_build_filename (documents_mountpoint, doc_ids[j], basename, NULL);
+ ruri = g_strconcat ("file:", doc_path, NULL);
+ g_free (basename);
+ g_free (doc_path);
+ j++;
+ }
+
+ ruris = g_list_append (ruris, ruri);
+ }
+ }
+ else
+ {
+ ruris = g_list_copy_deep (uris, (GCopyFunc)g_strdup, NULL);
+ }
+
+out:
+ g_clear_object (&fd_list);
+ g_clear_pointer (&extra_out, g_variant_unref);
+ g_clear_pointer (&doc_ids, g_strfreev);
+ g_free (as_is);
+
+ return ruris;
+}
diff --git a/gio/gdocumentportal.h b/gio/gdocumentportal.h
index 720768c..9d52490 100644
--- a/gio/gdocumentportal.h
+++ b/gio/gdocumentportal.h
@@ -26,6 +26,10 @@ G_BEGIN_DECLS
char * g_document_portal_add_document (GFile *file,
GError **error);
+GList * g_document_portal_add_documents (GList *uris,
+ const char *app_id,
+ GError **error);
+
G_END_DECLS
#endif
[
Date Prev][
Date Next] [
Thread Prev][
Thread Next]
[
Thread Index]
[
Date Index]
[
Author Index]