pki_pkcs12.h
上传用户:stc1860
上传日期:2007-01-12
资源大小:234k
文件大小:3k
源码类别:

CA认证

开发平台:

MultiPlatform

  1. /*
  2.  * Copyright (C) 2001 Christian Hohnstaedt.
  3.  *
  4.  *  All rights reserved.
  5.  *
  6.  *
  7.  *  Redistribution and use in source and binary forms, with or without 
  8.  *  modification, are permitted provided that the following conditions are met:
  9.  *
  10.  *  - Redistributions of source code must retain the above copyright notice,
  11.  *    this list of conditions and the following disclaimer.
  12.  *  - Redistributions in binary form must reproduce the above copyright notice,
  13.  *    this list of conditions and the following disclaimer in the documentation
  14.  *    and/or other materials provided with the distribution.
  15.  *  - Neither the name of the author nor the names of its contributors may be 
  16.  *    used to endorse or promote products derived from this software without
  17.  *    specific prior written permission.
  18.  *
  19.  *
  20.  * THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS "AS IS"
  21.  * AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO,
  22.  * THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR
  23.  * PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT OWNER OR
  24.  * CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL,
  25.  * EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO,
  26.  * PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR PROFITS;
  27.  * OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY,
  28.  * WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR
  29.  * OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF
  30.  * ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
  31.  *
  32.  *
  33.  * This program links to software with different licenses from:
  34.  *
  35.  * http://www.openssl.org which includes cryptographic software
  36.  *  written by Eric Young (eay@cryptsoft.com)"
  37.  *
  38.  * http://www.sleepycat.com
  39.  *
  40.  * http://www.trolltech.com
  41.  * 
  42.  *
  43.  *
  44.  * http://www.hohnstaedt.de/xca
  45.  * email: christian@hohnstaedt.de
  46.  *
  47.  * $Id: pki_pkcs12.h,v 1.7 2003/01/06 19:35:51 chris Exp $
  48.  *
  49.  */                           
  50. #include <iostream>
  51. #include <string>
  52. #include <openssl/rsa.h>
  53. #include <openssl/pem.h>
  54. #include <openssl/stack.h>
  55. #include <openssl/evp.h>
  56. #include <openssl/x509.h>
  57. #include <openssl/pkcs12.h>
  58. #include "pki_key.h"
  59. #include "pki_x509.h"
  60. #ifndef PKI_PKCS12_H
  61. #define PKI_PKCS12_H
  62. class pki_pkcs12: public pki_base
  63. {
  64.     friend class pki_x509;
  65.     friend class pki_key;
  66.     protected:
  67. PKCS12 *pkcs12;
  68. pki_x509 *cert;
  69. pki_key *key;
  70. STACK_OF(X509) *certstack;
  71. pem_password_cb *passcb;
  72.     public:
  73. pki_pkcs12(const string d, pki_x509 *acert, pki_key *akey, pem_password_cb *cb);   
  74. pki_pkcs12(const string fname, pem_password_cb *cb);
  75. /* destructor */
  76. ~pki_pkcs12();
  77. void addCaCert(pki_x509 *acert);
  78. pki_key *getKey(); 
  79. pki_x509 *getCert();
  80. pki_x509 *getCa(int x);
  81. int numCa(); // number of ca certs;
  82. //bool fromData(unsigned char *p, int size);
  83. //unsigned char *toData(int *size);
  84. //bool compare(pki_base *ref);
  85. void writePKCS12(const string fname);
  86. };
  87. #endif