--- /dev/null
+/*
+ * 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.
+ */
+
+
+//
+// keychainacl - Keychain-related ACL and credential forms
+//
+#ifndef _KEYCHAINACL
+#define _KEYCHAINACL
+
+#include <Security/cssm.h>
+#include <security_cdsa_utilities/cssmaclpod.h>
+#include <security_cdsa_utilities/cssmcred.h>
+#include <security_cdsa_utilities/cssmalloc.h>
+
+#ifdef _CPP_KEYCHAINACL
+# pragma export on
+#endif
+
+
+namespace Security
+{
+
+namespace CssmClient
+{
+
+class KeychainAclFactory
+{
+public:
+ KeychainAclFactory(Allocator &alloc);
+ ~KeychainAclFactory();
+
+ Allocator &allocator;
+
+public:
+ //
+ // Create credentials. These functions return AccessCredentials pointers.
+ //
+ const AccessCredentials *nullCredentials();
+ const AccessCredentials *keychainPromptCredentials();
+ const AccessCredentials *keychainPromptUnlockCredentials();
+ const AutoCredentials *passwordChangeCredentials(const CssmData &password);
+ const AutoCredentials *passwordUnlockCredentials(const CssmData &password);
+
+public:
+ //
+ // Create initial ACLs. Pass those to resource creation functions.
+ //
+ AclEntryInput *keychainPromptOwner(const CssmData &description);
+ AclEntryInput *anyOwner();
+ void release(AclEntryInput *input);
+
+public:
+ //
+ // Edit ACLs (in external form, as TypedLists)
+ //
+ void comment(TypedList &subject);
+ void uncomment(TypedList &subject);
+
+private:
+ AutoCredentials nullCred;
+ AutoCredentials kcCred;
+ AutoCredentials kcUnlockCred;
+};
+
+
+} // end namespace CssmClient
+
+} // end namespace Security
+
+#ifdef _CPP_KEYCHAINACL
+# pragma export off
+#endif
+
+#endif //_KEYCHAINACL