Home | History | Annotate | Line # | Download | only in cgdconfig
params.h revision 1.14.2.1
      1  1.14.2.1    martin /* $NetBSD: params.h,v 1.14.2.1 2024/10/11 08:54:39 martin Exp $ */
      2       1.1     elric 
      3       1.1     elric /*-
      4       1.4     elric  * Copyright (c) 2002, 2003 The NetBSD Foundation, Inc.
      5       1.1     elric  * All rights reserved.
      6       1.1     elric  *
      7       1.1     elric  * This code is derived from software contributed to The NetBSD Foundation
      8       1.1     elric  * by Roland C. Dowdeswell.
      9       1.1     elric  *
     10       1.1     elric  * Redistribution and use in source and binary forms, with or without
     11       1.1     elric  * modification, are permitted provided that the following conditions
     12       1.1     elric  * are met:
     13       1.1     elric  * 1. Redistributions of source code must retain the above copyright
     14       1.1     elric  *    notice, this list of conditions and the following disclaimer.
     15       1.1     elric  * 2. Redistributions in binary form must reproduce the above copyright
     16       1.1     elric  *    notice, this list of conditions and the following disclaimer in the
     17       1.1     elric  *    documentation and/or other materials provided with the distribution.
     18       1.1     elric  *
     19       1.1     elric  * THIS SOFTWARE IS PROVIDED BY THE NETBSD FOUNDATION, INC. AND CONTRIBUTORS
     20       1.1     elric  * ``AS IS'' AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED
     21       1.1     elric  * TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR
     22       1.1     elric  * PURPOSE ARE DISCLAIMED.  IN NO EVENT SHALL THE FOUNDATION OR CONTRIBUTORS
     23       1.1     elric  * BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR
     24       1.1     elric  * CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF
     25       1.1     elric  * SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS
     26       1.1     elric  * INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN
     27       1.1     elric  * CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE)
     28       1.1     elric  * ARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE
     29       1.1     elric  * POSSIBILITY OF SUCH DAMAGE.
     30       1.1     elric  */
     31       1.1     elric 
     32       1.4     elric #ifndef PARAMS_H
     33       1.4     elric #define PARAMS_H
     34       1.4     elric 
     35       1.4     elric #include "utils.h"
     36       1.4     elric 
     37       1.4     elric struct keygen {
     38       1.4     elric 	int		 kg_method;
     39       1.8  christos 	size_t		 kg_iterations;
     40      1.12       nia 	size_t		 kg_memory;		/* only used for Argon2 */
     41      1.12       nia 	size_t		 kg_parallelism;	/* only used for Argon2 */
     42      1.12       nia 	size_t		 kg_version;		/* only used for Argon2 */
     43       1.4     elric 	bits_t		*kg_salt;
     44       1.4     elric 	bits_t		*kg_key;
     45      1.10     elric 	string_t	*kg_cmd;
     46      1.13  riastrad 	string_t	*kg_sharedid;
     47      1.13  riastrad 	int		 kg_sharedalg;
     48      1.13  riastrad 	size_t		 kg_sharedlen;
     49      1.13  riastrad 	bits_t		*kg_sharedinfo;
     50       1.4     elric 	struct keygen	*next;
     51       1.4     elric };
     52       1.4     elric 
     53       1.1     elric struct params {
     54       1.4     elric 	string_t	*algorithm;
     55       1.4     elric 	string_t	*ivmeth;
     56       1.4     elric 	bits_t		*key;
     57       1.8  christos 	size_t		 keylen;
     58       1.8  christos 	size_t		 bsize;
     59       1.2     elric 	int		 verify_method;
     60       1.4     elric 	struct keygen	*dep_keygen;
     61       1.4     elric 	struct keygen	*keygen;
     62       1.1     elric };
     63       1.1     elric 
     64       1.2     elric /* key generation methods */
     65       1.2     elric 
     66       1.6       dan #define KEYGEN_UNKNOWN			0x0
     67       1.6       dan #define KEYGEN_RANDOMKEY		0x1
     68       1.6       dan #define KEYGEN_PKCS5_PBKDF2_OLD		0x2
     69       1.6       dan #define KEYGEN_STOREDKEY		0x3
     70       1.7        tv #define KEYGEN_URANDOMKEY		0x4
     71       1.6       dan #define KEYGEN_PKCS5_PBKDF2_SHA1	0x5
     72      1.10     elric #define KEYGEN_SHELL_CMD		0x6
     73      1.12       nia #define KEYGEN_ARGON2ID			0x7
     74       1.1     elric 
     75       1.2     elric /* verification methods */
     76       1.2     elric 
     77       1.2     elric #define VERIFY_UNKNOWN		0x0
     78       1.2     elric #define VERIFY_NONE		0x1
     79       1.2     elric #define VERIFY_DISKLABEL	0x2
     80       1.4     elric #define VERIFY_FFS		0x3
     81       1.5        cb #define VERIFY_REENTER		0x4
     82      1.11   mlelstv #define VERIFY_MBR      	0x5
     83      1.11   mlelstv #define VERIFY_GPT      	0x6
     84  1.14.2.1    martin #define VERIFY_ZFS      	0x7
     85       1.2     elric 
     86      1.13  riastrad /* shared key derivation methods */
     87      1.13  riastrad 
     88      1.13  riastrad #define	SHARED_ALG_UNKNOWN		0x0
     89      1.13  riastrad #define	SHARED_ALG_HKDF_HMAC_SHA256	0x1
     90      1.13  riastrad 
     91       1.4     elric __BEGIN_DECLS
     92       1.4     elric struct params	*params_new(void);
     93       1.4     elric void		 params_free(struct params *);
     94       1.4     elric 
     95       1.4     elric int		 params_filldefaults(struct params *);
     96       1.4     elric int		 params_verify(const struct params *);
     97       1.4     elric 
     98       1.4     elric struct params	*params_combine(struct params *, struct params *);
     99       1.4     elric struct params	*params_algorithm(string_t *);
    100       1.4     elric struct params	*params_ivmeth(string_t *);
    101       1.8  christos struct params	*params_keylen(size_t);
    102       1.8  christos struct params	*params_bsize(size_t);
    103       1.4     elric struct params	*params_verify_method(string_t *);
    104       1.4     elric struct params	*params_keygen(struct keygen *);
    105       1.4     elric struct params	*params_dep_keygen(struct keygen *);
    106       1.4     elric 
    107       1.4     elric struct params	*params_fget(FILE *);
    108       1.4     elric struct params	*params_cget(const char *);
    109       1.4     elric int		 params_fput(struct params *, FILE *);
    110       1.4     elric int		 params_cput(struct params *, const char *);
    111       1.4     elric 
    112       1.4     elric struct keygen	*keygen_new(void);
    113       1.4     elric void		 keygen_free(struct keygen *);
    114       1.4     elric 
    115       1.8  christos int		 keygen_filldefaults(struct keygen *, size_t);
    116      1.14  riastrad void		 keygen_stripstored(struct keygen **);
    117      1.14  riastrad int		 keygen_makeshared(struct keygen *);
    118      1.14  riastrad int		 keygen_tweakshared(struct keygen *);
    119       1.4     elric int		 keygen_verify(const struct keygen *);
    120       1.4     elric void		 keygen_addlist(struct keygen **, struct keygen *);
    121       1.4     elric 
    122       1.4     elric struct keygen	*keygen_combine(struct keygen *, struct keygen *);
    123       1.4     elric struct keygen	*keygen_generate(int);
    124       1.4     elric struct keygen	*keygen_method(string_t *);
    125       1.4     elric struct keygen	*keygen_set_method(struct keygen *, string_t *);
    126       1.4     elric struct keygen	*keygen_salt(bits_t *);
    127       1.8  christos struct keygen	*keygen_iterations(size_t);
    128      1.12       nia struct keygen	*keygen_memory(size_t);
    129      1.12       nia struct keygen	*keygen_parallelism(size_t);
    130      1.12       nia struct keygen	*keygen_version(size_t);
    131       1.4     elric struct keygen	*keygen_key(bits_t *);
    132      1.10     elric struct keygen	*keygen_cmd(string_t *);
    133      1.13  riastrad struct keygen	*keygen_shared(string_t *, string_t *, bits_t *);
    134       1.1     elric 
    135       1.4     elric int		 keygen_fput(struct keygen *, int, FILE *);
    136       1.4     elric __END_DECLS
    137       1.1     elric 
    138       1.4     elric #endif
    139