diff options
Diffstat (limited to 'builtin/credential.c')
-rw-r--r-- | builtin/credential.c | 52 |
1 files changed, 52 insertions, 0 deletions
diff --git a/builtin/credential.c b/builtin/credential.c new file mode 100644 index 0000000000..a295c80b36 --- /dev/null +++ b/builtin/credential.c @@ -0,0 +1,52 @@ +#define USE_THE_REPOSITORY_VARIABLE + +#include "git-compat-util.h" +#include "credential.h" +#include "builtin.h" +#include "environment.h" +#include "config.h" + +static const char usage_msg[] = + "git credential (fill|approve|reject)"; + +int cmd_credential(int argc, + const char **argv, + const char *prefix UNUSED, + struct repository *repo UNUSED) +{ + const char *op; + struct credential c = CREDENTIAL_INIT; + + repo_config(the_repository, git_default_config, NULL); + + show_usage_if_asked(argc, argv, usage_msg); + if (argc != 2) + usage(usage_msg); + op = argv[1]; + + if (!strcmp(op, "capability")) { + credential_set_all_capabilities(&c, CREDENTIAL_OP_INITIAL); + credential_announce_capabilities(&c, stdout); + return 0; + } + + if (credential_read(&c, stdin, CREDENTIAL_OP_INITIAL) < 0) + die("unable to read credential from stdin"); + + if (!strcmp(op, "fill")) { + credential_fill(the_repository, &c, 0); + credential_next_state(&c); + credential_write(&c, stdout, CREDENTIAL_OP_RESPONSE); + } else if (!strcmp(op, "approve")) { + credential_set_all_capabilities(&c, CREDENTIAL_OP_HELPER); + credential_approve(the_repository, &c); + } else if (!strcmp(op, "reject")) { + credential_set_all_capabilities(&c, CREDENTIAL_OP_HELPER); + credential_reject(the_repository, &c); + } else { + usage(usage_msg); + } + + credential_clear(&c); + return 0; +} |