blob: 5fb4f17887211df6b6ed5c02f39e1e62a8a1bdaf [file] [log] [blame]
// Copyright 1995-2016 The OpenSSL Project Authors. All Rights Reserved.
//
// Licensed under the Apache License, Version 2.0 (the "License");
// you may not use this file except in compliance with the License.
// You may obtain a copy of the License at
//
// https://www.apache.org/licenses/LICENSE-2.0
//
// Unless required by applicable law or agreed to in writing, software
// distributed under the License is distributed on an "AS IS" BASIS,
// WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
// See the License for the specific language governing permissions and
// limitations under the License.
#ifndef OPENSSL_HEADER_CRYPTO_RSA_INTERNAL_H
#define OPENSSL_HEADER_CRYPTO_RSA_INTERNAL_H
#include <openssl/base.h>
#if defined(__cplusplus)
extern "C" {
#endif
int RSA_padding_check_PKCS1_OAEP_mgf1(uint8_t *out, size_t *out_len,
size_t max_out, const uint8_t *from,
size_t from_len, const uint8_t *param,
size_t param_len, const EVP_MD *md,
const EVP_MD *mgf1md);
enum rsa_pss_params_t {
// RSA-PSS using SHA-256, MGF1 with SHA-256, salt length 32.
rsa_pss_sha256,
// RSA-PSS using SHA-384, MGF1 with SHA-384, salt length 48.
rsa_pss_sha384,
// RSA-PSS using SHA-512, MGF1 with SHA-512, salt length 64.
rsa_pss_sha512,
};
// rsa_pss_params_get_md returns the hash function used with |params|. This also
// specifies the MGF-1 hash and the salt length because we do not support other
// configurations.
const EVP_MD *rsa_pss_params_get_md(rsa_pss_params_t params);
// rsa_marshal_pss_params marshals |params| as a DER-encoded RSASSA-PSS-params
// (RFC 4055). It returns one on success and zero on error.
int rsa_marshal_pss_params(CBB *cbb, rsa_pss_params_t params);
// rsa_marshal_pss_params decodes a DER-encoded RSASSA-PSS-params
// (RFC 4055). It returns one on success and zero on error. On success, it sets
// |*out| to the result. If |allow_explicit_trailer| is non-zero, an explicit
// encoding of the trailerField is allowed, although it is not valid DER.
int rsa_parse_pss_params(CBS *cbs, rsa_pss_params_t *out,
int allow_explicit_trailer);
#if defined(__cplusplus)
} // extern C
#endif
#endif // OPENSSL_HEADER_CRYPTO_RSA_INTERNAL_H