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) 52a99a7e74a7f215066514fe81d2bfa6639d9edddTorne (Richard Coles)#include "net/ssl/ssl_client_auth_cache.h" 65821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles) 75821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)#include "base/logging.h" 8c2e0dbddbe15c98d52c4786dac06cb8952a8ae6dTorne (Richard Coles)#include "net/cert/x509_certificate.h" 95821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles) 105821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)namespace net { 115821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles) 125821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)SSLClientAuthCache::SSLClientAuthCache() { 135821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles) CertDatabase::GetInstance()->AddObserver(this); 145821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)} 155821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles) 165821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)SSLClientAuthCache::~SSLClientAuthCache() { 175821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles) CertDatabase::GetInstance()->RemoveObserver(this); 185821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)} 195821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles) 205821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)bool SSLClientAuthCache::Lookup( 215d1f7b1de12d16ceb2c938c56701a3e8bfa558f7Torne (Richard Coles) const HostPortPair& server, 225821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles) scoped_refptr<X509Certificate>* certificate) { 235821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles) DCHECK(certificate); 245821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles) 255821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles) AuthCacheMap::iterator iter = cache_.find(server); 265821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles) if (iter == cache_.end()) 275821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles) return false; 285821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles) 295821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles) *certificate = iter->second; 305821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles) return true; 315821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)} 325821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles) 335d1f7b1de12d16ceb2c938c56701a3e8bfa558f7Torne (Richard Coles)void SSLClientAuthCache::Add(const HostPortPair& server, 345821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles) X509Certificate* value) { 355821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles) cache_[server] = value; 365821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles) 375821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles) // TODO(wtc): enforce a maximum number of entries. 385821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)} 395821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles) 405d1f7b1de12d16ceb2c938c56701a3e8bfa558f7Torne (Richard Coles)void SSLClientAuthCache::Remove(const HostPortPair& server) { 415821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles) cache_.erase(server); 425821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)} 435821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles) 445821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)void SSLClientAuthCache::OnCertAdded(const X509Certificate* cert) { 455821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles) cache_.clear(); 465821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)} 475821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles) 485821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)} // namespace net 49