Home | History | Annotate | Line # | Download | only in cgdconfig
      1  1.15  christos /* $NetBSD: params.h,v 1.15 2024/05/12 18:02:16 christos 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.15  christos #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