/* vim:set et sw=2 cin cino=t0,f0,(0,{s,>2s,n-s,^-s,e2s: */ /* * Copyright © 2019 Collabora Ltd. * * SPDX-License-Identifier: LGPL-2.0+ * * This library is free software; you can redistribute it and/or * modify it under the terms of the GNU Lesser General Public * License as published by the Free Software Foundation; either * version 2 of the License, or (at your option) any later version. * * This library is distributed in the hope that it will be useful, * but WITHOUT ANY WARRANTY; without even the implied warranty of * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU * Lesser General Public License for more details. * * You should have received a copy of the GNU Lesser General Public * License along with this library. If not, see . * * Authors: * - Denis Pynkin (d4s) */ #pragma once #include #include #include "ostree-blob-reader.h" #include "ostree-ref.h" #include "ostree-remote.h" #include "ostree-types.h" G_BEGIN_DECLS #define OSTREE_TYPE_SIGN (ostree_sign_get_type ()) /** * OSTREE_SIGN_NAME_ED25519: * The name of the default ed25519 signing type. * * Since: 2020.4 */ #define OSTREE_SIGN_NAME_ED25519 "ed25519" /** * OSTREE_SIGN_NAME_SPKI: * The name of the spki signing type. * * Since: 2024.7 */ #define OSTREE_SIGN_NAME_SPKI "spki" _OSTREE_PUBLIC G_DECLARE_INTERFACE (OstreeSign, ostree_sign, OSTREE, SIGN, GObject) struct _OstreeSignInterface { GTypeInterface g_iface; const gchar *(*get_name) (OstreeSign *self); gboolean (*data) (OstreeSign *self, GBytes *data, GBytes **signature, GCancellable *cancellable, GError **error); gboolean (*data_verify) (OstreeSign *self, GBytes *data, GVariant *signatures, char **out_success_message, GError **error); const gchar *(*metadata_key) (OstreeSign *self); const gchar *(*metadata_format) (OstreeSign *self); gboolean (*clear_keys) (OstreeSign *self, GError **error); gboolean (*set_sk) (OstreeSign *self, GVariant *secret_key, GError **error); gboolean (*set_pk) (OstreeSign *self, GVariant *public_key, GError **error); gboolean (*add_pk) (OstreeSign *self, GVariant *public_key, GError **error); gboolean (*load_pk) (OstreeSign *self, GVariant *options, GError **error); }; _OSTREE_PUBLIC const gchar *ostree_sign_get_name (OstreeSign *self); _OSTREE_PUBLIC gboolean ostree_sign_data (OstreeSign *self, GBytes *data, GBytes **signature, GCancellable *cancellable, GError **error); _OSTREE_PUBLIC gboolean ostree_sign_data_verify (OstreeSign *self, GBytes *data, GVariant *signatures, char **out_success_message, GError **error); _OSTREE_PUBLIC const gchar *ostree_sign_metadata_key (OstreeSign *self); _OSTREE_PUBLIC const gchar *ostree_sign_metadata_format (OstreeSign *self); _OSTREE_PUBLIC gboolean ostree_sign_commit (OstreeSign *self, OstreeRepo *repo, const gchar *commit_checksum, GCancellable *cancellable, GError **error); _OSTREE_PUBLIC gboolean ostree_sign_commit_verify (OstreeSign *self, OstreeRepo *repo, const gchar *commit_checksum, char **out_success_message, GCancellable *cancellable, GError **error); _OSTREE_PUBLIC gboolean ostree_sign_clear_keys (OstreeSign *self, GError **error); _OSTREE_PUBLIC gboolean ostree_sign_set_sk (OstreeSign *self, GVariant *secret_key, GError **error); _OSTREE_PUBLIC gboolean ostree_sign_set_pk (OstreeSign *self, GVariant *public_key, GError **error); _OSTREE_PUBLIC gboolean ostree_sign_add_pk (OstreeSign *self, GVariant *public_key, GError **error); _OSTREE_PUBLIC gboolean ostree_sign_load_pk (OstreeSign *self, GVariant *options, GError **error); _OSTREE_PUBLIC GPtrArray *ostree_sign_get_all (void); _OSTREE_PUBLIC OstreeSign *ostree_sign_get_by_name (const gchar *name, GError **error); _OSTREE_PUBLIC gboolean ostree_sign_summary (OstreeSign *self, OstreeRepo *repo, GVariant *keys, GCancellable *cancellable, GError **error); _OSTREE_PUBLIC OstreeBlobReader *ostree_sign_read_pk (OstreeSign *self, GInputStream *stream); _OSTREE_PUBLIC OstreeBlobReader *ostree_sign_read_sk (OstreeSign *self, GInputStream *stream); G_END_DECLS