blob: 648bb2332d459fa8cf0485f58e1e7a1d1ebe3a16 [file] [log] [blame]
/*
* Copyright (C) 2010 Apple Inc. All rights reserved.
*
* Redistribution and use in source and binary forms, with or without
* modification, are permitted provided that the following conditions
* are met:
* 1. Redistributions of source code must retain the above copyright
* notice, this list of conditions and the following disclaimer.
* 2. Redistributions in binary form must reproduce the above copyright
* notice, this list of conditions and the following disclaimer in the
* documentation and/or other materials provided with the distribution.
*
* THIS SOFTWARE IS PROVIDED BY APPLE INC. AND ITS CONTRIBUTORS ``AS IS''
* AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO,
* THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR
* PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL APPLE INC. OR ITS CONTRIBUTORS
* BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR
* CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF
* SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS
* INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN
* CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE)
* ARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF
* THE POSSIBILITY OF SUCH DAMAGE.
*/
#ifndef ArgumentCodersCF_h
#define ArgumentCodersCF_h
#include <Security/SecCertificate.h>
#include <Security/SecTrust.h>
#include <wtf/RetainPtr.h>
#if HAVE(SEC_KEYCHAIN)
#include <Security/SecKeychainItem.h>
#endif
namespace IPC {
class Encoder;
class Decoder;
// CFArrayRef
void encode(Encoder&, CFArrayRef);
bool decode(Decoder&, RetainPtr<CFArrayRef>& result);
// CFBooleanRef
void encode(Encoder&, CFBooleanRef);
bool decode(Decoder&, RetainPtr<CFBooleanRef>& result);
// CFDataRef
void encode(Encoder&, CFDataRef);
bool decode(Decoder&, RetainPtr<CFDataRef>& result);
// CFDateRef
void encode(Encoder&, CFDateRef);
bool decode(Decoder&, RetainPtr<CFDateRef>& result);
// CFDictionaryRef
void encode(Encoder&, CFDictionaryRef);
bool decode(Decoder&, RetainPtr<CFDictionaryRef>& result);
// CFNumberRef
void encode(Encoder&, CFNumberRef);
bool decode(Decoder&, RetainPtr<CFNumberRef>& result);
// CFStringRef
void encode(Encoder&, CFStringRef);
bool decode(Decoder&, RetainPtr<CFStringRef>& result);
// CFTypeRef
void encode(Encoder&, CFTypeRef);
bool decode(Decoder&, RetainPtr<CFTypeRef>& result);
// CFURLRef
void encode(Encoder&, CFURLRef);
bool decode(Decoder&, RetainPtr<CFURLRef>& result);
// SecCertificateRef
void encode(Encoder&, SecCertificateRef);
bool decode(Decoder&, RetainPtr<SecCertificateRef>& result);
// SecIdentityRef
void encode(Encoder&, SecIdentityRef);
bool decode(Decoder&, RetainPtr<SecIdentityRef>& result);
#if HAVE(SEC_KEYCHAIN)
// SecKeychainItemRef
void encode(Encoder&, SecKeychainItemRef);
bool decode(Decoder&, RetainPtr<SecKeychainItemRef>& result);
#endif
#if HAVE(SEC_ACCESS_CONTROL)
// SecAccessControlRef
void encode(Encoder&, SecAccessControlRef);
bool decode(Decoder&, RetainPtr<SecAccessControlRef>& result);
#endif
#if HAVE(SEC_TRUST_SERIALIZATION)
// SecTrustRef
void encode(Encoder&, SecTrustRef);
bool decode(Decoder&, RetainPtr<SecTrustRef>&);
#endif
#if PLATFORM(IOS_FAMILY)
void setAllowsDecodingSecKeyRef(bool);
#endif
CFTypeRef tokenNullTypeRef();
} // namespace IPC
#endif // ArgumentCodersCF_h