1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 58 59 60 61 62 63 64 65 66 67 68 69 70 71 72
|
//
// Copyright (c) ZeroC, Inc. All rights reserved.
//
#ifndef ICESSL_SECURE_TRANSPORT_H
#define ICESSL_SECURE_TRANSPORT_H
#ifdef __APPLE__
#include <IceSSL/Plugin.h>
#include <Security/Security.h>
namespace IceSSL
{
namespace SecureTransport
{
class Certificate;
ICE_DEFINE_PTR(CertificatePtr, Certificate);
/**
* This convenience class is a wrapper around a native certificate.
* \headerfile IceSSL/IceSSL.h
*/
class ICESSL_API Certificate : public virtual IceSSL::Certificate
{
public:
/**
* Constructs a certificate using a native certificate.
* The Certificate class assumes ownership of the given native
* certificate.
* @param cert The certificate cert.
* @return The new certificate instance.
*/
static CertificatePtr create(SecCertificateRef cert);
/**
* Loads the certificate from a file. The certificate must use the
* PEM encoding format.
* @param file The certificate file.
* @return The new certificate instance.
* @throws CertificateReadException if the file cannot be read.
*/
static CertificatePtr load(const std::string& file);
/**
* Decodes a certificate from a string that uses the PEM encoding format.
* @param str A string containing the encoded certificate.
* @return The new certificate instance.
* @throws CertificateEncodingException if an error occurs.
*/
static CertificatePtr decode(const std::string& str);
/**
* Obtains the native X509 certificate value wrapped by this object.
* @return A reference to the native certificate.
* The returned reference is only valid for the lifetime of this
* object. You can increment the reference count of the returned
* object with CFRetain.
*/
virtual SecCertificateRef getCert() const = 0;
};
} // SecureTransport namespace end
} // IceSSL namespace end
#endif
#endif
|