// Copyright 2014 The Chromium OS 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 #include namespace brillo { namespace http { const char kErrorDomain[] = "http_transport"; const char kDirectProxy[] = "direct://"; std::shared_ptr Transport::CreateDefault() { return std::make_shared(std::make_shared()); } std::shared_ptr Transport::CreateDefaultWithProxy( const std::string& proxy) { if (proxy.empty() || proxy == kDirectProxy) { return CreateDefault(); } else { return std::make_shared(std::make_shared(), proxy); } } base::FilePath Transport::CertificateToPath(Transport::Certificate cert) { const char* str; switch (cert) { case Certificate::kDefault: str = #ifdef __ANDROID__ "/system/etc/security/cacerts_google"; #else "/usr/share/chromeos-ca-certificates"; #endif break; case Certificate::kHermesProd: str = "/usr/share/hermes-ca-certificates/prod"; break; case Certificate::kHermesTest: str = "/usr/share/hermes-ca-certificates/test"; break; case Certificate::kNss: str = "/etc/ssl/certs"; break; default: CHECK(false) << "Invalid certificate"; break; } return base::FilePath(str); } } // namespace http } // namespace brillo