Chromium Code Reviews| Index: chrome/browser/chromeos/net/cert_profile_filter.cc |
| diff --git a/chrome/browser/chromeos/net/cert_profile_filter.cc b/chrome/browser/chromeos/net/cert_profile_filter.cc |
| new file mode 100644 |
| index 0000000000000000000000000000000000000000..4f14fade5f2cb2525b94112ae38089fa5673f256 |
| --- /dev/null |
| +++ b/chrome/browser/chromeos/net/cert_profile_filter.cc |
| @@ -0,0 +1,64 @@ |
| +// Copyright 2014 The Chromium Authors. All rights reserved. |
| +// Use of this source code is governed by a BSD-style license that can be |
| +// found in the LICENSE file. |
| + |
| +#include "chrome/browser/chromeos/net/cert_profile_filter.h" |
| + |
| +#include "base/bind.h" |
| +#include "components/cert_database/public/cert_database_service_io_part.h" |
| +#include "net/cert/nss_cert_database.h" |
| +#include "net/cert/nss_profile_filter_chromeos.h" |
| + |
| +namespace chromeos { |
| + |
| +namespace { |
| + |
| +class ProfileFilterFactory : public net::NSSProfileFilterChromeOSFactory { |
| + public: |
| + explicit ProfileFilterFactory( |
| + const base::WeakPtr<cert_database::CertDatabaseServiceIOPart>& cert_db_io) |
| + : cert_db_io_(cert_db_io) {} |
| + |
| + virtual scoped_ptr<net::NSSProfileFilterChromeOS> CreateFilter( |
| + const base::Callback<void(const net::NSSProfileFilterChromeOS&)>& |
| + callback) override { |
| + if (!cert_db_io_) |
| + return make_scoped_ptr(new net::NSSProfileFilterChromeOS); |
| + |
| + net::NSSCertDatabase* cert_db = cert_db_io_->GetNSSCertDatabase( |
| + base::Bind(&DidGetNSSCertDatabase, callback)); |
| + if (cert_db) |
| + return CreateFilterInternal(cert_db); |
| + return scoped_ptr<net::NSSProfileFilterChromeOS>(); |
|
mattm
2014/10/18 00:45:15
return nullptr
pneubeck (no reviews)
2014/10/21 09:22:09
Done.
|
| + } |
| + |
| + private: |
| + static void DidGetNSSCertDatabase( |
| + const base::Callback<void(const net::NSSProfileFilterChromeOS&)>& |
| + callback, |
| + net::NSSCertDatabase* cert_db) { |
| + callback.Run(*CreateFilterInternal(cert_db)); |
| + } |
| + |
| + static scoped_ptr<net::NSSProfileFilterChromeOS> CreateFilterInternal( |
| + net::NSSCertDatabase* nss_cert_db) { |
| + scoped_ptr<net::NSSProfileFilterChromeOS> filter( |
| + new net::NSSProfileFilterChromeOS); |
| + filter->Init(nss_cert_db->GetPublicSlot(), |
| + nss_cert_db->GetPrivateSlot(), |
| + nss_cert_db->GetSystemSlot()); |
| + return filter.Pass(); |
| + } |
| + |
| + base::WeakPtr<cert_database::CertDatabaseServiceIOPart> cert_db_io_; |
| +}; |
| + |
| +} // namespace |
| + |
| +scoped_ptr<net::NSSProfileFilterChromeOSFactory> CreateProfileFilterFactory( |
| + const base::WeakPtr<cert_database::CertDatabaseServiceIOPart>& cert_db_io) { |
| + return scoped_ptr<net::NSSProfileFilterChromeOSFactory>( |
| + new ProfileFilterFactory(cert_db_io)); |
|
mattm
2014/10/18 00:45:15
I think you can use make_scoped_ptr for this case
pneubeck (no reviews)
2014/10/21 09:22:08
Done.
|
| +} |
| + |
| +} // namespace chromeos |