]> git.ipfire.org Git - thirdparty/openssl.git/blame - crypto/pkcs12/p12_init.c
Validate the SM2 digest len before use
[thirdparty/openssl.git] / crypto / pkcs12 / p12_init.c
CommitLineData
0f113f3e 1/*
b1322259 2 * Copyright 1999-2016 The OpenSSL Project Authors. All Rights Reserved.
8d8c7266 3 *
b1322259
RS
4 * Licensed under the OpenSSL license (the "License"). You may not use
5 * this file except in compliance with the License. You can obtain a copy
6 * in the file LICENSE in the source distribution or at
7 * https://www.openssl.org/source/license.html
8d8c7266
DSH
8 */
9
10#include <stdio.h>
b39fc560 11#include "internal/cryptlib.h"
ec577822 12#include <openssl/pkcs12.h>
54c38b7f 13#include "p12_lcl.h"
8d8c7266
DSH
14
15/* Initialise a PKCS12 structure to take data */
16
8afca8d9 17PKCS12 *PKCS12_init(int mode)
8d8c7266 18{
0f113f3e 19 PKCS12 *pkcs12;
75ebbd9a
RS
20
21 if ((pkcs12 = PKCS12_new()) == NULL) {
0f113f3e
MC
22 PKCS12err(PKCS12_F_PKCS12_INIT, ERR_R_MALLOC_FAILURE);
23 return NULL;
24 }
25 ASN1_INTEGER_set(pkcs12->version, 3);
26 pkcs12->authsafes->type = OBJ_nid2obj(mode);
27 switch (mode) {
28 case NID_pkcs7_data:
75ebbd9a 29 if ((pkcs12->authsafes->d.data = ASN1_OCTET_STRING_new()) == NULL) {
0f113f3e
MC
30 PKCS12err(PKCS12_F_PKCS12_INIT, ERR_R_MALLOC_FAILURE);
31 goto err;
32 }
33 break;
34 default:
35 PKCS12err(PKCS12_F_PKCS12_INIT, PKCS12_R_UNSUPPORTED_PKCS12_MODE);
36 goto err;
37 }
0f113f3e 38 return pkcs12;
e0e920b1 39
0f113f3e 40 err:
e0e920b1 41 PKCS12_free(pkcs12);
0f113f3e 42 return NULL;
8d8c7266 43}