forked from Mirrors/flatpak-builder
lib: Use the new remote helpers
parent
4cdec26264
commit
2f6fc54897
|
@ -251,10 +251,8 @@ xdg_app_installation_list_installed_refs (XdgAppInstallation *self,
|
||||||
return NULL;
|
return NULL;
|
||||||
|
|
||||||
for (i = 0; raw_refs[i] != NULL; i++)
|
for (i = 0; raw_refs[i] != NULL; i++)
|
||||||
{
|
g_ptr_array_add (refs,
|
||||||
g_ptr_array_add (refs,
|
get_ref (self, raw_refs[i], cancellable));
|
||||||
get_ref (self, raw_refs[i], cancellable));
|
|
||||||
}
|
|
||||||
|
|
||||||
g_ptr_array_add (refs, NULL);
|
g_ptr_array_add (refs, NULL);
|
||||||
return (XdgAppInstalledRef **)g_ptr_array_free (g_steal_pointer (&refs), FALSE);
|
return (XdgAppInstalledRef **)g_ptr_array_free (g_steal_pointer (&refs), FALSE);
|
||||||
|
@ -268,24 +266,15 @@ xdg_app_installation_list_remotes (XdgAppInstallation *self,
|
||||||
XdgAppInstallationPrivate *priv = xdg_app_installation_get_instance_private (self);
|
XdgAppInstallationPrivate *priv = xdg_app_installation_get_instance_private (self);
|
||||||
g_auto(GStrv) remote_names = NULL;
|
g_auto(GStrv) remote_names = NULL;
|
||||||
g_autoptr(GPtrArray) remotes = g_ptr_array_new_with_free_func (g_object_unref);
|
g_autoptr(GPtrArray) remotes = g_ptr_array_new_with_free_func (g_object_unref);
|
||||||
guint n_remotes;
|
|
||||||
OstreeRepo *repo;
|
|
||||||
int i;
|
int i;
|
||||||
|
|
||||||
if (!xdg_app_dir_ensure_repo (priv->dir, cancellable, error))
|
remote_names = xdg_app_dir_list_remotes (priv->dir, cancellable, error);
|
||||||
return FALSE;
|
if (remote_names == NULL)
|
||||||
|
return NULL;
|
||||||
|
|
||||||
repo = xdg_app_dir_get_repo (priv->dir);
|
for (i = 0; remote_names[i] != NULL; i++)
|
||||||
remote_names = ostree_repo_remote_list (repo, &n_remotes);
|
g_ptr_array_add (remotes,
|
||||||
|
xdg_app_remote_new (priv->dir, remote_names[i]));
|
||||||
if (remote_names)
|
|
||||||
{
|
|
||||||
for (i = 0; remote_names[i] != NULL; i++)
|
|
||||||
{
|
|
||||||
g_ptr_array_add (remotes,
|
|
||||||
xdg_app_remote_new (repo, remote_names[i]));
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
g_ptr_array_add (remotes, NULL);
|
g_ptr_array_add (remotes, NULL);
|
||||||
return (XdgAppRemote **)g_ptr_array_free (g_steal_pointer (&remotes), FALSE);
|
return (XdgAppRemote **)g_ptr_array_free (g_steal_pointer (&remotes), FALSE);
|
||||||
|
|
|
@ -26,8 +26,9 @@
|
||||||
#define __XDG_APP_REMOTE_PRIVATE_H__
|
#define __XDG_APP_REMOTE_PRIVATE_H__
|
||||||
|
|
||||||
#include <xdg-app-remote.h>
|
#include <xdg-app-remote.h>
|
||||||
|
#include <xdg-app-dir.h>
|
||||||
#include <ostree.h>
|
#include <ostree.h>
|
||||||
|
|
||||||
XdgAppRemote *xdg_app_remote_new (OstreeRepo *repo, const char *name);
|
XdgAppRemote *xdg_app_remote_new (XdgAppDir *dir, const char *name);
|
||||||
|
|
||||||
#endif /* __XDG_APP_REMOTE_PRIVATE_H__ */
|
#endif /* __XDG_APP_REMOTE_PRIVATE_H__ */
|
||||||
|
|
|
@ -33,7 +33,7 @@ struct _XdgAppRemotePrivate
|
||||||
char *name;
|
char *name;
|
||||||
char *url;
|
char *url;
|
||||||
char *title;
|
char *title;
|
||||||
OstreeRepo *repo;
|
XdgAppDir *dir;
|
||||||
};
|
};
|
||||||
|
|
||||||
G_DEFINE_TYPE_WITH_PRIVATE (XdgAppRemote, xdg_app_remote, G_TYPE_OBJECT)
|
G_DEFINE_TYPE_WITH_PRIVATE (XdgAppRemote, xdg_app_remote, G_TYPE_OBJECT)
|
||||||
|
@ -53,8 +53,8 @@ xdg_app_remote_finalize (GObject *object)
|
||||||
g_free (priv->name);
|
g_free (priv->name);
|
||||||
g_free (priv->url);
|
g_free (priv->url);
|
||||||
g_free (priv->title);
|
g_free (priv->title);
|
||||||
g_object_unref (priv->repo);
|
g_object_unref (priv->dir);
|
||||||
|
|
||||||
G_OBJECT_CLASS (xdg_app_remote_parent_class)->finalize (object);
|
G_OBJECT_CLASS (xdg_app_remote_parent_class)->finalize (object);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -136,9 +136,10 @@ const char *
|
||||||
xdg_app_remote_get_url (XdgAppRemote *self)
|
xdg_app_remote_get_url (XdgAppRemote *self)
|
||||||
{
|
{
|
||||||
XdgAppRemotePrivate *priv = xdg_app_remote_get_instance_private (self);
|
XdgAppRemotePrivate *priv = xdg_app_remote_get_instance_private (self);
|
||||||
|
OstreeRepo *repo = xdg_app_dir_get_repo (priv->dir);
|
||||||
|
|
||||||
if (priv->url == NULL)
|
if (priv->url == NULL)
|
||||||
ostree_repo_remote_get_url (priv->repo, priv->name, &priv->url, NULL);
|
ostree_repo_remote_get_url (repo, priv->name, &priv->url, NULL);
|
||||||
|
|
||||||
return priv->url;
|
return priv->url;
|
||||||
}
|
}
|
||||||
|
@ -147,14 +148,9 @@ const char *
|
||||||
xdg_app_remote_get_title (XdgAppRemote *self)
|
xdg_app_remote_get_title (XdgAppRemote *self)
|
||||||
{
|
{
|
||||||
XdgAppRemotePrivate *priv = xdg_app_remote_get_instance_private (self);
|
XdgAppRemotePrivate *priv = xdg_app_remote_get_instance_private (self);
|
||||||
GKeyFile *config;
|
|
||||||
|
|
||||||
if (priv->title == NULL)
|
if (priv->title == NULL)
|
||||||
{
|
priv->title = xdg_app_dir_get_remote_title (priv->dir, priv->name);
|
||||||
g_autofree char *group = g_strdup_printf ("remote \"%s\"", priv->name);
|
|
||||||
config = ostree_repo_get_config (priv->repo);
|
|
||||||
priv->title = g_key_file_get_string (config, group, "xa.title", NULL);
|
|
||||||
}
|
|
||||||
|
|
||||||
return priv->title ? priv->title : priv->name;
|
return priv->title ? priv->title : priv->name;
|
||||||
}
|
}
|
||||||
|
@ -163,9 +159,10 @@ gboolean
|
||||||
xdg_app_remote_get_gpg_verify (XdgAppRemote *self)
|
xdg_app_remote_get_gpg_verify (XdgAppRemote *self)
|
||||||
{
|
{
|
||||||
XdgAppRemotePrivate *priv = xdg_app_remote_get_instance_private (self);
|
XdgAppRemotePrivate *priv = xdg_app_remote_get_instance_private (self);
|
||||||
|
OstreeRepo *repo = xdg_app_dir_get_repo (priv->dir);
|
||||||
gboolean res;
|
gboolean res;
|
||||||
|
|
||||||
if (ostree_repo_remote_get_gpg_verify (priv->repo, priv->name, &res, NULL))
|
if (ostree_repo_remote_get_gpg_verify (repo, priv->name, &res, NULL))
|
||||||
return res;
|
return res;
|
||||||
|
|
||||||
return FALSE;
|
return FALSE;
|
||||||
|
@ -198,30 +195,28 @@ xdg_app_remote_list_refs (XdgAppRemote *self,
|
||||||
GCancellable *cancellable,
|
GCancellable *cancellable,
|
||||||
GError **error)
|
GError **error)
|
||||||
{
|
{
|
||||||
|
XdgAppRemotePrivate *priv = xdg_app_remote_get_instance_private (self);
|
||||||
g_autoptr(GPtrArray) refs = g_ptr_array_new_with_free_func (g_object_unref);
|
g_autoptr(GPtrArray) refs = g_ptr_array_new_with_free_func (g_object_unref);
|
||||||
g_autoptr(GHashTable) ht = NULL;
|
g_autoptr(GHashTable) ht = NULL;
|
||||||
const char *url;
|
|
||||||
g_autofree char *title = NULL;
|
|
||||||
GHashTableIter iter;
|
GHashTableIter iter;
|
||||||
gpointer key;
|
gpointer key;
|
||||||
gpointer value;
|
gpointer value;
|
||||||
|
|
||||||
url = xdg_app_remote_get_url (self);
|
if (!xdg_app_dir_list_remote_refs (priv->dir,
|
||||||
g_print ("url: %s\n", url);
|
priv->name,
|
||||||
if (url)
|
&ht,
|
||||||
|
cancellable,
|
||||||
|
error))
|
||||||
|
return NULL;
|
||||||
|
|
||||||
|
g_hash_table_iter_init (&iter, ht);
|
||||||
|
while (g_hash_table_iter_next (&iter, &key, &value))
|
||||||
{
|
{
|
||||||
if (!ostree_repo_load_summary (url, &ht, &title, cancellable, error))
|
const char *refspec = key;
|
||||||
return FALSE;
|
const char *checksum = value;
|
||||||
|
|
||||||
g_hash_table_iter_init (&iter, ht);
|
g_ptr_array_add (refs,
|
||||||
while (g_hash_table_iter_next (&iter, &key, &value))
|
get_ref (self, refspec, checksum));
|
||||||
{
|
|
||||||
const char *refspec = key;
|
|
||||||
const char *checksum = value;
|
|
||||||
|
|
||||||
g_ptr_array_add (refs,
|
|
||||||
get_ref (self, refspec, checksum));
|
|
||||||
}
|
|
||||||
}
|
}
|
||||||
|
|
||||||
g_ptr_array_add (refs, NULL);
|
g_ptr_array_add (refs, NULL);
|
||||||
|
@ -230,16 +225,16 @@ xdg_app_remote_list_refs (XdgAppRemote *self,
|
||||||
|
|
||||||
|
|
||||||
XdgAppRemote *
|
XdgAppRemote *
|
||||||
xdg_app_remote_new (OstreeRepo *repo,
|
xdg_app_remote_new (XdgAppDir *dir,
|
||||||
const char *name)
|
const char *name)
|
||||||
{
|
{
|
||||||
XdgAppRemotePrivate *priv;
|
XdgAppRemotePrivate *priv;
|
||||||
XdgAppRemote *self = g_object_new (XDG_APP_TYPE_REMOTE,
|
XdgAppRemote *self = g_object_new (XDG_APP_TYPE_REMOTE,
|
||||||
"name", name,
|
"name", name,
|
||||||
NULL);
|
NULL);
|
||||||
|
|
||||||
priv = xdg_app_remote_get_instance_private (self);
|
priv = xdg_app_remote_get_instance_private (self);
|
||||||
priv->repo = g_object_ref (repo);
|
priv->dir = g_object_ref (dir);
|
||||||
|
|
||||||
return self;
|
return self;
|
||||||
}
|
}
|
||||||
|
|
Loading…
Reference in New Issue