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)
5c2e0dbddbe15c98d52c4786dac06cb8952a8ae6dTorne (Richard Coles)#include "net/cert/test_root_certs.h"
65821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)
75821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)#include <openssl/err.h>
85821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)#include <openssl/x509v3.h>
95821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)
105821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)#include "base/location.h"
115821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)#include "base/logging.h"
125821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)#include "crypto/openssl_util.h"
13c2e0dbddbe15c98d52c4786dac06cb8952a8ae6dTorne (Richard Coles)#include "net/cert/x509_certificate.h"
145821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)
155821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)namespace net {
165821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)
175821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)bool TestRootCerts::Add(X509Certificate* certificate) {
185821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)  if (!X509_STORE_add_cert(X509Certificate::cert_store(),
195821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)                           certificate->os_cert_handle())) {
205821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)    unsigned long error_code = ERR_peek_error();
215821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)    if (ERR_GET_LIB(error_code) != ERR_LIB_X509 ||
225821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)        ERR_GET_REASON(error_code) != X509_R_CERT_ALREADY_IN_HASH_TABLE) {
235821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)      crypto::ClearOpenSSLERRStack(FROM_HERE);
245821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)      return false;
255821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)    }
265821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)    ERR_clear_error();
275821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)  }
285821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)
295821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)  empty_ = false;
305821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)  return true;
315821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)}
325821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)
335821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)void TestRootCerts::Clear() {
345821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)  if (empty_)
355821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)    return;
365821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)
375821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)  X509Certificate::ResetCertStore();
385821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)  empty_ = true;
395821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)}
405821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)
415821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)bool TestRootCerts::IsEmpty() const {
425821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)  return empty_;
435821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)}
445821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)
455821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)TestRootCerts::~TestRootCerts() {}
465821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)
475821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)void TestRootCerts::Init() {
485821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)  empty_ = true;
495821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)}
505821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)
515821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)}  // namespace net
52