]> git.saurik.com Git - apple/security.git/blobdiff - Security/libsecurity_cdsa_client/lib/keychainacl.h
Security-57031.1.35.tar.gz
[apple/security.git] / Security / libsecurity_cdsa_client / lib / keychainacl.h
diff --git a/Security/libsecurity_cdsa_client/lib/keychainacl.h b/Security/libsecurity_cdsa_client/lib/keychainacl.h
new file mode 100644 (file)
index 0000000..05e1354
--- /dev/null
@@ -0,0 +1,89 @@
+/*
+ * 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