1/* 2 * Copyright (c) 2019-2021 Yubico AB. All rights reserved. 3 * Use of this source code is governed by a BSD-style 4 * license that can be found in the LICENSE file. 5 */ 6 7#ifndef _FIDO_CREDMAN_H 8#define _FIDO_CREDMAN_H 9 10#include <stdint.h> 11#include <stdlib.h> 12 13#ifdef _FIDO_INTERNAL 14#include "blob.h" 15#include "fido/err.h" 16#include "fido/param.h" 17#include "fido/types.h" 18#else 19#include <fido.h> 20#include <fido/err.h> 21#include <fido/param.h> 22#endif 23 24#ifdef __cplusplus 25extern "C" { 26#endif /* __cplusplus */ 27 28#ifdef _FIDO_INTERNAL 29struct fido_credman_metadata { 30 uint64_t rk_existing; 31 uint64_t rk_remaining; 32}; 33 34struct fido_credman_single_rp { 35 fido_rp_t rp_entity; 36 fido_blob_t rp_id_hash; 37}; 38 39struct fido_credman_rp { 40 struct fido_credman_single_rp *ptr; 41 size_t n_alloc; /* number of allocated entries */ 42 size_t n_rx; /* number of populated entries */ 43}; 44 45struct fido_credman_rk { 46 fido_cred_t *ptr; 47 size_t n_alloc; /* number of allocated entries */ 48 size_t n_rx; /* number of populated entries */ 49}; 50#endif 51 52typedef struct fido_credman_metadata fido_credman_metadata_t; 53typedef struct fido_credman_rk fido_credman_rk_t; 54typedef struct fido_credman_rp fido_credman_rp_t; 55 56const char *fido_credman_rp_id(const fido_credman_rp_t *, size_t); 57const char *fido_credman_rp_name(const fido_credman_rp_t *, size_t); 58 59const fido_cred_t *fido_credman_rk(const fido_credman_rk_t *, size_t); 60const unsigned char *fido_credman_rp_id_hash_ptr(const fido_credman_rp_t *, 61 size_t); 62 63fido_credman_metadata_t *fido_credman_metadata_new(void); 64fido_credman_rk_t *fido_credman_rk_new(void); 65fido_credman_rp_t *fido_credman_rp_new(void); 66 67int fido_credman_del_dev_rk(fido_dev_t *, const unsigned char *, size_t, 68 const char *); 69int fido_credman_get_dev_metadata(fido_dev_t *, fido_credman_metadata_t *, 70 const char *); 71int fido_credman_get_dev_rk(fido_dev_t *, const char *, fido_credman_rk_t *, 72 const char *); 73int fido_credman_get_dev_rp(fido_dev_t *, fido_credman_rp_t *, const char *); 74int fido_credman_set_dev_rk(fido_dev_t *, fido_cred_t *, const char *); 75 76size_t fido_credman_rk_count(const fido_credman_rk_t *); 77size_t fido_credman_rp_count(const fido_credman_rp_t *); 78size_t fido_credman_rp_id_hash_len(const fido_credman_rp_t *, size_t); 79 80uint64_t fido_credman_rk_existing(const fido_credman_metadata_t *); 81uint64_t fido_credman_rk_remaining(const fido_credman_metadata_t *); 82 83void fido_credman_metadata_free(fido_credman_metadata_t **); 84void fido_credman_rk_free(fido_credman_rk_t **); 85void fido_credman_rp_free(fido_credman_rp_t **); 86 87#ifdef __cplusplus 88} /* extern "C" */ 89#endif /* __cplusplus */ 90 91#endif /* !_FIDO_CREDMAN_H */ 92