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

CA认证

开发平台:

WINDOWS

  1. /*
  2.  * Return SSLKEAType derived from cert's Public Key algorithm info.
  3.  *
  4.  * The contents of this file are subject to the Mozilla Public
  5.  * License Version 1.1 (the "License"); you may not use this file
  6.  * except in compliance with the License. You may obtain a copy of
  7.  * the License at http://www.mozilla.org/MPL/
  8.  * 
  9.  * Software distributed under the License is distributed on an "AS
  10.  * IS" basis, WITHOUT WARRANTY OF ANY KIND, either express or
  11.  * implied. See the License for the specific language governing
  12.  * rights and limitations under the License.
  13.  * 
  14.  * The Original Code is the Netscape security libraries.
  15.  * 
  16.  * The Initial Developer of the Original Code is Netscape
  17.  * Communications Corporation.  Portions created by Netscape are 
  18.  * Copyright (C) 1994-2000 Netscape Communications Corporation.  All
  19.  * Rights Reserved.
  20.  * 
  21.  * Contributor(s):
  22.  * 
  23.  * Alternatively, the contents of this file may be used under the
  24.  * terms of the GNU General Public License Version 2 or later (the
  25.  * "GPL"), in which case the provisions of the GPL are applicable 
  26.  * instead of those above.  If you wish to allow use of your 
  27.  * version of this file only under the terms of the GPL and not to
  28.  * allow others to use your version of this file under the MPL,
  29.  * indicate your decision by deleting the provisions above and
  30.  * replace them with the notice and other provisions required by
  31.  * the GPL.  If you do not delete the provisions above, a recipient
  32.  * may use your version of this file under either the MPL or the
  33.  * GPL.
  34.  *
  35.  # $Id: nsskea.c,v 1.1 2000/03/31 19:32:56 relyea%netscape.com Exp $
  36.  */
  37. #include "cert.h"
  38. #include "ssl.h" /* for SSLKEAType */
  39. #include "secoid.h"
  40. SSLKEAType
  41. NSS_FindCertKEAType(CERTCertificate * cert)
  42. {
  43.   SSLKEAType keaType = kt_null; 
  44.   int tag;
  45.   
  46.   if (!cert) goto loser;
  47.   
  48.   tag = SECOID_GetAlgorithmTag(&(cert->subjectPublicKeyInfo.algorithm));
  49.   
  50.   switch (tag) {
  51.   case SEC_OID_X500_RSA_ENCRYPTION:
  52.   case SEC_OID_PKCS1_RSA_ENCRYPTION:
  53.     keaType = kt_rsa;
  54.     break;
  55.   case SEC_OID_MISSI_KEA_DSS_OLD:
  56.   case SEC_OID_MISSI_KEA_DSS:
  57.   case SEC_OID_MISSI_DSS_OLD:
  58.   case SEC_OID_MISSI_DSS:
  59.     keaType = kt_fortezza;
  60.     break;
  61.   case SEC_OID_X942_DIFFIE_HELMAN_KEY:
  62.     keaType = kt_dh;
  63.     break;
  64.   default:
  65.     keaType = kt_null;
  66.   }
  67.   
  68.  loser:
  69.   
  70.   return keaType;
  71. }