summaryrefslogtreecommitdiff
path: root/builtin/credential.c
diff options
context:
space:
mode:
Diffstat (limited to 'builtin/credential.c')
-rw-r--r--builtin/credential.c52
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;
+}