2  * Copyright (c) 2000-2004,2011,2014 Apple Inc. All Rights Reserved. 
   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 
  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. 
  20 // mdsclient - friendly interface to CDSA MDS API 
  22 #include <security_cdsa_client/mdsclient.h> 
  23 #include <Security/mdspriv.h> 
  31 // The MDS access object singleton 
  33 ModuleNexus
<Directory
> mds
; 
  37 // Directory construction initializes MDS and opens the "CDSA" database 
  39 Directory::Directory() 
  40         : mMemoryFunctions(Allocator::standard()) 
  42         StLock
<Mutex
> _(mInitLock
); 
  43         CssmError::check(MDS_Initialize(&mCallerGuid
, &mMemoryFunctions
, 
  44                 this, &mCDSA
.DLHandle
)); 
  45         mCDSA
.DBHandle 
= CSSM_INVALID_HANDLE
; 
  50 // Cleanup (only called if the ModuleNexus is explicitly reset) 
  52 Directory::~Directory() 
  55                 CssmError::check(DbClose(mCDSA
)); 
  56         CssmError::check(MDS_Terminate(mds())); 
  61 // Open MDS database if needed 
  63 const MDS_DB_HANDLE 
&Directory::cdsa() const 
  65         if (mCDSA
.DBHandle 
== CSSM_INVALID_HANDLE
) { 
  66                 StLock
<Mutex
> _(mInitLock
); 
  67                 if (mCDSA
.DBHandle 
== CSSM_INVALID_HANDLE
) 
  68                         CssmError::check(DbOpen(mCDSA
.DLHandle
, MDS_CDSA_DIRECTORY_NAME
, NULL
, 
  69                                 CSSM_DB_ACCESS_READ
,    // access mode 
  71                                 NULL
,                                   // OpenParameters 
  79 // The DLAccess implementation for MDS. 
  80 // We don't ever return record data, of course; we just zero it out. 
  82 CSSM_HANDLE 
Directory::dlGetFirst(const CSSM_QUERY 
&query
, CSSM_DB_RECORD_ATTRIBUTE_DATA 
&attributes
, 
  83         CSSM_DATA 
*data
, CSSM_DB_UNIQUE_RECORD 
*&id
) 
  86         switch (CSSM_RETURN rc 
= DataGetFirst(cdsa(), &query
, &result
, &attributes
, NULL
, &id
)) { 
  91         case CSSMERR_DL_ENDOFDATA
: 
  92                 return CSSM_INVALID_HANDLE
; 
  94                 CssmError::throwMe(rc
); 
  95                 return CSSM_INVALID_HANDLE
; // placebo 
  99 bool Directory::dlGetNext(CSSM_HANDLE handle
, CSSM_DB_RECORD_ATTRIBUTE_DATA 
&attributes
, 
 100         CSSM_DATA 
*data
, CSSM_DB_UNIQUE_RECORD 
*&id
) 
 102         CSSM_RETURN rc 
= DataGetNext(cdsa(), handle
, &attributes
, NULL
, &id
); 
 108         case CSSMERR_DL_ENDOFDATA
: 
 111                 CssmError::throwMe(rc
); 
 112                 return false;   // placebo 
 116 void Directory::dlAbortQuery(CSSM_HANDLE handle
) 
 118         CssmError::check(DataAbortQuery(cdsa(), handle
)); 
 121 void Directory::dlFreeUniqueId(CSSM_DB_UNIQUE_RECORD 
*id
) 
 123         CssmError::check(FreeUniqueRecord(cdsa(), id
)); 
 126 void Directory::dlDeleteRecord(CSSM_DB_UNIQUE_RECORD 
*id
) 
 128         CssmError::check(DataDelete(cdsa(), id
)); 
 131 Allocator 
&Directory::allocator() 
 133         return Allocator::standard(); 
 138 // Public MDS operations 
 140 void Directory::install() 
 142         CssmError::check(MDS_Install(this->mds())); 
 145 void Directory::install(const MDS_InstallDefaults 
*defaults
, 
 146         const char *path
, const char *subdir
, const char *file
) 
 148         CssmError::check(MDS_InstallFile(this->mds(), defaults
, path
, subdir
, file
)); 
 151 void Directory::uninstall(const char *guid
, uint32 ssid
) 
 153         CssmError::check(MDS_RemoveSubservice(this->mds(), guid
, ssid
)); 
 157 } // end namespace MDSClient 
 158 } // end namespace Security