reSIProcate/stack  9694
MacSecurity.hxx
Go to the documentation of this file.
00001 #if !defined(RESIP_MACSECURITY_HXX)
00002 #define RESIP_MACSECURITY_HXX
00003 
00004 #if defined(HAVE_CONFIG_H)
00005   #include "config.h"
00006 #endif
00007 
00008 #include "resip/stack/ssl/Security.hxx"
00009 
00010 namespace resip
00011 {
00012 
00013 // Instead of using Mac specific data types
00014 // we pass around handles. This keeps us from
00015 // having to include Mac OS headers.
00016 typedef void * KeychainHandle;
00017 
00018 /*
00019  * Manages certificates in the Mac Keychain.
00020  */
00021 class MacSecurity : public Security
00022 {
00023    public:
00024 
00025       MacSecurity(){};
00026 
00027       // load root certificates into memory
00028       virtual void preload();
00029 
00030       // we need to stub out these functions since we don't
00031       // dynamically add or remove certificates on the mac
00032       virtual void onReadPEM(const Data&, PEMType, Data&) const
00033       { }
00034       virtual void onWritePEM(const Data&, PEMType, const Data&) const
00035       { }
00036       virtual void onRemovePEM(const Data&, PEMType) const
00037       { }
00038 
00039    protected:
00040 
00041       // Opens a search handle to certificates store in
00042       // the X509Anchors keychain
00043       KeychainHandle openSystemCertStore();
00044       
00045       // loads root certificates into memory
00046       void getCerts();
00047       
00048       void closeCertifStore(KeychainHandle searchReference);
00049 };
00050 
00051 } // namespace resip
00052 
00053 #endif // ndef RESIP_MACSECURITY_HXX
00054 
00055 /* ====================================================================
00056  * The Vovida Software License, Version 1.0 
00057  * 
00058  * Copyright (c) 2000 Vovida Networks, Inc.  All rights reserved.
00059  * 
00060  * Redistribution and use in source and binary forms, with or without
00061  * modification, are permitted provided that the following conditions
00062  * are met:
00063  * 
00064  * 1. Redistributions of source code must retain the above copyright
00065  *    notice, this list of conditions and the following disclaimer.
00066  * 
00067  * 2. Redistributions in binary form must reproduce the above copyright
00068  *    notice, this list of conditions and the following disclaimer in
00069  *    the documentation and/or other materials provided with the
00070  *    distribution.
00071  * 
00072  * 3. The names "VOCAL", "Vovida Open Communication Application Library",
00073  *    and "Vovida Open Communication Application Library (VOCAL)" must
00074  *    not be used to endorse or promote products derived from this
00075  *    software without prior written permission. For written
00076  *    permission, please contact vocal@vovida.org.
00077  *
00078  * 4. Products derived from this software may not be called "VOCAL", nor
00079  *    may "VOCAL" appear in their name, without prior written
00080  *    permission of Vovida Networks, Inc.
00081  * 
00082  * THIS SOFTWARE IS PROVIDED "AS IS" AND ANY EXPRESSED OR IMPLIED
00083  * WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED WARRANTIES
00084  * OF MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE, TITLE AND
00085  * NON-INFRINGEMENT ARE DISCLAIMED.  IN NO EVENT SHALL VOVIDA
00086  * NETWORKS, INC. OR ITS CONTRIBUTORS BE LIABLE FOR ANY DIRECT DAMAGES
00087  * IN EXCESS OF $1,000, NOR FOR ANY INDIRECT, INCIDENTAL, SPECIAL,
00088  * EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO,
00089  * PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR
00090  * PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY
00091  * OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT
00092  * (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE
00093  * USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH
00094  * DAMAGE.
00095  * 
00096  * ====================================================================
00097  * 
00098  * This software consists of voluntary contributions made by Vovida
00099  * Networks, Inc. and many individuals on behalf of Vovida Networks,
00100  * Inc.  For more information on Vovida Networks, Inc., please see
00101  * <http://www.vovida.org/>.
00102  *
00103  */