PHP 7.4.33
Preview: kdf.h Size: 5.49 KB
//usr/include/openssl/kdf.h
/*
 * Copyright 2016-2021 The OpenSSL Project Authors. All Rights Reserved.
 *
 * Licensed under the Apache License 2.0 (the "License").  You may not use
 * this file except in compliance with the License.  You can obtain a copy
 * in the file LICENSE in the source distribution or at
 * https://www.openssl.org/source/license.html
 */

#ifndef OPENSSL_KDF_H
# define OPENSSL_KDF_H
# pragma once

# include <openssl/macros.h>
# ifndef OPENSSL_NO_DEPRECATED_3_0
#  define HEADER_KDF_H
# endif

# include <stdarg.h>
# include <stddef.h>
# include <openssl/types.h>
# include <openssl/core.h>

# ifdef __cplusplus
extern "C" {
# endif

int EVP_KDF_up_ref(EVP_KDF *kdf);
void EVP_KDF_free(EVP_KDF *kdf);
EVP_KDF *EVP_KDF_fetch(OSSL_LIB_CTX *libctx, const char *algorithm,
                       const char *properties);

EVP_KDF_CTX *EVP_KDF_CTX_new(EVP_KDF *kdf);
void EVP_KDF_CTX_free(EVP_KDF_CTX *ctx);
EVP_KDF_CTX *EVP_KDF_CTX_dup(const EVP_KDF_CTX *src);
const char *EVP_KDF_get0_description(const EVP_KDF *kdf);
int EVP_KDF_is_a(const EVP_KDF *kdf, const char *name);
const char *EVP_KDF_get0_name(const EVP_KDF *kdf);
const OSSL_PROVIDER *EVP_KDF_get0_provider(const EVP_KDF *kdf);
const EVP_KDF *EVP_KDF_CTX_kdf(EVP_KDF_CTX *ctx);

void EVP_KDF_CTX_reset(EVP_KDF_CTX *ctx);
size_t EVP_KDF_CTX_get_kdf_size(EVP_KDF_CTX *ctx);
int EVP_KDF_derive(EVP_KDF_CTX *ctx, unsigned char *key, size_t keylen,
                   const OSSL_PARAM params[]);
int EVP_KDF_get_params(EVP_KDF *kdf, OSSL_PARAM params[]);
int EVP_KDF_CTX_get_params(EVP_KDF_CTX *ctx, OSSL_PARAM params[]);
int EVP_KDF_CTX_set_params(EVP_KDF_CTX *ctx, const OSSL_PARAM params[]);
const OSSL_PARAM *EVP_KDF_gettable_params(const EVP_KDF *kdf);
const OSSL_PARAM *EVP_KDF_gettable_ctx_params(const EVP_KDF *kdf);
const OSSL_PARAM *EVP_KDF_settable_ctx_params(const EVP_KDF *kdf);
const OSSL_PARAM *EVP_KDF_CTX_gettable_params(EVP_KDF_CTX *ctx);
const OSSL_PARAM *EVP_KDF_CTX_settable_params(EVP_KDF_CTX *ctx);

void EVP_KDF_do_all_provided(OSSL_LIB_CTX *libctx,
                             void (*fn)(EVP_KDF *kdf, void *arg),
                             void *arg);
int EVP_KDF_names_do_all(const EVP_KDF *kdf,
                         void (*fn)(const char *name, void *data),
                         void *data);

# define EVP_KDF_HKDF_MODE_EXTRACT_AND_EXPAND  0
# define EVP_KDF_HKDF_MODE_EXTRACT_ONLY        1
# define EVP_KDF_HKDF_MODE_EXPAND_ONLY         2

#define EVP_KDF_SSHKDF_TYPE_INITIAL_IV_CLI_TO_SRV     65
#define EVP_KDF_SSHKDF_TYPE_INITIAL_IV_SRV_TO_CLI     66
#define EVP_KDF_SSHKDF_TYPE_ENCRYPTION_KEY_CLI_TO_SRV 67
#define EVP_KDF_SSHKDF_TYPE_ENCRYPTION_KEY_SRV_TO_CLI 68
#define EVP_KDF_SSHKDF_TYPE_INTEGRITY_KEY_CLI_TO_SRV  69
#define EVP_KDF_SSHKDF_TYPE_INTEGRITY_KEY_SRV_TO_CLI  70

/**** The legacy PKEY-based KDF API follows. ****/

# define EVP_PKEY_CTRL_TLS_MD                   (EVP_PKEY_ALG_CTRL)
# define EVP_PKEY_CTRL_TLS_SECRET               (EVP_PKEY_ALG_CTRL + 1)
# define EVP_PKEY_CTRL_TLS_SEED                 (EVP_PKEY_ALG_CTRL + 2)
# define EVP_PKEY_CTRL_HKDF_MD                  (EVP_PKEY_ALG_CTRL + 3)
# define EVP_PKEY_CTRL_HKDF_SALT                (EVP_PKEY_ALG_CTRL + 4)
# define EVP_PKEY_CTRL_HKDF_KEY                 (EVP_PKEY_ALG_CTRL + 5)
# define EVP_PKEY_CTRL_HKDF_INFO                (EVP_PKEY_ALG_CTRL + 6)
# define EVP_PKEY_CTRL_HKDF_MODE                (EVP_PKEY_ALG_CTRL + 7)
# define EVP_PKEY_CTRL_PASS                     (EVP_PKEY_ALG_CTRL + 8)
# define EVP_PKEY_CTRL_SCRYPT_SALT              (EVP_PKEY_ALG_CTRL + 9)
# define EVP_PKEY_CTRL_SCRYPT_N                 (EVP_PKEY_ALG_CTRL + 10)
# define EVP_PKEY_CTRL_SCRYPT_R                 (EVP_PKEY_ALG_CTRL + 11)
# define EVP_PKEY_CTRL_SCRYPT_P                 (EVP_PKEY_ALG_CTRL + 12)
# define EVP_PKEY_CTRL_SCRYPT_MAXMEM_BYTES      (EVP_PKEY_ALG_CTRL + 13)

# define EVP_PKEY_HKDEF_MODE_EXTRACT_AND_EXPAND \
            EVP_KDF_HKDF_MODE_EXTRACT_AND_EXPAND
# define EVP_PKEY_HKDEF_MODE_EXTRACT_ONLY       \
            EVP_KDF_HKDF_MODE_EXTRACT_ONLY
# define EVP_PKEY_HKDEF_MODE_EXPAND_ONLY        \
            EVP_KDF_HKDF_MODE_EXPAND_ONLY

int EVP_PKEY_CTX_set_tls1_prf_md(EVP_PKEY_CTX *ctx, const EVP_MD *md);

int EVP_PKEY_CTX_set1_tls1_prf_secret(EVP_PKEY_CTX *pctx,
                                      const unsigned char *sec, int seclen);

int EVP_PKEY_CTX_add1_tls1_prf_seed(EVP_PKEY_CTX *pctx,
                                    const unsigned char *seed, int seedlen);

int EVP_PKEY_CTX_set_hkdf_md(EVP_PKEY_CTX *ctx, const EVP_MD *md);

int EVP_PKEY_CTX_set1_hkdf_salt(EVP_PKEY_CTX *ctx,
                                const unsigned char *salt, int saltlen);

int EVP_PKEY_CTX_set1_hkdf_key(EVP_PKEY_CTX *ctx,
                               const unsigned char *key, int keylen);

int EVP_PKEY_CTX_add1_hkdf_info(EVP_PKEY_CTX *ctx,
                                const unsigned char *info, int infolen);

int EVP_PKEY_CTX_set_hkdf_mode(EVP_PKEY_CTX *ctx, int mode);
# define EVP_PKEY_CTX_hkdf_mode EVP_PKEY_CTX_set_hkdf_mode

int EVP_PKEY_CTX_set1_pbe_pass(EVP_PKEY_CTX *ctx, const char *pass,
                               int passlen);

int EVP_PKEY_CTX_set1_scrypt_salt(EVP_PKEY_CTX *ctx,
                                  const unsigned char *salt, int saltlen);

int EVP_PKEY_CTX_set_scrypt_N(EVP_PKEY_CTX *ctx, uint64_t n);

int EVP_PKEY_CTX_set_scrypt_r(EVP_PKEY_CTX *ctx, uint64_t r);

int EVP_PKEY_CTX_set_scrypt_p(EVP_PKEY_CTX *ctx, uint64_t p);

int EVP_PKEY_CTX_set_scrypt_maxmem_bytes(EVP_PKEY_CTX *ctx,
                                         uint64_t maxmem_bytes);


# ifdef __cplusplus
}
# endif
#endif

Directory Contents

Dirs: 0 × Files: 133
Name Size Perms Modified Actions
3.66 KB lrw-r--r-- 2026-04-07 12:05:56
Edit Download
59.49 KB lrw-r--r-- 2026-04-07 12:05:56
Edit Download
7.55 KB lrw-r--r-- 2026-04-07 12:05:56
Edit Download
35.10 KB lrw-r--r-- 2026-04-07 12:05:56
Edit Download
398 B lrw-r--r-- 2026-04-07 12:05:56
Edit Download
3.09 KB lrw-r--r-- 2026-04-07 12:05:56
Edit Download
842 B lrw-r--r-- 2026-04-07 12:05:56
Edit Download
38.84 KB lrw-r--r-- 2026-04-07 12:05:56
Edit Download
3.01 KB lrw-r--r-- 2026-04-07 12:05:56
Edit Download
2.63 KB lrw-r--r-- 2026-04-07 12:05:56
Edit Download
23.13 KB lrw-r--r-- 2026-04-07 12:05:56
Edit Download
1.84 KB lrw-r--r-- 2026-04-07 12:05:56
Edit Download
1.62 KB lrw-r--r-- 2026-04-07 12:05:56
Edit Download
594 B lrw-r--r-- 2026-04-07 12:05:56
Edit Download
4.95 KB lrw-r--r-- 2026-04-07 12:05:56
Edit Download
2.02 KB lrw-r--r-- 2026-04-07 12:05:56
Edit Download
1.57 KB lrw-r--r-- 2026-04-07 12:05:56
Edit Download
39.82 KB lrw-r--r-- 2026-04-07 12:05:56
Edit Download
5.77 KB lrw-r--r-- 2026-04-07 12:05:56
Edit Download
1.70 KB lrw-r--r-- 2026-04-07 12:05:56
Edit Download
33.29 KB lrw-r--r-- 2026-04-07 12:05:56
Edit Download
6.39 KB lrw-r--r-- 2026-04-07 12:05:56
Edit Download
1.41 KB lrw-r--r-- 2026-04-07 12:05:56
Edit Download
813 B lrw-r--r-- 2026-04-07 12:05:56
Edit Download
10.24 KB lrw-r--r-- 2026-04-07 12:05:56
Edit Download
2.15 KB lrw-r--r-- 2026-04-07 12:05:56
Edit Download
1.16 KB lrw-r--r-- 2026-04-07 12:05:56
Edit Download
1.39 KB lrw-r--r-- 2026-04-07 12:05:56
Edit Download
7.94 KB lrw-r--r-- 2026-04-07 12:05:56
Edit Download
46.46 KB lrw-r--r-- 2026-04-07 12:05:56
Edit Download
28.48 KB lrw-r--r-- 2026-04-07 12:05:56
Edit Download
1.10 KB lrw-r--r-- 2026-04-07 12:05:56
Edit Download
14.30 KB lrw-r--r-- 2026-04-07 12:05:56
Edit Download
1.96 KB lrw-r--r-- 2026-04-07 12:05:56
Edit Download
23.39 KB lrw-r--r-- 2026-04-07 12:05:56
Edit Download
1.85 KB lrw-r--r-- 2026-04-07 12:05:56
Edit Download
78.51 KB lrw-r--r-- 2026-04-07 12:05:56
Edit Download
22.23 KB lrw-r--r-- 2026-04-07 12:05:56
Edit Download
1.65 KB lrw-r--r-- 2026-04-07 12:05:56
Edit Download
5.63 KB lrw-r--r-- 2026-04-07 12:05:56
Edit Download
791 B lrw-r--r-- 2026-04-07 12:05:56
Edit Download
8.33 KB lrw-r--r-- 2026-04-07 12:05:56
Edit Download
14.94 KB lrw-r--r-- 2026-04-07 12:05:56
Edit Download
2.45 KB lrw-r--r-- 2026-04-07 12:05:56
Edit Download
12.15 KB lrw-r--r-- 2026-04-07 12:05:56
Edit Download
1.53 KB lrw-r--r-- 2026-04-07 12:05:56
Edit Download
1.43 KB lrw-r--r-- 2026-04-07 12:05:56
Edit Download
1.02 KB lrw-r--r-- 2026-04-07 12:05:56
Edit Download
66.10 KB lrw-r--r-- 2026-04-07 12:05:56
Edit Download
361 B lrw-r--r-- 2026-04-07 12:05:56
Edit Download
361 B lrw-r--r-- 2026-04-07 12:05:56
Edit Download
5.16 KB lrw-r--r-- 2026-04-07 12:05:56
Edit Download
5.32 KB lrw-r--r-- 2026-04-07 12:05:56
Edit Download
791 B lrw-r--r-- 2026-04-07 12:05:56
Edit Download
37.91 KB lrw-r--r-- 2026-04-07 12:05:56
Edit Download
2.77 KB lrw-r--r-- 2026-04-07 12:05:56
Edit Download
20.59 KB lrw-r--r-- 2026-04-07 12:05:56
Edit Download
8.76 KB lrw-r--r-- 2026-04-07 12:05:56
Edit Download
1.12 KB lrw-r--r-- 2026-04-07 12:05:56
Edit Download
101.17 KB lrw-r--r-- 2026-04-07 12:05:56
Edit Download
7.18 KB lrw-r--r-- 2026-04-07 12:05:56
Edit Download
8.51 KB lrw-r--r-- 2026-04-07 12:05:56
Edit Download
1013 B lrw-r--r-- 2026-04-07 12:05:56
Edit Download
1.64 KB lrw-r--r-- 2026-04-07 12:05:56
Edit Download
2.09 KB lrw-r--r-- 2026-04-07 12:05:56
Edit Download
5.16 KB lrw-r--r-- 2026-04-07 12:05:56
Edit Download
2.39 KB lrw-r--r-- 2026-04-07 12:05:56
Edit Download
2.94 KB lrw-r--r-- 2026-04-07 12:05:56
Edit Download
5.49 KB lrw-r--r-- 2026-04-07 12:05:56
Edit Download
482 B lrw-r--r-- 2026-04-07 12:05:56
Edit Download
13.73 KB lrw-r--r-- 2026-04-07 12:05:56
Edit Download
9.87 KB lrw-r--r-- 2026-04-07 12:05:56
Edit Download
1.43 KB lrw-r--r-- 2026-04-07 12:05:56
Edit Download
1.66 KB lrw-r--r-- 2026-04-07 12:05:56
Edit Download
1.66 KB lrw-r--r-- 2026-04-07 12:05:56
Edit Download
1.41 KB lrw-r--r-- 2026-04-07 12:05:56
Edit Download
10.53 KB lrw-r--r-- 2026-04-07 12:05:56
Edit Download
6.69 KB lrw-r--r-- 2026-04-07 12:05:56
Edit Download
782 B lrw-r--r-- 2026-04-07 12:05:56
Edit Download
223.31 KB lrw-r--r-- 2026-04-07 12:05:56
Edit Download
28.67 KB lrw-r--r-- 2026-04-07 12:05:56
Edit Download
2.15 KB lrw-r--r-- 2026-04-07 12:05:56
Edit Download
3.11 KB lrw-r--r-- 2026-04-07 12:05:56
Edit Download
562 B lrw-r--r-- 2026-04-07 12:05:56
Edit Download
7.16 KB lrw-r--r-- 2026-04-07 12:05:56
Edit Download
2.74 KB lrw-r--r-- 2026-04-07 12:05:56
Edit Download
25.16 KB lrw-r--r-- 2026-04-07 12:05:56
Edit Download
531 B lrw-r--r-- 2026-04-07 12:05:56
Edit Download
2.57 KB lrw-r--r-- 2026-04-07 12:05:56
Edit Download
21.81 KB lrw-r--r-- 2026-04-07 12:05:56
Edit Download
2.88 KB lrw-r--r-- 2026-04-07 12:05:56
Edit Download
18.87 KB lrw-r--r-- 2026-04-07 12:05:56
Edit Download
1.79 KB lrw-r--r-- 2026-04-07 12:05:56
Edit Download
8.02 KB lrw-r--r-- 2026-04-07 12:05:56
Edit Download
2.27 KB lrw-r--r-- 2026-04-07 12:05:56
Edit Download
981 B lrw-r--r-- 2026-04-07 12:05:56
Edit Download
3.77 KB lrw-r--r-- 2026-04-07 12:05:56
Edit Download
3.18 KB lrw-r--r-- 2026-04-07 12:05:56
Edit Download
2.33 KB lrw-r--r-- 2026-04-07 12:05:56
Edit Download
1.17 KB lrw-r--r-- 2026-04-07 12:05:56
Edit Download
2.79 KB lrw-r--r-- 2026-04-07 12:05:56
Edit Download
1.68 KB lrw-r--r-- 2026-04-07 12:05:56
Edit Download
27.62 KB lrw-r--r-- 2026-04-07 12:05:56
Edit Download
5.55 KB lrw-r--r-- 2026-04-07 12:05:56
Edit Download
18.01 KB lrw-r--r-- 2026-04-07 12:05:56
Edit Download
3.87 KB lrw-r--r-- 2026-04-07 12:05:56
Edit Download
3.92 KB lrw-r--r-- 2026-04-07 12:05:56
Edit Download
4.55 KB lrw-r--r-- 2026-04-07 12:05:56
Edit Download
15.13 KB lrw-r--r-- 2026-04-07 12:05:56
Edit Download
1.40 KB lrw-r--r-- 2026-04-07 12:05:56
Edit Download
121.46 KB lrw-r--r-- 2026-04-07 12:05:56
Edit Download
658 B lrw-r--r-- 2026-04-07 12:05:56
Edit Download
14.43 KB lrw-r--r-- 2026-04-07 12:05:56
Edit Download
19.86 KB lrw-r--r-- 2026-04-07 12:05:56
Edit Download
26.37 KB lrw-r--r-- 2026-04-07 12:05:56
Edit Download
3.21 KB lrw-r--r-- 2026-04-07 12:05:56
Edit Download
14.82 KB lrw-r--r-- 2026-04-07 12:05:56
Edit Download
2.04 KB lrw-r--r-- 2026-04-07 12:05:56
Edit Download
1.26 KB lrw-r--r-- 2026-04-07 12:05:56
Edit Download
70.00 KB lrw-r--r-- 2026-04-07 12:05:56
Edit Download
10.07 KB lrw-r--r-- 2026-04-07 12:05:56
Edit Download
19.24 KB lrw-r--r-- 2026-04-07 12:05:56
Edit Download
3.00 KB lrw-r--r-- 2026-04-07 12:05:56
Edit Download
1.74 KB lrw-r--r-- 2026-04-07 12:05:56
Edit Download
7.04 KB lrw-r--r-- 2026-04-07 12:05:56
Edit Download
18.80 KB lrw-r--r-- 2026-04-07 12:05:56
Edit Download
1.36 KB lrw-r--r-- 2026-04-07 12:05:56
Edit Download
1.81 KB lrw-r--r-- 2026-04-07 12:05:56
Edit Download
69.86 KB lrw-r--r-- 2026-04-07 12:05:56
Edit Download
3.18 KB lrw-r--r-- 2026-04-07 12:05:56
Edit Download
91.77 KB lrw-r--r-- 2026-04-07 12:05:56
Edit Download
4.71 KB lrw-r--r-- 2026-04-07 12:05:56
Edit Download
50.81 KB lrw-r--r-- 2026-04-07 12:05:56
Edit Download
If ZipArchive is unavailable, a .tar will be created (no compression).