/security/nss/lib/softoken/softoknt.h

http://github.com/zpao/v8monkey · C Header · 94 lines · 37 code · 6 blank · 51 comment · 0 complexity · 3f5e8b4a6b93eb46e8fa23fe508a69f2 MD5 · raw file

  1. /*
  2. * softoknt.h - public data structures for the software token library
  3. *
  4. * ***** BEGIN LICENSE BLOCK *****
  5. * Version: MPL 1.1/GPL 2.0/LGPL 2.1
  6. *
  7. * The contents of this file are subject to the Mozilla Public License Version
  8. * 1.1 (the "License"); you may not use this file except in compliance with
  9. * the License. You may obtain a copy of the License at
  10. * http://www.mozilla.org/MPL/
  11. *
  12. * Software distributed under the License is distributed on an "AS IS" basis,
  13. * WITHOUT WARRANTY OF ANY KIND, either express or implied. See the License
  14. * for the specific language governing rights and limitations under the
  15. * License.
  16. *
  17. * The Original Code is the Netscape security libraries.
  18. *
  19. * The Initial Developer of the Original Code is
  20. * Netscape Communications Corporation.
  21. * Portions created by the Initial Developer are Copyright (C) 1994-2000
  22. * the Initial Developer. All Rights Reserved.
  23. *
  24. * Contributor(s):
  25. *
  26. * Alternatively, the contents of this file may be used under the terms of
  27. * either the GNU General Public License Version 2 or later (the "GPL"), or
  28. * the GNU Lesser General Public License Version 2.1 or later (the "LGPL"),
  29. * in which case the provisions of the GPL or the LGPL are applicable instead
  30. * of those above. If you wish to allow use of your version of this file only
  31. * under the terms of either the GPL or the LGPL, and not to allow others to
  32. * use your version of this file under the terms of the MPL, indicate your
  33. * decision by deleting the provisions above and replace them with the notice
  34. * and other provisions required by the GPL or the LGPL. If you do not delete
  35. * the provisions above, a recipient may use your version of this file under
  36. * the terms of any one of the MPL, the GPL or the LGPL.
  37. *
  38. * ***** END LICENSE BLOCK ***** */
  39. /* $Id: softoknt.h,v 1.6 2009/08/03 16:58:28 christophe.ravel.bugs%sun.com Exp $ */
  40. #ifndef _SOFTOKNT_H_
  41. #define _SOFTOKNT_H_
  42. /*
  43. * RSA block types
  44. *
  45. * The actual values are important -- they are fixed, *not* arbitrary.
  46. * The explicit value assignments are not needed (because C would give
  47. * us those same values anyway) but are included as a reminder...
  48. */
  49. typedef enum {
  50. RSA_BlockPrivate0 = 0, /* unused, really */
  51. RSA_BlockPrivate = 1, /* pad for a private-key operation */
  52. RSA_BlockPublic = 2, /* pad for a public-key operation */
  53. RSA_BlockOAEP = 3, /* use OAEP padding */
  54. /* XXX is this only for a public-key
  55. operation? If so, add "Public" */
  56. RSA_BlockRaw = 4, /* simply justify the block appropriately */
  57. RSA_BlockTotal
  58. } RSA_BlockType;
  59. #define NSS_SOFTOKEN_DEFAULT_CHUNKSIZE 2048
  60. /*
  61. * FIPS 140-2 auditing
  62. */
  63. typedef enum {
  64. NSS_AUDIT_ERROR = 3, /* errors */
  65. NSS_AUDIT_WARNING = 2, /* warning messages */
  66. NSS_AUDIT_INFO = 1 /* informational messages */
  67. } NSSAuditSeverity;
  68. typedef enum {
  69. NSS_AUDIT_ACCESS_KEY = 0,
  70. NSS_AUDIT_CHANGE_KEY,
  71. NSS_AUDIT_COPY_KEY,
  72. NSS_AUDIT_CRYPT,
  73. NSS_AUDIT_DERIVE_KEY,
  74. NSS_AUDIT_DESTROY_KEY,
  75. NSS_AUDIT_DIGEST_KEY,
  76. NSS_AUDIT_FIPS_STATE,
  77. NSS_AUDIT_GENERATE_KEY,
  78. NSS_AUDIT_INIT_PIN,
  79. NSS_AUDIT_INIT_TOKEN,
  80. NSS_AUDIT_LOAD_KEY,
  81. NSS_AUDIT_LOGIN,
  82. NSS_AUDIT_LOGOUT,
  83. NSS_AUDIT_SELF_TEST,
  84. NSS_AUDIT_SET_PIN,
  85. NSS_AUDIT_UNWRAP_KEY,
  86. NSS_AUDIT_WRAP_KEY
  87. } NSSAuditType;
  88. #endif /* _SOFTOKNT_H_ */