2  * Copyright (c) 2006-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  * SecFramework.c - generic non API class specific functions 
  29 /* Allows us to build genanchors against the BaseSDK. */ 
  30 #undef __ENVIRONMENT_IPHONE_OS_VERSION_MIN_REQUIRED__ 
  31 #undef __ENVIRONMENT_MAC_OS_X_VERSION_MIN_REQUIRED__ 
  34 #include "SecFramework.h" 
  35 #include <dispatch/dispatch.h> 
  36 #include <CoreFoundation/CFBundle.h> 
  37 #include <CoreFoundation/CFURLAccess.h> 
  38 #include <Security/SecRandom.h> 
  39 #include <CommonCrypto/CommonRandomSPI.h> 
  41 #include <sys/types.h> 
  43 #include <utilities/debugging.h> 
  44 #include <utilities/SecCFWrappers.h> 
  45 #include <Security/SecBase.h> 
  48 #if !(TARGET_IPHONE_SIMULATOR && defined(IPHONE_SIMULATOR_HOST_MIN_VERSION_REQUIRED) && IPHONE_SIMULATOR_HOST_MIN_VERSION_REQUIRED < 1090) 
  49 #include <sys/guarded.h> 
  50 #define USE_GUARDED_OPEN 1 
  52 #define USE_GUARDED_OPEN 0 
  56 /* Security.framework's bundle id. */ 
  57 static CFStringRef kSecFrameworkBundleID 
= CFSTR("com.apple.Security"); 
  59 CFGiblisGetSingleton(CFBundleRef
, SecFrameworkGetBundle
, bundle
,  ^{ 
  60     *bundle 
= CFRetainSafe(CFBundleGetBundleWithIdentifier(kSecFrameworkBundleID
)); 
  63 CFStringRef 
SecFrameworkCopyLocalizedString(CFStringRef key
, 
  64     CFStringRef tableName
) { 
  65     CFBundleRef bundle 
= SecFrameworkGetBundle(); 
  67         return CFBundleCopyLocalizedString(bundle
, key
, key
, tableName
); 
  69     return CFRetainSafe(key
); 
  72 CFURLRef 
SecFrameworkCopyResourceURL(CFStringRef resourceName
, 
  73         CFStringRef resourceType
, CFStringRef subDirName
) { 
  75     CFBundleRef bundle 
= SecFrameworkGetBundle(); 
  77         url 
= CFBundleCopyResourceURL(bundle
, resourceName
, 
  78                         resourceType
, subDirName
); 
  80             secwarning("resource: %@.%@ in %@ not found", resourceName
, 
  81                 resourceType
, subDirName
); 
  88 CFDataRef 
SecFrameworkCopyResourceContents(CFStringRef resourceName
, 
  89         CFStringRef resourceType
, CFStringRef subDirName
) { 
  90     CFURLRef url 
= SecFrameworkCopyResourceURL(resourceName
, resourceType
, 
  92         CFDataRef data 
= NULL
; 
  95         if (!CFURLCreateDataAndPropertiesFromResource(kCFAllocatorDefault
, 
  96             url
, &data
, NULL
, NULL
, &error
)) { 
  97             secwarning("read: %ld", (long) error
); 
 107 const SecRandomRef kSecRandomDefault 
= NULL
; 
 109 int SecRandomCopyBytes(SecRandomRef rnd
, size_t count
, uint8_t *bytes
) { 
 110     if (rnd 
!= kSecRandomDefault
) 
 112     return CCRandomCopyBytes(kCCRandomDefault
, bytes
, count
);