2021-10-01 23:52:55 +00:00
|
|
|
/*
|
|
|
|
* Copyright (c) 2018 Yubico AB. All rights reserved.
|
|
|
|
* Use of this source code is governed by a BSD-style
|
|
|
|
* license that can be found in the LICENSE file.
|
|
|
|
*/
|
|
|
|
|
|
|
|
#include <fido.h>
|
|
|
|
#include <stdio.h>
|
|
|
|
#include <stdlib.h>
|
|
|
|
|
|
|
|
#include "../openbsd-compat/openbsd-compat.h"
|
|
|
|
#include "extern.h"
|
|
|
|
|
|
|
|
static int action;
|
|
|
|
|
|
|
|
void
|
|
|
|
usage(void)
|
|
|
|
{
|
|
|
|
fprintf(stderr,
|
|
|
|
"usage: fido2-token -C [-d] device\n"
|
|
|
|
" fido2-token -Db [-k key_path] [-i cred_id -n rp_id] device\n"
|
|
|
|
" fido2-token -Dei template_id device\n"
|
|
|
|
" fido2-token -Du device\n"
|
|
|
|
" fido2-token -Gb [-k key_path] [-i cred_id -n rp_id] blob_path device\n"
|
|
|
|
" fido2-token -I [-cd] [-k rp_id -i cred_id] device\n"
|
|
|
|
" fido2-token -L [-bder] [-k rp_id] [device]\n"
|
|
|
|
" fido2-token -R [-d] device\n"
|
|
|
|
" fido2-token -S [-adefu] [-l pin_length] [-i template_id -n template_name] device\n"
|
|
|
|
" fido2-token -Sb [-k key_path] [-i cred_id -n rp_id] blob_path device\n"
|
|
|
|
" fido2-token -Sc -i cred_id -k user_id -n name -p display_name device\n"
|
2023-04-26 16:37:20 +00:00
|
|
|
" fido2-token -Sm rp_id device\n"
|
2021-10-01 23:52:55 +00:00
|
|
|
" fido2-token -V\n"
|
|
|
|
);
|
|
|
|
|
|
|
|
exit(1);
|
|
|
|
}
|
|
|
|
|
|
|
|
static void
|
|
|
|
setaction(int ch)
|
|
|
|
{
|
|
|
|
if (action)
|
|
|
|
usage();
|
|
|
|
action = ch;
|
|
|
|
}
|
|
|
|
|
|
|
|
int
|
|
|
|
main(int argc, char **argv)
|
|
|
|
{
|
|
|
|
int ch;
|
|
|
|
int flags = 0;
|
|
|
|
char *device;
|
|
|
|
|
|
|
|
while ((ch = getopt(argc, argv, TOKEN_OPT)) != -1) {
|
|
|
|
switch (ch) {
|
|
|
|
case 'a':
|
|
|
|
case 'b':
|
|
|
|
case 'c':
|
|
|
|
case 'e':
|
|
|
|
case 'f':
|
|
|
|
case 'i':
|
|
|
|
case 'k':
|
|
|
|
case 'l':
|
2023-04-26 16:37:20 +00:00
|
|
|
case 'm':
|
2021-10-01 23:52:55 +00:00
|
|
|
case 'n':
|
|
|
|
case 'p':
|
|
|
|
case 'r':
|
|
|
|
case 'u':
|
|
|
|
break; /* ignore */
|
|
|
|
case 'd':
|
|
|
|
flags = FIDO_DEBUG;
|
|
|
|
break;
|
|
|
|
default:
|
|
|
|
setaction(ch);
|
|
|
|
break;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
if (argc - optind < 1)
|
|
|
|
device = NULL;
|
|
|
|
else
|
|
|
|
device = argv[argc - 1];
|
|
|
|
|
|
|
|
fido_init(flags);
|
|
|
|
|
|
|
|
switch (action) {
|
|
|
|
case 'C':
|
|
|
|
return (pin_change(device));
|
|
|
|
case 'D':
|
|
|
|
return (token_delete(argc, argv, device));
|
|
|
|
case 'G':
|
|
|
|
return (token_get(argc, argv, device));
|
|
|
|
case 'I':
|
|
|
|
return (token_info(argc, argv, device));
|
|
|
|
case 'L':
|
|
|
|
return (token_list(argc, argv, device));
|
|
|
|
case 'R':
|
|
|
|
return (token_reset(device));
|
|
|
|
case 'S':
|
|
|
|
return (token_set(argc, argv, device));
|
|
|
|
case 'V':
|
|
|
|
fprintf(stderr, "%d.%d.%d\n", _FIDO_MAJOR, _FIDO_MINOR,
|
|
|
|
_FIDO_PATCH);
|
|
|
|
exit(0);
|
|
|
|
}
|
|
|
|
|
|
|
|
usage();
|
|
|
|
|
|
|
|
/* NOTREACHED */
|
|
|
|
}
|