/* * The contents of this file are subject to the Mozilla Public * License Version 1.1 (the "License"); you may not use this file * except in compliance with the License. You may obtain a copy of * the License at http://www.mozilla.org/MPL/ * * Software distributed under the License is distributed on an "AS * IS" basis, WITHOUT WARRANTY OF ANY KIND, either express or * implied. See the License for the specific language governing * rights and limitations under the License. * * The Original Code is the Netscape security libraries. * * The Initial Developer of the Original Code is Netscape * Communications Corporation. Portions created by Netscape are * Copyright (C) 2000 Netscape Communications Corporation. All * Rights Reserved. * * Contributor(s): * Ian McGreer * Javier Delgadillo * * Alternatively, the contents of this file may be used under the * terms of the GNU General Public License Version 2 or later (the * "GPL"), in which case the provisions of the GPL are applicable * instead of those above. If you wish to allow use of your * version of this file only under the terms of the GPL and not to * allow others to use your version of this file under the MPL, * indicate your decision by deleting the provisions above and * replace them with the notice and other provisions required by * the GPL. If you do not delete the provisions above, a recipient * may use your version of this file under either the MPL or the * GPL. * */ #include "nsOCSPResponder.h" #include "nsCOMPtr.h" #include "nsIDateTimeFormat.h" #include "nsDateTimeFormatCID.h" #include "nsComponentManagerUtils.h" #include "nsReadableUtils.h" #include "certdb.h" /* Implementation file */ NS_IMPL_ISUPPORTS1(nsOCSPResponder, nsIOCSPResponder) nsOCSPResponder::nsOCSPResponder() { /* member initializers and constructor code */ } nsOCSPResponder::nsOCSPResponder(const PRUnichar * aCA, const PRUnichar * aURL) { mCA.Assign(aCA); mURL.Assign(aURL); } nsOCSPResponder::~nsOCSPResponder() { /* destructor code */ } /* readonly attribute */ NS_IMETHODIMP nsOCSPResponder::GetResponseSigner(PRUnichar** aCA) { NS_ENSURE_ARG(aCA); *aCA = ToNewUnicode(mCA); return NS_OK; } /* readonly attribute */ NS_IMETHODIMP nsOCSPResponder::GetServiceURL(PRUnichar** aURL) { NS_ENSURE_ARG(aURL); *aURL = ToNewUnicode(mURL); return NS_OK; } PRBool nsOCSPResponder::IncludeCert(CERTCertificate *aCert) { CERTCertTrust *trust; char *nickname; trust = aCert->trust; nickname = aCert->nickname; PR_ASSERT(trust != nsnull); // Check that trust is non-null // if (trust == nsnull) { return PR_FALSE; } if ( ( ( trust->sslFlags & CERTDB_INVISIBLE_CA ) || (trust->emailFlags & CERTDB_INVISIBLE_CA ) || (trust->objectSigningFlags & CERTDB_INVISIBLE_CA ) ) || nickname == NULL) { return PR_FALSE; } if ((trust->sslFlags & CERTDB_VALID_CA) || (trust->emailFlags & CERTDB_VALID_CA) || (trust->objectSigningFlags & CERTDB_VALID_CA)) { return PR_TRUE; } return PR_FALSE; } // CmpByCAName // // Compare two responders their token name. Returns -1, 0, 1 as // in strcmp. No token name (null) is treated as >. PRInt32 nsOCSPResponder::CmpCAName(nsIOCSPResponder *a, nsIOCSPResponder *b) { PRInt32 cmp1; nsXPIDLString aTok, bTok; a->GetResponseSigner(getter_Copies(aTok)); b->GetResponseSigner(getter_Copies(bTok)); if (aTok != nsnull && bTok != nsnull) { cmp1 = Compare(aTok, bTok); } else { cmp1 = (aTok == nsnull) ? 1 : -1; } return cmp1; } // ocsp_compare_entries // // Compare two responders. Returns -1, 0, 1 as // in strcmp. Entries with urls come before those without urls. PRInt32 nsOCSPResponder::CompareEntries(nsIOCSPResponder *a, nsIOCSPResponder *b) { nsXPIDLString aURL, bURL; nsAutoString aURLAuto, bURLAuto; a->GetServiceURL(getter_Copies(aURL)); aURLAuto.Assign(aURL); b->GetServiceURL(getter_Copies(bURL)); bURLAuto.Assign(bURL); if (!aURLAuto.IsEmpty()) { if (!bURLAuto.IsEmpty()) { return nsOCSPResponder::CmpCAName(a, b); } else { return -1; } } else { if (!bURLAuto.IsEmpty()) { return 1; } else { return nsOCSPResponder::CmpCAName(a, b); } } }