]>
git.saurik.com Git - apple/security.git/blob - Security/libsecurity_ssl/lib/sslBER.h
2 * Copyright (c) 1999-2001,2005-2007,2010-2012,2014 Apple Inc. All Rights Reserved.
4 * @APPLE_LICENSE_HEADER_START@
6 * This file contains Original Code and/or Modifications of Original Code
7 * as defined in and that are subject to the Apple Public Source License
8 * Version 2.0 (the 'License'). You may not use this file except in
9 * compliance with the License. Please obtain a copy of the License at
10 * http://www.opensource.apple.com/apsl/ and read it before using this
13 * The Original Code and all software distributed under the License are
14 * distributed on an 'AS IS' basis, WITHOUT WARRANTY OF ANY KIND, EITHER
15 * EXPRESS OR IMPLIED, AND APPLE HEREBY DISCLAIMS ALL SUCH WARRANTIES,
16 * INCLUDING WITHOUT LIMITATION, ANY WARRANTIES OF MERCHANTABILITY,
17 * FITNESS FOR A PARTICULAR PURPOSE, QUIET ENJOYMENT OR NON-INFRINGEMENT.
18 * Please see the License for the specific language governing rights and
19 * limitations under the License.
21 * @APPLE_LICENSE_HEADER_END@
25 * sslBER.h - BER routines
40 * Given a PKCS-1 encoded RSA public key, extract the
41 * modulus and public exponent.
43 * RSAPublicKey ::= SEQUENCE {
44 * modulus INTEGER, -- n
45 * publicExponent INTEGER -- e }
48 OSStatus
sslDecodeRsaBlob(
49 const SSLBuffer
*blob
, /* PKCS-1 encoded */
50 SSLBuffer
*modulus
, /* data mallocd and RETURNED */
51 SSLBuffer
*exponent
); /* data mallocd and RETURNED */
54 * Given a raw modulus and exponent, cook up a
55 * BER-encoded RSA public key blob.
58 OSStatus
sslEncodeRsaBlob(
59 const SSLBuffer
*modulus
,
60 const SSLBuffer
*exponent
,
61 SSLBuffer
*blob
); /* data mallocd and RETURNED */
64 * Given a DER encoded DHParameter, extract the prime and generator.
65 * modulus and public exponent.
67 OSStatus
sslDecodeDhParams(
68 const SSLBuffer
*blob
, /* PKCS-1 encoded */
69 SSLBuffer
*prime
, /* data mallocd and RETURNED */
70 SSLBuffer
*generator
); /* data mallocd and RETURNED */
73 * Given a prime and generator, cook up a BER-encoded DHParameter blob.
75 OSStatus
sslEncodeDhParams(
76 const SSLBuffer
*prime
,
77 const SSLBuffer
*generator
,
78 SSLBuffer
*blob
); /* data mallocd and RETURNED */
81 * Given an ECDSA public key in CSSM format, extract the SSL_ECDSA_NamedCurve
82 * from its algorithm parameters.
84 OSStatus
sslEcdsaPeerCurve(
86 SSL_ECDSA_NamedCurve
*namedCurve
);
89 * Given an ECDSA public key in X509 format, extract the raw public key
90 * bits in ECPOint format.
92 OSStatus
sslEcdsaPubKeyBits(
94 SSLBuffer
*pubBits
); /* data mallocd and RETURNED */
100 #endif /* _SSL_BER_H_ */