freebsd-dev/contrib/libfido2/tools/fido2-token.c
Ed Maste f540a43052 libfido2: update to 1.9.0
Some highlights from NEWS:

 ** Added OpenSSL 3.0 compatibility.
 ** Removed OpenSSL 1.0 compatibility.
 ** Support for FIDO 2.1 "minPinLength" extension.
 ** Support for COSE_EDDSA, COSE_ES256, and COSE_RS1 attestation.
 ** Support for TPM 2.0 attestation.
 ** Support for device timeouts; see fido_dev_set_timeout().
 ** New API calls:
  - es256_pk_from_EVP_PKEY;
  - fido_cred_attstmt_len;
  - fido_cred_attstmt_ptr;
  - fido_cred_pin_minlen;
  - fido_cred_set_attstmt;
  - fido_cred_set_pin_minlen;
  - fido_dev_set_pin_minlen_rpid;
  - fido_dev_set_timeout;
  - rs256_pk_from_EVP_PKEY.
 ** Reliability and portability fixes.
 ** Better handling of HID devices without identification strings; gh#381.

Relnotes:       Yes
Sponsored by:   The FreeBSD Foundation
2023-05-05 19:11:52 -04:00

110 lines
2.1 KiB
C

/*
* 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"
" fido2-token -Sm rp_id device\n"
" 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':
case 'm':
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 */
}