| Index: ios/web/public/test/response_providers/http_auth_response_provider.mm
 | 
| diff --git a/ios/web/public/test/response_providers/http_auth_response_provider.mm b/ios/web/public/test/response_providers/http_auth_response_provider.mm
 | 
| new file mode 100644
 | 
| index 0000000000000000000000000000000000000000..36ed46c7cf3f85703d8924aee6e7608f14afc03b
 | 
| --- /dev/null
 | 
| +++ b/ios/web/public/test/response_providers/http_auth_response_provider.mm
 | 
| @@ -0,0 +1,53 @@
 | 
| +// Copyright 2017 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.
 | 
| +
 | 
| +#import "ios/web/public/test/response_providers/http_auth_response_provider.h"
 | 
| +
 | 
| +#include "base/base64.h"
 | 
| +#include "base/strings/stringprintf.h"
 | 
| +#include "net/http/http_request_headers.h"
 | 
| +#include "net/http/http_response_headers.h"
 | 
| +
 | 
| +namespace web {
 | 
| +
 | 
| +HttpAuthResponseProvider::HttpAuthResponseProvider(const GURL& url,
 | 
| +                                                   const std::string& realm,
 | 
| +                                                   const std::string& username,
 | 
| +                                                   const std::string& password)
 | 
| +    : url_(url), realm_(realm), username_(username), password_(password) {}
 | 
| +
 | 
| +HttpAuthResponseProvider::~HttpAuthResponseProvider() = default;
 | 
| +
 | 
| +bool HttpAuthResponseProvider::CanHandleRequest(const Request& request) {
 | 
| +  return request.url == url_;
 | 
| +}
 | 
| +
 | 
| +void HttpAuthResponseProvider::GetResponseHeadersAndBody(
 | 
| +    const Request& request,
 | 
| +    scoped_refptr<net::HttpResponseHeaders>* headers,
 | 
| +    std::string* response_body) {
 | 
| +  if (HeadersHaveValidCredentials(request.headers)) {
 | 
| +    *response_body = page_text();
 | 
| +    *headers = GetDefaultResponseHeaders();
 | 
| +  } else {
 | 
| +    *headers = GetResponseHeaders("", net::HTTP_UNAUTHORIZED);
 | 
| +    (*headers)->AddHeader(base::StringPrintf(
 | 
| +        "WWW-Authenticate: Basic realm=\"%s\"", realm_.c_str()));
 | 
| +  }
 | 
| +}
 | 
| +
 | 
| +bool HttpAuthResponseProvider::HeadersHaveValidCredentials(
 | 
| +    const net::HttpRequestHeaders& headers) {
 | 
| +  std::string header;
 | 
| +  if (headers.GetHeader(net::HttpRequestHeaders::kAuthorization, &header)) {
 | 
| +    std::string auth =
 | 
| +        base::StringPrintf("%s:%s", username_.c_str(), password_.c_str());
 | 
| +    std::string encoded_auth;
 | 
| +    base::Base64Encode(auth, &encoded_auth);
 | 
| +    return header == base::StringPrintf("Basic %s", encoded_auth.c_str());
 | 
| +  }
 | 
| +  return false;
 | 
| +}
 | 
| +
 | 
| +}  // namespace web
 | 
| 
 |