Continuation of the addition of `ostree_repo_write_regfile_inline()`.
This will be helpful for ostree-rs-ext and importing from tar, it's
quite inefficient and awkward for small files to end up creating
a whole `GInputStream` and `GFileInfo` and etc. for small files.
ostree_repo_write_metadata_finish
ostree_repo_write_content
ostree_repo_write_regfile_inline
+ostree_repo_write_symlink
ostree_repo_write_metadata_trusted
ostree_repo_write_metadata_stream_trusted
ostree_repo_write_content_trusted
LIBOSTREE_2021.2 {
global:
ostree_repo_write_regfile_inline;
+ ostree_repo_write_symlink;
} LIBOSTREE_2021.1;
/* Stub section for the stable release *after* this development one; don't
return ostree_checksum_from_bytes (csum);
}
+/**
+ * ostree_repo_write_symlink:
+ * @self: repo
+ * @expected_checksum: (allow-none): The expected checksum
+ * @uid: User id
+ * @gid: Group id
+ * @xattrs: (allow-none): Extended attributes, GVariant of type (ayay)
+ * @symlink_target: Target of the symbolic link
+ * @cancellable: Cancellable
+ * @error: Error
+ *
+ * Synchronously create a symlink object.
+ *
+ * Unlike `ostree_repo_write_content()`, if @expected_checksum is provided,
+ * this function will not check for the presence of the object beforehand.
+ *
+ * Returns: (transfer full): Checksum (as a hex string) of the committed file
+ * Since: 2021.2
+ */
+char *
+ostree_repo_write_symlink (OstreeRepo *self,
+ const char *expected_checksum,
+ guint32 uid,
+ guint32 gid,
+ GVariant *xattrs,
+ const char *symlink_target,
+ GCancellable *cancellable,
+ GError **error)
+{
+ g_assert (symlink_target != NULL);
+
+ g_autoptr(GFileInfo) finfo = _ostree_mode_uidgid_to_gfileinfo (S_IFLNK | 0777, uid, gid);
+ g_file_info_set_attribute_byte_string (finfo, "standard::symlink-target", symlink_target);
+ g_autofree guint8* csum = NULL;
+ if (!write_content_object (self, expected_checksum,
+ NULL, finfo, xattrs, &csum,
+ cancellable, error))
+ return NULL;
+ return ostree_checksum_from_bytes (csum);
+}
+
typedef struct {
OstreeRepo *repo;
char *expected_checksum;
GCancellable *cancellable,
GError **error);
+_OSTREE_PUBLIC
+char * ostree_repo_write_symlink (OstreeRepo *self,
+ const char *expected_checksum,
+ guint32 uid,
+ guint32 gid,
+ GVariant *xattrs,
+ const char *symlink_target,
+ GCancellable *cancellable,
+ GError **error);
+
_OSTREE_PUBLIC
gboolean ostree_repo_write_metadata_trusted (OstreeRepo *self,
OstreeObjectType objtype,
assertEquals(inline_checksum, "8aaa9dc13a0c5839fe4a277756798c609c53fac6fa2290314ecfef9041065873");
let written = false;
try {
+ // Changed an a to b from above to make the checksum not match
repo.write_regfile_inline("8baa9dc13a0c5839fe4a277756798c609c53fac6fa2290314ecfef9041065873", 0, 0, regfile_mode, null, inline_content, null);
written = true;
} catch (e) {
g_assert_no_error (error);
g_assert_cmpstr (checksum, ==, "4f600d252338f93279c51c964915cb2c26f0d09082164c54890d1a3c78cdeb1e");
g_clear_pointer (&checksum, g_free);
+
+ // Test symlinks
+ g_clear_pointer (&xattrs, g_variant_unref);
+ g_variant_builder_init (&xattrs_builder, (GVariantType*)"a(ayay)");
+ g_variant_builder_add (&xattrs_builder, "(^ay^ay)", "security.selinux", "system_u:object_r:bin_t:s0");
+ g_clear_pointer (&xattrs, g_variant_unref);
+ xattrs = g_variant_ref_sink (g_variant_builder_end (&xattrs_builder));
+
+ g_clear_pointer (&checksum, g_free);
+ checksum = ostree_repo_write_symlink (repo, NULL, 0, 0, xattrs, "bash", NULL, &error);
+ g_assert_no_error (error);
+ g_assert_cmpstr (checksum, ==, "23a2e97d21d960ac7a4e39a8721b1baff7b213e00e5e5641334f50506012fcff");
}
int