mirror of
https://github.com/mozilla/gecko-dev.git
synced 2024-11-07 20:17:37 +00:00
1b252b2e3b
but in place. redefined the script security manager in caps and it is now generating codebase principals.
90 lines
2.3 KiB
C++
90 lines
2.3 KiB
C++
/* -*- Mode: C++; tab-width: 4; indent-tabs-mode: nil; c-basic-offset: 4 -*-
|
|
*
|
|
* The contents of this file are subject to the Netscape Public License
|
|
* Version 1.0 (the "NPL"); you may not use this file except in
|
|
* compliance with the NPL. You may obtain a copy of the NPL at
|
|
* http://www.mozilla.org/NPL/
|
|
*
|
|
* Software distributed under the NPL is distributed on an "AS IS" basis,
|
|
* WITHOUT WARRANTY OF ANY KIND, either express or implied. See the NPL
|
|
* for the specific language governing rights and limitations under the
|
|
* NPL.
|
|
*
|
|
* The Initial Developer of this code under the NPL is Netscape
|
|
* Communications Corporation. Portions created by Netscape are
|
|
* Copyright (C) 1998 Netscape Communications Corporation. All Rights
|
|
* Reserved.
|
|
*/
|
|
/*describes principals for use with signed scripts*/
|
|
#ifndef _NS_CERTIFICATE_PRINCIPAL_H_
|
|
#define _NS_CERTIFICATE_PRINCIPAL_H_
|
|
#include "jsapi.h"
|
|
#include "nsVector.h"
|
|
#include "nsIPrincipal.h"
|
|
|
|
#define NS_CERTIFICATEPRINCIPALMANAGER_CID \
|
|
{ 0x7ee2a4c0, 0x4b91, 0x11d3, \
|
|
{ 0xba, 0x18, 0x00, 0x60, 0xb0, 0xf1, 0x99, 0xa2 }}
|
|
|
|
class nsCertificatePrincipal : public nsICertificatePrincipal {
|
|
public:
|
|
|
|
NS_DEFINE_STATIC_CID_ACCESSOR(NS_CERTIFICATEPRINCIPALMANAGER_CID)
|
|
|
|
NS_DECL_ISUPPORTS
|
|
|
|
NS_IMETHOD
|
|
GetPublicKey(char ** pk);
|
|
|
|
NS_IMETHOD
|
|
GetCompanyName(char ** cn);
|
|
|
|
NS_IMETHOD
|
|
GetCertificateAuthority(char ** ca);
|
|
|
|
NS_IMETHOD
|
|
GetSerialNumber(char ** sn);
|
|
|
|
NS_IMETHOD
|
|
GetExpirationDate(char ** ed);
|
|
|
|
NS_IMETHOD
|
|
GetFingerPrint(char ** fp);
|
|
|
|
NS_IMETHOD
|
|
ToJSPrincipal(JSPrincipals * * jsprin);
|
|
|
|
NS_IMETHOD
|
|
GetType(PRInt16 * type);
|
|
|
|
NS_IMETHOD
|
|
IsSecure(PRBool * result);
|
|
|
|
NS_IMETHOD
|
|
ToString(char ** result);
|
|
|
|
NS_IMETHOD
|
|
HashCode(PRUint32 * code);
|
|
|
|
NS_IMETHOD
|
|
Equals(nsIPrincipal * other, PRBool * result);
|
|
|
|
nsCertificatePrincipal(PRInt16 type, const char * key);
|
|
nsCertificatePrincipal(PRInt16 type, const unsigned char ** certChain, PRUint32 * certChainLengths, PRUint32 noOfCerts);
|
|
virtual ~nsCertificatePrincipal(void);
|
|
|
|
protected:
|
|
PRInt16 itsType;
|
|
const char * itsKey;
|
|
nsVector * itsCertificateArray;
|
|
char * itsCompanyName;
|
|
char * itsCertificateAuthority;
|
|
char * itsSerialNumber;
|
|
char * itsExpirationDate;
|
|
char * itsFingerPrint;
|
|
char * itsNickname;
|
|
char * itsString;
|
|
};
|
|
|
|
#endif // _NS_CERTIFICATE_PRINCIPAL_H_
|