Mercurial > projects > dstep
view dstep/security/SecTrust.d @ 16:19885b43130e
Huge update, the bridge actually works now
author | Jacob Carlborg <doob@me.com> |
---|---|
date | Sun, 03 Jan 2010 22:06:11 +0100 |
parents | 07194b026fa4 |
children |
line wrap: on
line source
/** * Copyright: Copyright (c) 2009 Jacob Carlborg. * Authors: Jacob Carlborg * Version: Initial created: Jul 22, 2009 * License: $(LINK2 http://www.boost.org/LICENSE_1_0.txt, Boost Software License 1.0) */ module dstep.security.SecTrust; import dstep.corefoundation.CoreFoundation; import dstep.coreservices.carboncore.MacTypes : OSStatus; import dstep.security.SecBase; import dstep.security.cssmapple; import dstep.security.cssmtype; alias int SecTrustUserSetting; alias OpaqueSecTrustRef* SecTrustRef; enum SecTrustResultType { kSecTrustResultInvalid, kSecTrustResultProceed, kSecTrustResultConfirm, kSecTrustResultDeny, kSecTrustResultUnspecified, kSecTrustResultRecoverableTrustFailure, kSecTrustResultFatalTrustFailure, kSecTrustResultOtherError } extern (C) { uint SecTrustGetTypeID (); int SecTrustCreateWithCertificates (CFArrayRef certificates, CFTypeRef policies, SecTrustRef* trustRef); int SecTrustSetPolicies (SecTrustRef trust, CFTypeRef policies); int SecTrustSetParameters (SecTrustRef trustRef, uint action, CFDataRef actionData); int SecTrustSetAnchorCertificates (SecTrustRef trust, CFArrayRef anchorCertificates); int SecTrustSetKeychains (SecTrustRef trust, CFTypeRef keychainOrArray); int SecTrustSetVerifyDate (SecTrustRef trust, CFDateRef verifyDate); int SecTrustEvaluate (SecTrustRef trust, SecTrustResultType* result); int SecTrustGetResult (SecTrustRef trustRef, SecTrustResultType* result, CFArrayRef* certChain, CSSM_TP_APPLE_EVIDENCE_INFO** statusChain); int SecTrustGetCssmResult (SecTrustRef trust, CSSM_TP_VERIFY_CONTEXT_RESULT_PTR* result); int SecTrustGetCssmResultCode (SecTrustRef trust, OSStatus* resultCode); int SecTrustGetTPHandle (SecTrustRef trust, CSSM_TP_HANDLE* handle); int SecTrustCopyPolicies (SecTrustRef trust, CFArrayRef* policies); int SecTrustCopyCustomAnchorCertificates (SecTrustRef trust, CFArrayRef* anchors); int SecTrustCopyAnchorCertificates (CFArrayRef* anchors); int SecTrustGetCSSMAnchorCertificates (CSSM_DATA** cssmAnchors, uint* cssmAnchorCount); int SecTrustGetUserTrust (SecCertificateRef certificate, SecPolicyRef policy, SecTrustUserSetting* trustSetting); int SecTrustSetUserTrust (SecCertificateRef certificate, SecPolicyRef policy, int trustSetting); }