Hash :
4d5ee956
Author :
Date :
2022-07-02T21:27:21
create and verify tags signed by SSH keys This adds a new -s flag to 'got tag' that specifies the signer identity (for example, a key file) of the tagger. The tag object will include a signature that validates each of the tag object headers and the tag message. Verifying these signed tags requires maintaining an allowed signers file which maps signer identities (i.e. the email address of the tagger) to SSH public keys. See ssh-keygen(1) for more details of the allowed signers file. After creating this file and providing the path to it in got.conf(5) using the allowed_signers option, tags may be verified using with 'got tag -V tag_name'. The return code will be non-zero if a signature fails to verify. ok stsp@
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 58 59 60 61 62 63 64 65 66 67 68 69 70 71 72 73 74 75 76 77 78 79
/*
* Copyright (c) 2022 Josh Rickmar <jrick@zettaport.com>
* Copyright (c) 2020, 2021 Tracey Emery <tracey@openbsd.org>
* Copyright (c) 2020 Stefan Sperling <stsp@openbsd.org>
*
* Permission to use, copy, modify, and distribute this software for any
* purpose with or without fee is hereby granted, provided that the above
* copyright notice and this permission notice appear in all copies.
*
* THE SOFTWARE IS PROVIDED "AS IS" AND THE AUTHOR DISCLAIMS ALL WARRANTIES
* WITH REGARD TO THIS SOFTWARE INCLUDING ALL IMPLIED WARRANTIES OF
* MERCHANTABILITY AND FITNESS. IN NO EVENT SHALL THE AUTHOR BE LIABLE FOR
* ANY SPECIAL, DIRECT, INDIRECT, OR CONSEQUENTIAL DAMAGES OR ANY DAMAGES
* WHATSOEVER RESULTING FROM LOSS OF USE, DATA OR PROFITS, WHETHER IN AN
* ACTION OF CONTRACT, NEGLIGENCE OR OTHER TORTIOUS ACTION, ARISING OUT OF
* OR IN CONNECTION WITH THE USE OR PERFORMANCE OF THIS SOFTWARE.
*/
/*
* We maintain two different structures for fetch and send configuration
* settings in case they diverge in the future.
*/
struct fetch_config {
char *repository;
char *server;
char *protocol;
int port;
struct node_branch *branch;
};
struct send_config {
char *repository;
char *server;
char *protocol;
int port;
struct node_branch *branch;
};
struct node_branch {
char *branch_name;
struct node_branch *next;
struct node_branch *tail;
};
struct node_ref {
char *ref_name;
struct node_ref *next;
struct node_ref *tail;
};
struct gotconfig_remote_repo {
TAILQ_ENTRY(gotconfig_remote_repo) entry;
char *name;
char *repository;
char *server;
char *protocol;
int port;
int mirror_references;
int fetch_all_branches;
struct node_branch *branch;
struct node_ref *fetch_ref;
struct fetch_config *fetch_config;
struct send_config *send_config;
};
TAILQ_HEAD(gotconfig_remote_repo_list, gotconfig_remote_repo);
struct gotconfig {
char *author;
struct gotconfig_remote_repo_list remotes;
int nremotes;
char *allowed_signers_file;
char *revoked_signers_file;
};
/*
* Parse individual gotconfig repository files
*/
const struct got_error *gotconfig_parse(struct gotconfig **, const char *,
int *);
void gotconfig_free(struct gotconfig *);