15821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)/* ***** BEGIN LICENSE BLOCK ***** 25821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles) * Version: MPL 1.1/GPL 2.0/LGPL 2.1 35821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles) * 45821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles) * The contents of this file are subject to the Mozilla Public License Version 55821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles) * 1.1 (the "License"); you may not use this file except in compliance with 65821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles) * the License. You may obtain a copy of the License at 75821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles) * http://www.mozilla.org/MPL/ 85821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles) * 95821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles) * Software distributed under the License is distributed on an "AS IS" basis, 105821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles) * WITHOUT WARRANTY OF ANY KIND, either express or implied. See the License 115821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles) * for the specific language governing rights and limitations under the 125821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles) * License. 135821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles) * 145821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles) * The Original Code is the Netscape security libraries. 155821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles) * 165821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles) * The Initial Developer of the Original Code is 175821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles) * Netscape Communications Corporation. 185821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles) * Portions created by the Initial Developer are Copyright (C) 2000 195821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles) * the Initial Developer. All Rights Reserved. 205821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles) * 215821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles) * Contributor(s): 225821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles) * John Gardiner Myers <jgmyers@speakeasy.net> 235821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles) * 245821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles) * Alternatively, the contents of this file may be used under the terms of 255821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles) * either the GNU General Public License Version 2 or later (the "GPL"), or 265821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles) * the GNU Lesser General Public License Version 2.1 or later (the "LGPL"), 275821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles) * in which case the provisions of the GPL or the LGPL are applicable instead 285821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles) * of those above. If you wish to allow use of your version of this file only 295821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles) * under the terms of either the GPL or the LGPL, and not to allow others to 305821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles) * use your version of this file under the terms of the MPL, indicate your 315821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles) * decision by deleting the provisions above and replace them with the notice 325821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles) * and other provisions required by the GPL or the LGPL. If you do not delete 335821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles) * the provisions above, a recipient may use your version of this file under 345821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles) * the terms of any one of the MPL, the GPL or the LGPL. 355821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles) * 365821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles) * ***** END LICENSE BLOCK ***** */ 375821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles) 385821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)#include "chrome/third_party/mozilla_security_manager/nsUsageArrayHelper.h" 395821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles) 406e8cce623b6e4fe0c9e4af605d675dd9d0338c38Torne (Richard Coles)#include "chrome/grit/generated_resources.h" 415821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)#include "ui/base/l10n/l10n_util.h" 425821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles) 435821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)namespace mozilla_security_manager { 445821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles) 455821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)void GetCertUsageStrings(CERTCertificate* cert, std::vector<std::string>* out) { 465821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles) SECCertificateUsage usages = 0; 475821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles) // TODO(wtc): See if we should use X509Certificate::Verify instead. 485821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles) if (CERT_VerifyCertificateNow(CERT_GetDefaultCertDB(), cert, PR_TRUE, 495821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles) certificateUsageCheckAllUsages, 505821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles) NULL, &usages) == SECSuccess) { 515821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles) static const struct { 525821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles) SECCertificateUsage usage; 535821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles) int string_id; 545821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles) } usage_string_map[] = { 555821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles) {certificateUsageSSLClient, IDS_CERT_USAGE_SSL_CLIENT}, 565821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles) {certificateUsageSSLServer, IDS_CERT_USAGE_SSL_SERVER}, 575821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles) {certificateUsageSSLServerWithStepUp, 585821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles) IDS_CERT_USAGE_SSL_SERVER_WITH_STEPUP}, 595821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles) {certificateUsageEmailSigner, IDS_CERT_USAGE_EMAIL_SIGNER}, 605821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles) {certificateUsageEmailRecipient, IDS_CERT_USAGE_EMAIL_RECEIVER}, 615821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles) {certificateUsageObjectSigner, IDS_CERT_USAGE_OBJECT_SIGNER}, 625821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles) {certificateUsageSSLCA, IDS_CERT_USAGE_SSL_CA}, 635821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles) {certificateUsageStatusResponder, IDS_CERT_USAGE_STATUS_RESPONDER}, 645821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles) }; 655821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles) for (size_t i = 0; i < ARRAYSIZE_UNSAFE(usage_string_map); ++i) { 665821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles) if (usages & usage_string_map[i].usage) 675821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles) out->push_back(l10n_util::GetStringUTF8( 685821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles) usage_string_map[i].string_id)); 695821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles) } 705821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles) } 715821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)} 725821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles) 735821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)} // namespace mozilla_security_manager 74