[ostree/wip/archive-zlib: 1/2] pull: Check the remote repo type
- From: Colin Walters <walters src gnome org>
- To: commits-list gnome org
- Cc:
- Subject: [ostree/wip/archive-zlib: 1/2] pull: Check the remote repo type
- Date: Sat, 15 Sep 2012 18:42:59 +0000 (UTC)
commit 59ddbcc500e0cc36a59236294cd12920aac27c64
Author: Colin Walters <walters verbum org>
Date: Sat Sep 15 12:34:04 2012 -0400
pull: Check the remote repo type
We can only pull from archive repositories right now. This will also
be useful for adding compressed archives later.
src/libostree/ostree-repo.c | 37 ++++++++++++++++++++++--------
src/libostree/ostree-repo.h | 4 +++
src/ostree/ostree-pull.c | 53 +++++++++++++++++++++++++++++++++++++++++++
3 files changed, 84 insertions(+), 10 deletions(-)
---
diff --git a/src/libostree/ostree-repo.c b/src/libostree/ostree-repo.c
index 15843da..9bd44f1 100644
--- a/src/libostree/ostree-repo.c
+++ b/src/libostree/ostree-repo.c
@@ -587,6 +587,31 @@ ostree_repo_write_config (OstreeRepo *self,
}
gboolean
+ostree_repo_mode_from_string (const char *mode,
+ OstreeRepoMode *out_mode,
+ GError **error)
+{
+ gboolean ret = FALSE;
+ OstreeRepoMode ret_mode;
+
+ if (strcmp (mode, "bare") == 0)
+ ret_mode = OSTREE_REPO_MODE_BARE;
+ else if (strcmp (mode, "archive") == 0)
+ ret_mode = OSTREE_REPO_MODE_ARCHIVE;
+ else
+ {
+ g_set_error (error, G_IO_ERROR, G_IO_ERROR_FAILED,
+ "Invalid mode '%s' in repository configuration", mode);
+ goto out;
+ }
+
+ ret = TRUE;
+ *out_mode = ret_mode;
+ out:
+ return ret;
+}
+
+gboolean
ostree_repo_check (OstreeRepo *self, GError **error)
{
gboolean ret = FALSE;
@@ -641,16 +666,8 @@ ostree_repo_check (OstreeRepo *self, GError **error)
"bare", &mode, error))
goto out;
- if (strcmp (mode, "bare") == 0)
- self->mode = OSTREE_REPO_MODE_BARE;
- else if (strcmp (mode, "archive") == 0)
- self->mode = OSTREE_REPO_MODE_ARCHIVE;
- else
- {
- g_set_error (error, G_IO_ERROR, G_IO_ERROR_FAILED,
- "Invalid mode '%s' in repository configuration", mode);
- goto out;
- }
+ if (!ostree_repo_mode_from_string (mode, &self->mode, error))
+ goto out;
}
if (!ot_keyfile_get_value_with_default (self->config, "core", "parent",
diff --git a/src/libostree/ostree-repo.h b/src/libostree/ostree-repo.h
index 7edc635..5f5e0df 100644
--- a/src/libostree/ostree-repo.h
+++ b/src/libostree/ostree-repo.h
@@ -47,6 +47,10 @@ typedef enum {
OSTREE_REPO_MODE_ARCHIVE
} OstreeRepoMode;
+gboolean ostree_repo_mode_from_string (const char *mode,
+ OstreeRepoMode *out_mode,
+ GError **error);
+
OstreeRepoMode ostree_repo_get_mode (OstreeRepo *self);
GFile * ostree_repo_get_tmpdir (OstreeRepo *self);
diff --git a/src/ostree/ostree-pull.c b/src/ostree/ostree-pull.c
index 0115b8b..f1804da 100644
--- a/src/ostree/ostree-pull.c
+++ b/src/ostree/ostree-pull.c
@@ -1460,6 +1460,35 @@ repo_get_string_key_inherit (OstreeRepo *repo,
}
static gboolean
+load_remote_repo_config (OtPullData *pull_data,
+ GKeyFile **out_keyfile,
+ GCancellable *cancellable,
+ GError **error)
+{
+ gboolean ret = FALSE;
+ ot_lfree char *contents = NULL;
+ GKeyFile *ret_keyfile = NULL;
+ SoupURI *target_uri = NULL;
+
+ target_uri = suburi_new (pull_data->base_uri, "config", NULL);
+
+ if (!fetch_uri_contents_utf8 (pull_data, target_uri, &contents,
+ cancellable, error))
+ goto out;
+
+ ret_keyfile = g_key_file_new ();
+ if (!g_key_file_load_from_data (ret_keyfile, contents, strlen (contents),
+ 0, error))
+ goto out;
+
+ ret = TRUE;
+ ot_transfer_out_value (out_keyfile, &ret_keyfile);
+ out:
+ g_clear_pointer (&ret_keyfile, (GDestroyNotify) g_key_file_unref);
+ return ret;
+}
+
+static gboolean
ostree_builtin_pull (int argc, char **argv, GFile *repo_path, GError **error)
{
GOptionContext *context;
@@ -1468,6 +1497,7 @@ ostree_builtin_pull (int argc, char **argv, GFile *repo_path, GError **error)
gpointer key, value;
int i;
GCancellable *cancellable = NULL;
+ OstreeRepoMode remote_repo_mode;
ot_lfree char *remote_key = NULL;
ot_lobj OstreeRepo *repo = NULL;
ot_lfree char *path = NULL;
@@ -1477,10 +1507,12 @@ ostree_builtin_pull (int argc, char **argv, GFile *repo_path, GError **error)
ot_lhash GHashTable *updated_refs = NULL;
ot_lhash GHashTable *commits_to_fetch = NULL;
ot_lfree char *branch_rev = NULL;
+ ot_lfree char *remote_mode_str = NULL;
OtPullData pull_data_real;
OtPullData *pull_data = &pull_data_real;
SoupURI *summary_uri = NULL;
GKeyFile *config = NULL;
+ GKeyFile *remote_config = NULL;
char **configured_branches = NULL;
guint64 bytes_transferred;
@@ -1526,6 +1558,26 @@ ostree_builtin_pull (int argc, char **argv, GFile *repo_path, GError **error)
goto out;
}
+ if (!load_remote_repo_config (pull_data, &remote_config, cancellable, error))
+ goto out;
+
+ if (!ot_keyfile_get_value_with_default (remote_config, "core", "mode", "bare",
+ &remote_mode_str, error))
+ goto out;
+
+ if (!ostree_repo_mode_from_string (remote_mode_str, &remote_repo_mode, error))
+ goto out;
+
+ switch (remote_repo_mode)
+ {
+ case OSTREE_REPO_MODE_ARCHIVE:
+ break;
+ default:
+ g_set_error (error, G_IO_ERROR, G_IO_ERROR_FAILED,
+ "Can't pull from archives with mode \"%s\"",
+ remote_mode_str);
+ }
+
requested_refs_to_fetch = g_hash_table_new_full (g_str_hash, g_str_equal, g_free, g_free);
updated_refs = g_hash_table_new_full (g_str_hash, g_str_equal, g_free, g_free);
commits_to_fetch = g_hash_table_new_full (g_str_hash, g_str_equal, g_free, NULL);
@@ -1701,6 +1753,7 @@ ostree_builtin_pull (int argc, char **argv, GFile *repo_path, GError **error)
g_clear_pointer (&pull_data->file_checksums_to_fetch, (GDestroyNotify) g_hash_table_unref);
g_clear_pointer (&pull_data->cached_meta_pack_indexes, (GDestroyNotify) g_ptr_array_unref);
g_clear_pointer (&pull_data->cached_data_pack_indexes, (GDestroyNotify) g_ptr_array_unref);
+ g_clear_pointer (&remote_config, (GDestroyNotify) g_key_file_unref);
if (summary_uri)
soup_uri_free (summary_uri);
return ret;
[
Date Prev][
Date Next] [
Thread Prev][
Thread Next]
[
Thread Index]
[
Date Index]
[
Author Index]