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

CA认证

开发平台:

WINDOWS

  1. /*
  2.  * The contents of this file are subject to the Mozilla Public
  3.  * License Version 1.1 (the "License"); you may not use this file
  4.  * except in compliance with the License. You may obtain a copy of
  5.  * the License at http://www.mozilla.org/MPL/
  6.  * 
  7.  * Software distributed under the License is distributed on an "AS
  8.  * IS" basis, WITHOUT WARRANTY OF ANY KIND, either express or
  9.  * implied. See the License for the specific language governing
  10.  * rights and limitations under the License.
  11.  * 
  12.  * The Original Code is the Netscape security libraries.
  13.  * 
  14.  * The Initial Developer of the Original Code is Netscape
  15.  * Communications Corporation.  Portions created by Netscape are 
  16.  * Copyright (C) 1994-2000 Netscape Communications Corporation.  All
  17.  * Rights Reserved.
  18.  * 
  19.  * Contributor(s):
  20.  * 
  21.  * Alternatively, the contents of this file may be used under the
  22.  * terms of the GNU General Public License Version 2 or later (the
  23.  * "GPL"), in which case the provisions of the GPL are applicable 
  24.  * instead of those above.  If you wish to allow use of your 
  25.  * version of this file only under the terms of the GPL and not to
  26.  * allow others to use your version of this file under the MPL,
  27.  * indicate your decision by deleting the provisions above and
  28.  * replace them with the notice and other provisions required by
  29.  * the GPL.  If you do not delete the provisions above, a recipient
  30.  * may use your version of this file under either the MPL or the
  31.  * GPL.
  32.  */
  33. /*
  34.  * seccomon.h - common data structures for security libraries
  35.  *
  36.  * This file should have lowest-common-denominator datastructures
  37.  * for security libraries.  It should not be dependent on any other
  38.  * headers, and should not require linking with any libraries.
  39.  *
  40.  * $Id: seccomon.h,v 1.1 2000/03/31 19:39:16 relyea%netscape.com Exp $
  41.  */
  42. #ifndef _SECCOMMON_H_
  43. #define _SECCOMMON_H_
  44. #include "prtypes.h"
  45. #ifdef __cplusplus 
  46. # define SEC_BEGIN_PROTOS extern "C" {
  47. # define SEC_END_PROTOS }
  48. #else
  49. # define SEC_BEGIN_PROTOS
  50. # define SEC_END_PROTOS
  51. #endif
  52. #include "secport.h"
  53. typedef enum {
  54.     siBuffer,
  55.     siClearDataBuffer,
  56.     siCipherDataBuffer,
  57.     siDERCertBuffer,
  58.     siEncodedCertBuffer,
  59.     siDERNameBuffer,
  60.     siEncodedNameBuffer,
  61.     siAsciiNameString,
  62.     siAsciiString,
  63.     siDEROID
  64. } SECItemType;
  65. typedef struct SECItemStr SECItem;
  66. struct SECItemStr {
  67.     SECItemType type;
  68.     unsigned char *data;
  69.     unsigned int len;
  70. };
  71. /*
  72. ** A status code. Status's are used by procedures that return status
  73. ** values. Again the motivation is so that a compiler can generate
  74. ** warnings when return values are wrong. Correct testing of status codes:
  75. **
  76. ** SECStatus rv;
  77. ** rv = some_function (some_argument);
  78. ** if (rv != SECSuccess)
  79. ** do_an_error_thing();
  80. **
  81. */
  82. typedef enum _SECStatus {
  83.     SECWouldBlock = -2,
  84.     SECFailure = -1,
  85.     SECSuccess = 0
  86. } SECStatus;
  87. /*
  88. ** A comparison code. Used for procedures that return comparision
  89. ** values. Again the motivation is so that a compiler can generate
  90. ** warnings when return values are wrong.
  91. */
  92. typedef enum _SECComparison {
  93.     SECLessThan = -1,
  94.     SECEqual = 0,
  95.     SECGreaterThan = 1
  96. } SECComparison;
  97. #endif /* _SECCOMMON_H_ */