]> git.saurik.com Git - apple/security.git/blob - Keychain/SecKeychainAPIPriv.h
Security-28.tar.gz
[apple/security.git] / Keychain / SecKeychainAPIPriv.h
1 /*
2 * Copyright (c) 2000-2001 Apple Computer, Inc. All Rights Reserved.
3 *
4 * The contents of this file constitute Original Code as defined in and are
5 * subject to the Apple Public Source License Version 1.2 (the 'License').
6 * You may not use this file except in compliance with the License. Please obtain
7 * a copy of the License at http://www.apple.com/publicsource and read it before
8 * using this file.
9 *
10 * This Original Code and all software distributed under the License are
11 * distributed on an 'AS IS' basis, WITHOUT WARRANTY OF ANY KIND, EITHER EXPRESS
12 * OR IMPLIED, AND APPLE HEREBY DISCLAIMS ALL SUCH WARRANTIES, INCLUDING WITHOUT
13 * LIMITATION, ANY WARRANTIES OF MERCHANTABILITY, FITNESS FOR A PARTICULAR
14 * PURPOSE, QUIET ENJOYMENT OR NON-INFRINGEMENT. Please see the License for the
15 * specific language governing rights and limitations under the License.
16 */
17
18
19 /*
20 * SecKeychainAPIPriv.h
21 * SecurityCore
22 *
23 * Copyright: (c) 2000 by Apple Computer, Inc., all rights reserved
24 *
25 */
26 #ifndef __KEYCHAINAPIPRIV__
27 #define __KEYCHAINAPIPRIV__
28
29 #include <Security/SecKeychainAPI.h>
30
31 #if defined(__cplusplus)
32 extern "C" {
33 #endif
34
35 /* Private keychain item attributes */
36 enum
37 {
38 kSecClassItemAttr = 'clas', /* Item class (KCItemClass) */
39 kSecAliasItemAttr = 'alis', /* Alias attribute (required by CDSA). */
40 kSecProtectedDataItemAttr = 'prot', /* Item's data is protected (encrypted) (Boolean) */
41
42 /* Certificate attributes */
43 kSecSubjectItemAttr = 'subj', /* Subject distinguished name (DER-encoded data) */
44 kSecCommonNameItemAttr = 'cn ', /* Common Name (UTF8-encoded string) */
45 kSecIssuerItemAttr = 'issu', /* Issuer distinguished name (DER-encoded data) */
46 kSecSerialNumberItemAttr = 'snbr', /* Certificate serial number (DER-encoded data) */
47 kSecEMailItemAttr = 'mail', /* E-mail address (ASCII-encoded string) */
48 kSecPublicKeyHashItemAttr = 'hpky', /* Hash of public key (PublicKeyHash), 20 bytes max. */
49 kSecIssuerURLItemAttr = 'iurl', /* URL of the certificate issuer (ASCII-encoded string) */
50 /* Shared by keys and certificates */
51 kSecEncryptItemAttr = 'encr', /* Encrypt (Boolean) */
52 kSecDecryptItemAttr = 'decr', /* Decrypt (Boolean) */
53 kSecSignItemAttr = 'sign', /* Sign (Boolean) */
54 kSecVerifyItemAttr = 'veri', /* Verify (Boolean) */
55 kSecWrapItemAttr = 'wrap', /* Wrap (Boolean) */
56 kSecUnwrapItemAttr = 'unwr', /* Unwrap (Boolean) */
57 kSecStartDateItemAttr = 'sdat', /* Start Date (UInt32) */
58 kSecEndDateItemAttr = 'edat' /* End Date (UInt32) */
59 };
60
61 OSStatus SecKeychainChangePassword(SecKeychainRef keychainRef, UInt32 oldPasswordLength, const void *oldPassword, UInt32 newPasswordLength, const void *newPassword);
62
63 OSStatus SecKeychainCopyLogin(SecKeychainRef *keychainRef);
64
65 OSStatus SecKeychainLogin(UInt32 nameLength, void* name, UInt32 passwordLength, void* password);
66
67 OSStatus SecKeychainLogout();
68
69 #if defined(__cplusplus)
70 }
71 #endif
72
73 #endif // __KEYCHAINAPIPRIV__