]> git.saurik.com Git - apple/security.git/blobdiff - Security/libsecurity_apple_cspdl/lib/SSDLSession.h
Security-57031.1.35.tar.gz
[apple/security.git] / Security / libsecurity_apple_cspdl / lib / SSDLSession.h
diff --git a/Security/libsecurity_apple_cspdl/lib/SSDLSession.h b/Security/libsecurity_apple_cspdl/lib/SSDLSession.h
new file mode 100644 (file)
index 0000000..6ecb295
--- /dev/null
@@ -0,0 +1,194 @@
+/*
+ * Copyright (c) 2000-2001,2011,2014 Apple Inc. All Rights Reserved.
+ * 
+ * The contents of this file constitute Original Code as defined in and are
+ * subject to the Apple Public Source License Version 1.2 (the 'License').
+ * You may not use this file except in compliance with the License. Please obtain
+ * a copy of the License at http://www.apple.com/publicsource and read it before
+ * using this file.
+ * 
+ * This Original Code and all software distributed under the License are
+ * distributed on an 'AS IS' basis, WITHOUT WARRANTY OF ANY KIND, EITHER EXPRESS
+ * OR IMPLIED, AND APPLE HEREBY DISCLAIMS ALL SUCH WARRANTIES, INCLUDING WITHOUT
+ * LIMITATION, ANY WARRANTIES OF MERCHANTABILITY, FITNESS FOR A PARTICULAR
+ * PURPOSE, QUIET ENJOYMENT OR NON-INFRINGEMENT. Please see the License for the
+ * specific language governing rights and limitations under the License.
+ */
+
+
+//
+// SSDLSession.h - DL session for security server CSP/DL.
+//
+#ifndef _H_SSDLSESSION
+#define _H_SSDLSESSION
+
+#include <security_cdsa_plugin/DLsession.h>
+
+#include "SSDatabase.h"
+
+class CSPDLPlugin;
+class SSCSPDLSession;
+
+class SSDLSession : public DLPluginSession
+{
+public:
+       SSCSPDLSession &mSSCSPDLSession;
+
+       SSDLSession(CSSM_MODULE_HANDLE handle,
+                               CSPDLPlugin &plug,
+                               const CSSM_VERSION &version,
+                               uint32 subserviceId,
+                               CSSM_SERVICE_TYPE subserviceType,
+                               CSSM_ATTACH_FLAGS attachFlags,
+                               const CSSM_UPCALLS &upcalls,
+                               DatabaseManager &databaseManager,
+                               SSCSPDLSession &ssCSPDLSession);
+       ~SSDLSession();
+
+       SecurityServer::ClientSession &clientSession()
+       { return mClientSession; }
+    void GetDbNames(CSSM_NAME_LIST_PTR &NameList);
+    void FreeNameList(CSSM_NAME_LIST &NameList);
+    void DbDelete(const char *DbName,
+                  const CSSM_NET_ADDRESS *DbLocation,
+                  const AccessCredentials *AccessCred);
+    void DbCreate(const char *DbName,
+                  const CSSM_NET_ADDRESS *DbLocation,
+                  const CSSM_DBINFO &DBInfo,
+                  CSSM_DB_ACCESS_TYPE AccessRequest,
+                  const CSSM_RESOURCE_CONTROL_CONTEXT *CredAndAclEntry,
+                  const void *OpenParameters,
+                  CSSM_DB_HANDLE &DbHandle);
+    void CreateWithBlob(const char *DbName,
+                                               const CSSM_NET_ADDRESS *DbLocation,
+                                               const CSSM_DBINFO &DBInfo,
+                                               CSSM_DB_ACCESS_TYPE AccessRequest,
+                                               const void *OpenParameters,
+                                               const CSSM_DATA &blob,
+                                               CSSM_DB_HANDLE &DbHandle);
+    void DbOpen(const char *DbName,
+                const CSSM_NET_ADDRESS *DbLocation,
+                CSSM_DB_ACCESS_TYPE AccessRequest,
+                const AccessCredentials *AccessCred,
+                const void *OpenParameters,
+                CSSM_DB_HANDLE &DbHandle);
+    void DbClose(CSSM_DB_HANDLE DBHandle);
+    void CreateRelation(CSSM_DB_HANDLE DBHandle,
+                        CSSM_DB_RECORDTYPE RelationID,
+                        const char *RelationName,
+                        uint32 NumberOfAttributes,
+                        const CSSM_DB_SCHEMA_ATTRIBUTE_INFO *pAttributeInfo,
+                        uint32 NumberOfIndexes,
+                        const CSSM_DB_SCHEMA_INDEX_INFO &pIndexInfo);
+    void DestroyRelation(CSSM_DB_HANDLE DBHandle,
+                         CSSM_DB_RECORDTYPE RelationID);
+
+    void Authenticate(CSSM_DB_HANDLE DBHandle,
+                      CSSM_DB_ACCESS_TYPE AccessRequest,
+                      const AccessCredentials &AccessCred);
+    void GetDbAcl(CSSM_DB_HANDLE DBHandle,
+                  const CSSM_STRING *SelectionTag,
+                  uint32 &NumberOfAclInfos,
+                  CSSM_ACL_ENTRY_INFO_PTR &AclInfos);
+    void ChangeDbAcl(CSSM_DB_HANDLE DBHandle,
+                     const AccessCredentials &AccessCred,
+                     const CSSM_ACL_EDIT &AclEdit);
+    void GetDbOwner(CSSM_DB_HANDLE DBHandle,
+                    CSSM_ACL_OWNER_PROTOTYPE &Owner);
+    void ChangeDbOwner(CSSM_DB_HANDLE DBHandle,
+                       const AccessCredentials &AccessCred,
+                       const CSSM_ACL_OWNER_PROTOTYPE &NewOwner);
+    void GetDbNameFromHandle(CSSM_DB_HANDLE DBHandle,
+                             char **DbName);
+    void DataInsert(CSSM_DB_HANDLE DBHandle,
+                    CSSM_DB_RECORDTYPE RecordType,
+                    const CSSM_DB_RECORD_ATTRIBUTE_DATA *Attributes,
+                    const CssmData *Data,
+                    CSSM_DB_UNIQUE_RECORD_PTR &UniqueId);
+    void DataDelete(CSSM_DB_HANDLE DBHandle,
+                    const CSSM_DB_UNIQUE_RECORD &UniqueRecordIdentifier);
+    void DataModify(CSSM_DB_HANDLE DBHandle,
+                    CSSM_DB_RECORDTYPE RecordType,
+                    CSSM_DB_UNIQUE_RECORD &UniqueRecordIdentifier,
+                    const CSSM_DB_RECORD_ATTRIBUTE_DATA *AttributesToBeModified,
+                    const CssmData *DataToBeModified,
+                    CSSM_DB_MODIFY_MODE ModifyMode);
+    CSSM_HANDLE DataGetFirst(CSSM_DB_HANDLE DBHandle,
+                             const CssmQuery *Query,
+                             CSSM_DB_RECORD_ATTRIBUTE_DATA_PTR Attributes,
+                             CssmData *Data,
+                             CSSM_DB_UNIQUE_RECORD_PTR &UniqueId);
+    bool DataGetNext(CSSM_DB_HANDLE DBHandle,
+                     CSSM_HANDLE ResultsHandle,
+                     CSSM_DB_RECORD_ATTRIBUTE_DATA_PTR Attributes,
+                     CssmData *Data,
+                     CSSM_DB_UNIQUE_RECORD_PTR &UniqueId);
+    void DataAbortQuery(CSSM_DB_HANDLE DBHandle,
+                        CSSM_HANDLE ResultsHandle);
+    void DataGetFromUniqueRecordId(CSSM_DB_HANDLE DBHandle,
+                                   const CSSM_DB_UNIQUE_RECORD &UniqueRecord,
+                                   CSSM_DB_RECORD_ATTRIBUTE_DATA_PTR Attributes,
+                                   CssmData *Data);
+    void FreeUniqueRecord(CSSM_DB_HANDLE DBHandle,
+                          CSSM_DB_UNIQUE_RECORD &UniqueRecord);
+    void PassThrough(CSSM_DB_HANDLE DBHandle,
+                     uint32 PassThroughId,
+                     const void *InputParams,
+                     void **OutputParams);
+
+       Allocator &allocator() { return *static_cast<DatabaseSession *>(this); }
+
+       SSDatabase findDbHandle(CSSM_DB_HANDLE inDbHandle);
+protected:
+       CSSM_DB_HANDLE makeDbHandle(SSDatabase &inDb);
+       SSDatabase killDbHandle(CSSM_DB_HANDLE inDbHandle);
+
+       CSSM_DB_ATTRIBUTE_DATA_PTR reconstructRecordFromBlob (const CSSM_DATA& blob,
+                                                                                                                 CssmDataContainer &recordData,
+                                                                                                                 uint32 &numAttributes);
+
+       void getWrappedAttributesAndData (SSDatabase &db,
+                                                                         CSSM_DB_RECORDTYPE recordType,
+                                                                         CSSM_DB_UNIQUE_RECORD_PTR recordPtr,
+                                                                         CssmDataContainer &output,
+                                                                         CSSM_DATA *blobData);
+                                                               
+       void unwrapAttributesAndData (uint32 &numAttributes,
+                                                                 CSSM_DB_ATTRIBUTE_DATA_PTR &attributes,
+                                                                 CSSM_DATA &data,
+                                                                 CSSM_DATA &input);
+       
+       void cleanupAttributes (uint32 numAttributes, CSSM_DB_ATTRIBUTE_DATA_PTR attributes);
+       
+       void getUniqueIdForSymmetricKey (SSDatabase &db, CSSM_DATA &label,
+                                                                        CSSM_DB_UNIQUE_RECORD_PTR &uniqueRecord);
+
+       void getCorrespondingSymmetricKey (SSDatabase &db, CSSM_DATA& label, CssmDataContainer &key);
+       
+       void doGetWithoutEncryption (SSDatabase &db, const void* inInputParams, void **outOutputParams);
+       void doModifyWithoutEncryption (SSDatabase &db, const void* inInputParams, void **outOutputParams);
+       void doInsertWithoutEncryption (SSDatabase &db, const void* inInputParams, void** outOutputParams);
+       void doConvertRecordIdentifier (SSDatabase &db, const void* inInputParams, void **outOutputParams);
+
+       Mutex mDbHandleLock;
+       typedef map<CSSM_DB_HANDLE, SSDatabase> DbHandleMap;
+       DbHandleMap mDbHandleMap;
+
+       CSSM_DB_UNIQUE_RECORD_PTR makeSSUniqueRecord(SSUniqueRecord &uniqueId);
+       SSUniqueRecord killSSUniqueRecord(CSSM_DB_UNIQUE_RECORD &inUniqueRecord);
+       SSUniqueRecord findSSUniqueRecord(const CSSM_DB_UNIQUE_RECORD &inUniqueRecord);
+
+       CSSM_DB_UNIQUE_RECORD_PTR createUniqueRecord(CSSM_HANDLE ref);
+       CSSM_HANDLE parseUniqueRecord(const CSSM_DB_UNIQUE_RECORD &inUniqueRecord);
+       void freeUniqueRecord(CSSM_DB_UNIQUE_RECORD &inUniqueRecord);
+
+       Mutex mSSUniqueRecordLock;
+       typedef map<CSSM_HANDLE, SSUniqueRecord> SSUniqueRecordMap;
+       SSUniqueRecordMap mSSUniqueRecordMap;
+
+       CssmClient::DL mDL;
+       SecurityServer::ClientSession mClientSession;
+};
+
+
+#endif // _H_SSDLSESSION