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
49 lines
971 B
C
49 lines
971 B
C
/*
|
|
* Copyright (c) 2018-2021 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.
|
|
*/
|
|
|
|
/*
|
|
* Perform a factory reset on a given authenticator.
|
|
*/
|
|
|
|
#include <fido.h>
|
|
#include <stdio.h>
|
|
#include <stdlib.h>
|
|
|
|
#include "../openbsd-compat/openbsd-compat.h"
|
|
#include "extern.h"
|
|
|
|
int
|
|
main(int argc, char **argv)
|
|
{
|
|
fido_dev_t *dev;
|
|
int r;
|
|
|
|
if (argc != 2) {
|
|
fprintf(stderr, "usage: reset <device>\n");
|
|
exit(EXIT_FAILURE);
|
|
}
|
|
|
|
fido_init(0);
|
|
|
|
if ((dev = fido_dev_new()) == NULL)
|
|
errx(1, "fido_dev_new");
|
|
|
|
if ((r = fido_dev_open(dev, argv[1])) != FIDO_OK)
|
|
errx(1, "fido_dev_open: %s (0x%x)", fido_strerr(r), r);
|
|
|
|
if ((r = fido_dev_reset(dev)) != FIDO_OK) {
|
|
fido_dev_cancel(dev);
|
|
errx(1, "fido_dev_reset: %s (0x%x)", fido_strerr(r), r);
|
|
}
|
|
|
|
if ((r = fido_dev_close(dev)) != FIDO_OK)
|
|
errx(1, "fido_dev_close: %s (0x%x)", fido_strerr(r), r);
|
|
|
|
fido_dev_free(&dev);
|
|
|
|
exit(0);
|
|
}
|