2  * Copyright (c) 2015 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  @header SOSBackupSliceKeyBag.h - View Bags - backup bags for views 
  28 #ifndef _sec_SOSBackupSliceKeyBag_ 
  29 #define _sec_SOSBackupSliceKeyBag_ 
  31 #include <CoreFoundation/CoreFoundation.h> 
  32 #include <Security/SecureObjectSync/SOSPeerInfo.h> 
  34 // We don't have a portable header (particularly for the SIM) so for now we define the one type we need. 
  35 // This should be fixed when we get a portable AKS interface. 
  36 typedef int32_t bskb_keybag_handle_t
; 
  38 typedef struct __OpaqueSOSBackupSliceKeyBag 
*SOSBackupSliceKeyBagRef
; 
  40 CFTypeRef 
SOSBackupSliceKeyBageGetTypeID(void); 
  42 SOSBackupSliceKeyBagRef 
SOSBackupSliceKeyBagCreate(CFAllocatorRef allocator
, CFSetRef peers
, CFErrorRef
* error
); 
  43 SOSBackupSliceKeyBagRef 
SOSBackupSliceKeyBagCreateDirect(CFAllocatorRef allocator
, CFDataRef aks_bag
, CFErrorRef 
*error
); 
  45 SOSBackupSliceKeyBagRef 
SOSBackupSliceKeyBagCreateFromData(CFAllocatorRef allocator
, CFDataRef data
, CFErrorRef 
*error
); 
  47 CFDataRef 
SOSBSKBCopyEncoded(SOSBackupSliceKeyBagRef BackupSliceKeyBag
, CFErrorRef
* error
); 
  50 bool SOSBSKBIsDirect(SOSBackupSliceKeyBagRef backupSliceKeyBag
); 
  52 CFSetRef 
SOSBSKBGetPeers(SOSBackupSliceKeyBagRef backupSliceKeyBag
); 
  56 CFDataRef 
SOSBSKBCopyAKSBag(SOSBackupSliceKeyBagRef backupSliceKeyBag
, CFErrorRef
* error
); 
  60 const uint8_t* der_decode_BackupSliceKeyBag(CFAllocatorRef allocator
, 
  61                                   SOSBackupSliceKeyBagRef
* BackupSliceKeyBag
, CFErrorRef 
*error
, 
  62                                   const uint8_t* der
, const uint8_t *der_end
); 
  64 size_t der_sizeof_BackupSliceKeyBag(SOSBackupSliceKeyBagRef BackupSliceKeyBag
, CFErrorRef 
*error
); 
  65 uint8_t* der_encode_BackupSliceKeyBag(SOSBackupSliceKeyBagRef BackupSliceKeyBag
, CFErrorRef 
*error
, 
  66                             const uint8_t *der
, uint8_t *der_end
); 
  68 bskb_keybag_handle_t 
SOSBSKBLoadAndUnlockWithPeerIDAndSecret(SOSBackupSliceKeyBagRef backupSliceKeyBag
, 
  69                                                              CFStringRef peerID
, CFDataRef peerSecret
, 
  72 bskb_keybag_handle_t 
SOSBSKBLoadAndUnlockWithPeerSecret(SOSBackupSliceKeyBagRef backupSliceKeyBag
, 
  73                                                         SOSPeerInfoRef peer
, CFDataRef peerSecret
, 
  76 bskb_keybag_handle_t 
SOSBSKBLoadAndUnlockWithDirectSecret(SOSBackupSliceKeyBagRef backupSliceKeyBag
, 
  77                                                           CFDataRef directSecret
, 
  80 // Utilities for backup keys 
  81 bool SOSBSKBIsGoodBackupPublic(CFDataRef publicKey
, CFErrorRef 
*error
); 
  83 #endif /* defined(_sec_SOSBackupSliceKeyBag_) */