15821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)// Copyright (c) 2011 The Chromium Authors. All rights reserved.
25821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)// Use of this source code is governed by a BSD-style license that can be
35821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)// found in the LICENSE file.
45821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)
55821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)#ifndef CHROME_COMMON_NET_X509_CERTIFICATE_MODEL_H_
65821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)#define CHROME_COMMON_NET_X509_CERTIFICATE_MODEL_H_
75821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)
8c2e0dbddbe15c98d52c4786dac06cb8952a8ae6dTorne (Richard Coles)#include "net/cert/cert_type.h"
9c2e0dbddbe15c98d52c4786dac06cb8952a8ae6dTorne (Richard Coles)#include "net/cert/x509_certificate.h"
105821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)
115821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)// This namespace defines a set of functions to be used in UI-related bits of
125821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)// X509 certificates. It decouples the UI from the underlying crypto library
135821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)// (currently NSS or OpenSSL - in development).
145821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)// This is currently only used by linux, as mac / windows use their own native
155821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)// certificate viewers and crypto libraries.
165821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)namespace x509_certificate_model {
175821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)
185821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)std::string GetCertNameOrNickname(
195821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)    net::X509Certificate::OSCertHandle cert_handle);
205821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)
215821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)std::string GetTokenName(net::X509Certificate::OSCertHandle cert_handle);
225821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)
235821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)std::string GetVersion(net::X509Certificate::OSCertHandle cert_handle);
245821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)
255821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)net::CertType GetType(net::X509Certificate::OSCertHandle cert_handle);
265821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)
275821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)void GetUsageStrings(
285821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)    net::X509Certificate::OSCertHandle cert_handle,
295821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)    std::vector<std::string>* usages);
305821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)
315821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)std::string GetSerialNumberHexified(
325821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)    net::X509Certificate::OSCertHandle cert_handle,
335821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)    const std::string& alternative_text);
345821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)
355821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)std::string GetIssuerCommonName(
365821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)    net::X509Certificate::OSCertHandle cert_handle,
375821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)    const std::string& alternative_text);
385821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)
395821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)std::string GetIssuerOrgName(
405821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)    net::X509Certificate::OSCertHandle cert_handle,
415821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)    const std::string& alternative_text);
425821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)
435821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)std::string GetIssuerOrgUnitName(
445821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)    net::X509Certificate::OSCertHandle cert_handle,
455821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)    const std::string& alternative_text);
465821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)
475821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)std::string GetSubjectOrgName(
485821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)    net::X509Certificate::OSCertHandle cert_handle,
495821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)    const std::string& alternative_text);
505821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)
515821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)std::string GetSubjectOrgUnitName(
525821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)    net::X509Certificate::OSCertHandle cert_handle,
535821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)    const std::string& alternative_text);
545821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)
555821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)std::string GetSubjectCommonName(
565821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)    net::X509Certificate::OSCertHandle cert_handle,
575821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)    const std::string& alternative_text);
585821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)
595821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)bool GetTimes(net::X509Certificate::OSCertHandle cert_handle,
605821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)              base::Time* issued, base::Time* expires);
615821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)
625821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)std::string GetTitle(net::X509Certificate::OSCertHandle cert_handle);
635821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)std::string GetIssuerName(net::X509Certificate::OSCertHandle cert_handle);
645821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)std::string GetSubjectName(net::X509Certificate::OSCertHandle cert_handle);
655821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)
665821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)struct Extension {
675821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)  std::string name;
685821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)  std::string value;
695821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)};
705821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)
715821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)typedef std::vector<Extension> Extensions;
725821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)
735821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)void GetExtensions(
745821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)    const std::string& critical_label,
755821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)    const std::string& non_critical_label,
765821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)    net::X509Certificate::OSCertHandle cert_handle,
775821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)    Extensions* extensions);
785821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)
795821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)// Hash a certificate using the given algorithm, return the result as a
805821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)// colon-seperated hex string.
815821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)std::string HashCertSHA256(net::X509Certificate::OSCertHandle cert_handle);
825821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)std::string HashCertSHA1(net::X509Certificate::OSCertHandle cert_handle);
835821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)
845821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)// For host values, if they contain IDN Punycode-encoded A-labels, this will
855821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)// return a string suitable for display that contains both the original and the
865821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)// decoded U-label form.  Otherwise, the string will be returned as is.
875821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)std::string ProcessIDN(const std::string& input);
885821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)
895821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)void GetCertChainFromCert(net::X509Certificate::OSCertHandle cert_handle,
905821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)                          net::X509Certificate::OSCertHandles* cert_handles);
915821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)void DestroyCertChain(net::X509Certificate::OSCertHandles* cert_handles);
925821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)
935821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)std::string GetDerString(net::X509Certificate::OSCertHandle cert_handle);
945821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)std::string GetCMSString(const net::X509Certificate::OSCertHandles& cert_chain,
955821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)                         size_t start, size_t end);
965821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)
975821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)std::string ProcessSecAlgorithmSignature(
985821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)    net::X509Certificate::OSCertHandle cert_handle);
995821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)std::string ProcessSecAlgorithmSubjectPublicKey(
1005821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)    net::X509Certificate::OSCertHandle cert_handle);
1015821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)std::string ProcessSecAlgorithmSignatureWrap(
1025821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)    net::X509Certificate::OSCertHandle cert_handle);
1035821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)
1045821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)std::string ProcessSubjectPublicKeyInfo(
1055821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)    net::X509Certificate::OSCertHandle cert_handle);
1065821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)
1075821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)std::string ProcessRawBitsSignatureWrap(
1085821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)    net::X509Certificate::OSCertHandle cert_handle);
1095821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)
1105821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)// Format a buffer as |hex_separator| separated string, with 16 bytes on each
1115821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)// line separated using |line_separator|.
1125821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)std::string ProcessRawBytesWithSeparators(const unsigned char* data,
1135821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)                                          size_t data_length,
1145821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)                                          char hex_separator,
1155821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)                                          char line_separator);
1165821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)
1175821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)// Format a buffer as a space separated string, with 16 bytes on each line.
1185821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)std::string ProcessRawBytes(const unsigned char* data,
1195821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)                            size_t data_length);
1205821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)
1215821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)#if defined(USE_NSS)
1225821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)// Format a buffer as a space separated string, with 16 bytes on each line.
1235821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)// |data_length| is the length in bits.
1245821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)std::string ProcessRawBits(const unsigned char* data,
1255821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)                           size_t data_length);
1265821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)#endif  // USE_NSS
1275821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)
1285821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)}  // namespace x509_certificate_model
1295821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)
1305821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)#endif  // CHROME_COMMON_NET_X509_CERTIFICATE_MODEL_H_
131