1*b077aed3SPierre Pronchery /* 2*b077aed3SPierre Pronchery * Copyright 2019-2021 The OpenSSL Project Authors. All Rights Reserved. 3*b077aed3SPierre Pronchery * 4*b077aed3SPierre Pronchery * Licensed under the Apache License 2.0 (the "License"). You may not use 5*b077aed3SPierre Pronchery * this file except in compliance with the License. You can obtain a copy 6*b077aed3SPierre Pronchery * in the file LICENSE in the source distribution or at 7*b077aed3SPierre Pronchery * https://www.openssl.org/source/license.html 8*b077aed3SPierre Pronchery */ 9*b077aed3SPierre Pronchery 10*b077aed3SPierre Pronchery #ifndef OPENSSL_ENCODER_H 11*b077aed3SPierre Pronchery # define OPENSSL_ENCODER_H 12*b077aed3SPierre Pronchery # pragma once 13*b077aed3SPierre Pronchery 14*b077aed3SPierre Pronchery # include <openssl/opensslconf.h> 15*b077aed3SPierre Pronchery 16*b077aed3SPierre Pronchery # ifndef OPENSSL_NO_STDIO 17*b077aed3SPierre Pronchery # include <stdio.h> 18*b077aed3SPierre Pronchery # endif 19*b077aed3SPierre Pronchery # include <stdarg.h> 20*b077aed3SPierre Pronchery # include <stddef.h> 21*b077aed3SPierre Pronchery # include <openssl/encodererr.h> 22*b077aed3SPierre Pronchery # include <openssl/types.h> 23*b077aed3SPierre Pronchery # include <openssl/core.h> 24*b077aed3SPierre Pronchery 25*b077aed3SPierre Pronchery # ifdef __cplusplus 26*b077aed3SPierre Pronchery extern "C" { 27*b077aed3SPierre Pronchery # endif 28*b077aed3SPierre Pronchery 29*b077aed3SPierre Pronchery OSSL_ENCODER *OSSL_ENCODER_fetch(OSSL_LIB_CTX *libctx, const char *name, 30*b077aed3SPierre Pronchery const char *properties); 31*b077aed3SPierre Pronchery int OSSL_ENCODER_up_ref(OSSL_ENCODER *encoder); 32*b077aed3SPierre Pronchery void OSSL_ENCODER_free(OSSL_ENCODER *encoder); 33*b077aed3SPierre Pronchery 34*b077aed3SPierre Pronchery const OSSL_PROVIDER *OSSL_ENCODER_get0_provider(const OSSL_ENCODER *encoder); 35*b077aed3SPierre Pronchery const char *OSSL_ENCODER_get0_properties(const OSSL_ENCODER *encoder); 36*b077aed3SPierre Pronchery const char *OSSL_ENCODER_get0_name(const OSSL_ENCODER *kdf); 37*b077aed3SPierre Pronchery const char *OSSL_ENCODER_get0_description(const OSSL_ENCODER *kdf); 38*b077aed3SPierre Pronchery int OSSL_ENCODER_is_a(const OSSL_ENCODER *encoder, const char *name); 39*b077aed3SPierre Pronchery 40*b077aed3SPierre Pronchery void OSSL_ENCODER_do_all_provided(OSSL_LIB_CTX *libctx, 41*b077aed3SPierre Pronchery void (*fn)(OSSL_ENCODER *encoder, void *arg), 42*b077aed3SPierre Pronchery void *arg); 43*b077aed3SPierre Pronchery int OSSL_ENCODER_names_do_all(const OSSL_ENCODER *encoder, 44*b077aed3SPierre Pronchery void (*fn)(const char *name, void *data), 45*b077aed3SPierre Pronchery void *data); 46*b077aed3SPierre Pronchery const OSSL_PARAM *OSSL_ENCODER_gettable_params(OSSL_ENCODER *encoder); 47*b077aed3SPierre Pronchery int OSSL_ENCODER_get_params(OSSL_ENCODER *encoder, OSSL_PARAM params[]); 48*b077aed3SPierre Pronchery 49*b077aed3SPierre Pronchery const OSSL_PARAM *OSSL_ENCODER_settable_ctx_params(OSSL_ENCODER *encoder); 50*b077aed3SPierre Pronchery OSSL_ENCODER_CTX *OSSL_ENCODER_CTX_new(void); 51*b077aed3SPierre Pronchery int OSSL_ENCODER_CTX_set_params(OSSL_ENCODER_CTX *ctx, 52*b077aed3SPierre Pronchery const OSSL_PARAM params[]); 53*b077aed3SPierre Pronchery void OSSL_ENCODER_CTX_free(OSSL_ENCODER_CTX *ctx); 54*b077aed3SPierre Pronchery 55*b077aed3SPierre Pronchery /* Utilities that help set specific parameters */ 56*b077aed3SPierre Pronchery int OSSL_ENCODER_CTX_set_passphrase(OSSL_ENCODER_CTX *ctx, 57*b077aed3SPierre Pronchery const unsigned char *kstr, size_t klen); 58*b077aed3SPierre Pronchery int OSSL_ENCODER_CTX_set_pem_password_cb(OSSL_ENCODER_CTX *ctx, 59*b077aed3SPierre Pronchery pem_password_cb *cb, void *cbarg); 60*b077aed3SPierre Pronchery int OSSL_ENCODER_CTX_set_passphrase_cb(OSSL_ENCODER_CTX *ctx, 61*b077aed3SPierre Pronchery OSSL_PASSPHRASE_CALLBACK *cb, 62*b077aed3SPierre Pronchery void *cbarg); 63*b077aed3SPierre Pronchery int OSSL_ENCODER_CTX_set_passphrase_ui(OSSL_ENCODER_CTX *ctx, 64*b077aed3SPierre Pronchery const UI_METHOD *ui_method, 65*b077aed3SPierre Pronchery void *ui_data); 66*b077aed3SPierre Pronchery int OSSL_ENCODER_CTX_set_cipher(OSSL_ENCODER_CTX *ctx, 67*b077aed3SPierre Pronchery const char *cipher_name, 68*b077aed3SPierre Pronchery const char *propquery); 69*b077aed3SPierre Pronchery int OSSL_ENCODER_CTX_set_selection(OSSL_ENCODER_CTX *ctx, int selection); 70*b077aed3SPierre Pronchery int OSSL_ENCODER_CTX_set_output_type(OSSL_ENCODER_CTX *ctx, 71*b077aed3SPierre Pronchery const char *output_type); 72*b077aed3SPierre Pronchery int OSSL_ENCODER_CTX_set_output_structure(OSSL_ENCODER_CTX *ctx, 73*b077aed3SPierre Pronchery const char *output_structure); 74*b077aed3SPierre Pronchery 75*b077aed3SPierre Pronchery /* Utilities to add encoders */ 76*b077aed3SPierre Pronchery int OSSL_ENCODER_CTX_add_encoder(OSSL_ENCODER_CTX *ctx, OSSL_ENCODER *encoder); 77*b077aed3SPierre Pronchery int OSSL_ENCODER_CTX_add_extra(OSSL_ENCODER_CTX *ctx, 78*b077aed3SPierre Pronchery OSSL_LIB_CTX *libctx, const char *propq); 79*b077aed3SPierre Pronchery int OSSL_ENCODER_CTX_get_num_encoders(OSSL_ENCODER_CTX *ctx); 80*b077aed3SPierre Pronchery 81*b077aed3SPierre Pronchery typedef struct ossl_encoder_instance_st OSSL_ENCODER_INSTANCE; 82*b077aed3SPierre Pronchery OSSL_ENCODER * 83*b077aed3SPierre Pronchery OSSL_ENCODER_INSTANCE_get_encoder(OSSL_ENCODER_INSTANCE *encoder_inst); 84*b077aed3SPierre Pronchery void * 85*b077aed3SPierre Pronchery OSSL_ENCODER_INSTANCE_get_encoder_ctx(OSSL_ENCODER_INSTANCE *encoder_inst); 86*b077aed3SPierre Pronchery const char * 87*b077aed3SPierre Pronchery OSSL_ENCODER_INSTANCE_get_output_type(OSSL_ENCODER_INSTANCE *encoder_inst); 88*b077aed3SPierre Pronchery const char * 89*b077aed3SPierre Pronchery OSSL_ENCODER_INSTANCE_get_output_structure(OSSL_ENCODER_INSTANCE *encoder_inst); 90*b077aed3SPierre Pronchery 91*b077aed3SPierre Pronchery typedef const void *OSSL_ENCODER_CONSTRUCT(OSSL_ENCODER_INSTANCE *encoder_inst, 92*b077aed3SPierre Pronchery void *construct_data); 93*b077aed3SPierre Pronchery typedef void OSSL_ENCODER_CLEANUP(void *construct_data); 94*b077aed3SPierre Pronchery 95*b077aed3SPierre Pronchery int OSSL_ENCODER_CTX_set_construct(OSSL_ENCODER_CTX *ctx, 96*b077aed3SPierre Pronchery OSSL_ENCODER_CONSTRUCT *construct); 97*b077aed3SPierre Pronchery int OSSL_ENCODER_CTX_set_construct_data(OSSL_ENCODER_CTX *ctx, 98*b077aed3SPierre Pronchery void *construct_data); 99*b077aed3SPierre Pronchery int OSSL_ENCODER_CTX_set_cleanup(OSSL_ENCODER_CTX *ctx, 100*b077aed3SPierre Pronchery OSSL_ENCODER_CLEANUP *cleanup); 101*b077aed3SPierre Pronchery 102*b077aed3SPierre Pronchery /* Utilities to output the object to encode */ 103*b077aed3SPierre Pronchery int OSSL_ENCODER_to_bio(OSSL_ENCODER_CTX *ctx, BIO *out); 104*b077aed3SPierre Pronchery #ifndef OPENSSL_NO_STDIO 105*b077aed3SPierre Pronchery int OSSL_ENCODER_to_fp(OSSL_ENCODER_CTX *ctx, FILE *fp); 106*b077aed3SPierre Pronchery #endif 107*b077aed3SPierre Pronchery int OSSL_ENCODER_to_data(OSSL_ENCODER_CTX *ctx, unsigned char **pdata, 108*b077aed3SPierre Pronchery size_t *pdata_len); 109*b077aed3SPierre Pronchery 110*b077aed3SPierre Pronchery /* 111*b077aed3SPierre Pronchery * Create the OSSL_ENCODER_CTX with an associated type. This will perform 112*b077aed3SPierre Pronchery * an implicit OSSL_ENCODER_fetch(), suitable for the object of that type. 113*b077aed3SPierre Pronchery * This is more useful than calling OSSL_ENCODER_CTX_new(). 114*b077aed3SPierre Pronchery */ 115*b077aed3SPierre Pronchery OSSL_ENCODER_CTX *OSSL_ENCODER_CTX_new_for_pkey(const EVP_PKEY *pkey, 116*b077aed3SPierre Pronchery int selection, 117*b077aed3SPierre Pronchery const char *output_type, 118*b077aed3SPierre Pronchery const char *output_struct, 119*b077aed3SPierre Pronchery const char *propquery); 120*b077aed3SPierre Pronchery 121*b077aed3SPierre Pronchery # ifdef __cplusplus 122*b077aed3SPierre Pronchery } 123*b077aed3SPierre Pronchery # endif 124*b077aed3SPierre Pronchery #endif 125