+++ /dev/null
-/*
- * Copyright (c) 2000-2001 Apple Computer, 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