core: Map metadata from repository as trusted

ot_util_variant_map() assumed untrusted; add a boolean, and use it for
the repository internals.
This commit is contained in:
Colin Walters 2012-05-14 15:49:49 -04:00
parent cf53ed5cef
commit f95090095e
8 changed files with 70 additions and 33 deletions

View File

@ -1803,6 +1803,7 @@ static gboolean
map_variant_file_check_header_string (GFile *path, map_variant_file_check_header_string (GFile *path,
const GVariantType *variant_type, const GVariantType *variant_type,
const char *expected_header, const char *expected_header,
gboolean trusted,
GVariant **out_variant, GVariant **out_variant,
GCancellable *cancellable, GCancellable *cancellable,
GError **error) GError **error)
@ -1811,7 +1812,7 @@ map_variant_file_check_header_string (GFile *path,
const char *header; const char *header;
ot_lvariant GVariant *ret_variant = NULL; ot_lvariant GVariant *ret_variant = NULL;
if (!ot_util_variant_map (path, variant_type, &ret_variant, error)) if (!ot_util_variant_map (path, variant_type, trusted, &ret_variant, error))
goto out; goto out;
g_variant_get_child (ret_variant, 0, "&s", &header); g_variant_get_child (ret_variant, 0, "&s", &header);
@ -1899,7 +1900,7 @@ list_pack_checksums_from_superindex_file (GFile *superindex_path,
GVariantIter *data_variant_iter = NULL; GVariantIter *data_variant_iter = NULL;
if (!ot_util_variant_map (superindex_path, OSTREE_PACK_SUPER_INDEX_VARIANT_FORMAT, if (!ot_util_variant_map (superindex_path, OSTREE_PACK_SUPER_INDEX_VARIANT_FORMAT,
&superindex_variant, error)) TRUE, &superindex_variant, error))
goto out; goto out;
g_variant_get (superindex_variant, "(&s@a{sv}a(ayay)a(ayay))", g_variant_get (superindex_variant, "(&s@a{sv}a(ayay)a(ayay))",
@ -2293,7 +2294,7 @@ ostree_repo_resync_cached_remote_pack_indexes (OstreeRepo *self,
ret_uncached_data_indexes = g_ptr_array_new_with_free_func (g_free); ret_uncached_data_indexes = g_ptr_array_new_with_free_func (g_free);
if (!ot_util_variant_map (superindex_path, OSTREE_PACK_SUPER_INDEX_VARIANT_FORMAT, if (!ot_util_variant_map (superindex_path, OSTREE_PACK_SUPER_INDEX_VARIANT_FORMAT,
&superindex_variant, error)) FALSE, &superindex_variant, error))
goto out; goto out;
if (!ostree_validate_structureof_pack_superindex (superindex_variant, error)) if (!ostree_validate_structureof_pack_superindex (superindex_variant, error))
@ -2438,7 +2439,7 @@ ostree_repo_map_cached_remote_pack_index (OstreeRepo *self,
cached_pack_path = get_pack_index_path (cache_dir, is_meta, pack_checksum); cached_pack_path = get_pack_index_path (cache_dir, is_meta, pack_checksum);
if (!ot_util_variant_map (cached_pack_path, OSTREE_PACK_INDEX_VARIANT_FORMAT, if (!ot_util_variant_map (cached_pack_path, OSTREE_PACK_INDEX_VARIANT_FORMAT,
&ret_variant, error)) FALSE, &ret_variant, error))
goto out; goto out;
ret = TRUE; ret = TRUE;
@ -2470,7 +2471,7 @@ ostree_repo_add_cached_remote_pack_index (OstreeRepo *self,
if (!map_variant_file_check_header_string (cached_path, if (!map_variant_file_check_header_string (cached_path,
OSTREE_PACK_INDEX_VARIANT_FORMAT, OSTREE_PACK_INDEX_VARIANT_FORMAT,
"OSTv0PACKINDEX", "OSTv0PACKINDEX",
&input_index_variant, FALSE, &input_index_variant,
cancellable, error)) cancellable, error))
goto out; goto out;
@ -3437,7 +3438,7 @@ ostree_repo_load_pack_index (OstreeRepo *self,
path = get_pack_index_path (priv->pack_dir, is_meta, pack_checksum); path = get_pack_index_path (priv->pack_dir, is_meta, pack_checksum);
if (!map_variant_file_check_header_string (path, if (!map_variant_file_check_header_string (path,
OSTREE_PACK_INDEX_VARIANT_FORMAT, OSTREE_PACK_INDEX_VARIANT_FORMAT,
"OSTv0PACKINDEX", "OSTv0PACKINDEX", TRUE,
&ret_variant, &ret_variant,
cancellable, error)) cancellable, error))
goto out; goto out;
@ -3539,7 +3540,7 @@ ostree_repo_load_file (OstreeRepo *self,
ot_lvariant GVariant *archive_meta = NULL; ot_lvariant GVariant *archive_meta = NULL;
if (!ot_util_variant_map (loose_path, OSTREE_FILE_HEADER_GVARIANT_FORMAT, if (!ot_util_variant_map (loose_path, OSTREE_FILE_HEADER_GVARIANT_FORMAT,
&archive_meta, error)) TRUE, &archive_meta, error))
goto out; goto out;
if (!ostree_file_header_parse (archive_meta, &ret_file_info, &ret_xattrs, if (!ostree_file_header_parse (archive_meta, &ret_file_info, &ret_xattrs,
@ -3826,21 +3827,13 @@ repo_find_object (OstreeRepo *self,
ot_lobj GFile *ret_stored_path = NULL; ot_lobj GFile *ret_stored_path = NULL;
ot_lfree char *ret_pack_checksum = NULL; ot_lfree char *ret_pack_checksum = NULL;
if (out_stored_path) /* Look up metadata in packs first, but content loose first. We
{ * want to find loose content since that's preferable for
object_path = ostree_repo_get_object_path (self, checksum, objtype); * hardlinking scenarios.
*
if (lstat (ot_gfile_get_path_cached (object_path), &stbuf) == 0) * Metadata is much more efficient packed.
{ */
ret_stored_path = object_path; if (OSTREE_OBJECT_TYPE_IS_META (objtype))
object_path = NULL;
}
else
{
g_clear_object (&object_path);
}
}
if (!ret_stored_path || lookup_all)
{ {
if (out_pack_checksum) if (out_pack_checksum)
{ {
@ -3849,6 +3842,47 @@ repo_find_object (OstreeRepo *self,
cancellable, error)) cancellable, error))
goto out; goto out;
} }
if (!ret_pack_checksum || lookup_all)
{
object_path = ostree_repo_get_object_path (self, checksum, objtype);
if (lstat (ot_gfile_get_path_cached (object_path), &stbuf) == 0)
{
ret_stored_path = object_path;
object_path = NULL;
}
else
{
g_clear_object (&object_path);
}
}
}
else
{
if (out_stored_path)
{
object_path = ostree_repo_get_object_path (self, checksum, objtype);
if (lstat (ot_gfile_get_path_cached (object_path), &stbuf) == 0)
{
ret_stored_path = object_path;
object_path = NULL;
}
else
{
g_clear_object (&object_path);
}
}
if (!ret_stored_path || lookup_all)
{
if (out_pack_checksum)
{
if (!find_object_in_packs (self, checksum, objtype,
&ret_pack_checksum, &ret_pack_offset,
cancellable, error))
goto out;
}
}
} }
ret = TRUE; ret = TRUE;
@ -3945,7 +3979,7 @@ ostree_repo_load_variant (OstreeRepo *self,
if (object_path != NULL) if (object_path != NULL)
{ {
if (!ot_util_variant_map (object_path, ostree_metadata_variant_type (objtype), if (!ot_util_variant_map (object_path, ostree_metadata_variant_type (objtype),
&ret_variant, error)) TRUE, &ret_variant, error))
goto out; goto out;
} }
else if (pack_checksum != NULL) else if (pack_checksum != NULL)

View File

@ -108,10 +108,11 @@ ot_util_variant_take_ref (GVariant *variant)
* Note the returned @out_variant is not floating. * Note the returned @out_variant is not floating.
*/ */
gboolean gboolean
ot_util_variant_map (GFile *src, ot_util_variant_map (GFile *src,
const GVariantType *type, const GVariantType *type,
GVariant **out_variant, gboolean trusted,
GError **error) GVariant **out_variant,
GError **error)
{ {
gboolean ret = FALSE; gboolean ret = FALSE;
const char *path = NULL; const char *path = NULL;
@ -126,7 +127,7 @@ ot_util_variant_map (GFile *src,
ret_variant = g_variant_new_from_data (type, ret_variant = g_variant_new_from_data (type,
g_mapped_file_get_contents (mfile), g_mapped_file_get_contents (mfile),
g_mapped_file_get_length (mfile), g_mapped_file_get_length (mfile),
FALSE, trusted,
(GDestroyNotify) g_mapped_file_unref, (GDestroyNotify) g_mapped_file_unref,
mfile); mfile);
mfile = NULL; mfile = NULL;

View File

@ -59,6 +59,7 @@ gboolean ot_util_variant_save (GFile *dest,
gboolean ot_util_variant_map (GFile *src, gboolean ot_util_variant_map (GFile *src,
const GVariantType *type, const GVariantType *type,
gboolean trusted,
GVariant **out_variant, GVariant **out_variant,
GError **error); GError **error);

View File

@ -1008,8 +1008,8 @@ fetch_content (OtPullData *pull_data,
cancellable, error)) cancellable, error))
goto out; goto out;
if (!ot_util_variant_map (temp_path, OSTREE_FILE_HEADER_GVARIANT_FORMAT, &file_meta, if (!ot_util_variant_map (temp_path, OSTREE_FILE_HEADER_GVARIANT_FORMAT, FALSE,
error)) &file_meta, error))
goto out; goto out;
if (!ostree_file_header_parse (file_meta, &file_info, &xattrs, error)) if (!ostree_file_header_parse (file_meta, &file_info, &xattrs, error))

View File

@ -263,7 +263,8 @@ ostree_builtin_commit (int argc, char **argv, GFile *repo_path, GError **error)
else if (metadata_bin_path) else if (metadata_bin_path)
{ {
metadata_f = ot_gfile_new_for_path (metadata_bin_path); metadata_f = ot_gfile_new_for_path (metadata_bin_path);
if (!ot_util_variant_map (metadata_f, G_VARIANT_TYPE ("a{sv}"), &metadata, error)) if (!ot_util_variant_map (metadata_f, G_VARIANT_TYPE ("a{sv}"), TRUE,
&metadata, error))
goto out; goto out;
} }
else else

View File

@ -68,7 +68,7 @@ fsck_one_pack_file (OtFsckData *data,
pack_index_path = g_file_resolve_relative_path (ostree_repo_get_path (data->repo), path); pack_index_path = g_file_resolve_relative_path (ostree_repo_get_path (data->repo), path);
if (!ot_util_variant_map (pack_index_path, if (!ot_util_variant_map (pack_index_path,
OSTREE_PACK_INDEX_VARIANT_FORMAT, OSTREE_PACK_INDEX_VARIANT_FORMAT, FALSE,
&index_variant, error)) &index_variant, error))
goto out; goto out;

View File

@ -284,7 +284,7 @@ pack_one_meta_object (OtRepackData *data,
object_path = ostree_repo_get_object_path (data->repo, checksum, objtype); object_path = ostree_repo_get_object_path (data->repo, checksum, objtype);
if (!ot_util_variant_map (object_path, ostree_metadata_variant_type (objtype), if (!ot_util_variant_map (object_path, ostree_metadata_variant_type (objtype),
&metadata_v, error)) TRUE, &metadata_v, error))
goto out; goto out;
ret_packed_object = g_variant_new ("(y@ayv)", (guchar) objtype, ret_packed_object = g_variant_new ("(y@ayv)", (guchar) objtype,

View File

@ -67,7 +67,7 @@ do_print_variant_generic (const GVariantType *type,
f = ot_gfile_new_for_path (filename); f = ot_gfile_new_for_path (filename);
if (!ot_util_variant_map (f, type, &variant, error)) if (!ot_util_variant_map (f, type, TRUE, &variant, error))
goto out; goto out;
print_variant (variant); print_variant (variant);