hasht.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.  * hasht.h - public data structures for the hashing library
  34.  *
  35.  * $Id: hasht.h,v 1.1 2000/03/31 19:45:11 relyea%netscape.com Exp $
  36.  */
  37. #ifndef _HASHT_H_
  38. #define _HASHT_H_
  39. /* Opaque objects */
  40. typedef struct SECHashObjectStr SECHashObject;
  41. typedef struct HASHContextStr HASHContext;
  42. /*
  43.  * The hash functions the security library supports
  44.  * NOTE the order must match the definition of SECHashObjects[]!
  45.  */
  46. typedef enum {
  47.     HASH_AlgNULL,
  48.     HASH_AlgMD2,
  49.     HASH_AlgMD5,
  50.     HASH_AlgSHA1,
  51.     HASH_AlgTOTAL
  52. } HASH_HashType;
  53. /*
  54.  * Number of bytes each hash algorithm produces
  55.  */
  56. #define MD2_LENGTH 16
  57. #define MD5_LENGTH 16
  58. #define SHA1_LENGTH 20
  59. /*
  60.  * Structure to hold hash computation info and routines
  61.  */
  62. struct SECHashObjectStr {
  63.     unsigned int length;
  64.     void * (*create)(void);
  65.     void * (*clone)(void *);
  66.     void (*destroy)(void *, PRBool);
  67.     void (*begin)(void *);
  68.     void (*update)(void *, const unsigned char *, unsigned int);
  69.     void (*end)(void *, unsigned char *, unsigned int *, unsigned int);
  70. };
  71. struct HASHContextStr {
  72.     struct SECHashObjectStr *hashobj;
  73.     void *hash_context;
  74. };
  75. extern SECHashObject SECHashObjects[];
  76. /*only those functions below the PKCS #11 line should use SECRawHashObjects*/
  77. extern SECHashObject SECRawHashObjects[];
  78. #endif /* _HASHT_H_ */