| // Copyright (c) 2011 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. |
| |
| #ifndef NET_URL_REQUEST_URL_REQUEST_REDIRECT_JOB_H_ |
| #define NET_URL_REQUEST_URL_REQUEST_REDIRECT_JOB_H_ |
| |
| #include "base/memory/weak_ptr.h" |
| #include "net/base/net_export.h" |
| #include "net/url_request/url_request_job.h" |
| |
| class GURL; |
| |
| namespace net { |
| |
| // A URLRequestJob that will redirect the request to the specified |
| // URL. This is useful to restart a request at a different URL based |
| // on the result of another job. |
| class NET_EXPORT URLRequestRedirectJob : public URLRequestJob { |
| public: |
| // Valid status codes for the redirect job. Other 30x codes are theoretically |
| // valid, but unused so far. Both 302 and 307 are temporary redirects, with |
| // the difference being that 302 converts POSTs to GETs and removes upload |
| // data. |
| enum StatusCode { |
| REDIRECT_302_FOUND = 302, |
| REDIRECT_307_TEMPORARY_REDIRECT = 307, |
| }; |
| |
| // Constructs a job that redirects to the specified URL. |
| URLRequestRedirectJob(URLRequest* request, |
| NetworkDelegate* network_delegate, |
| const GURL& redirect_destination, |
| StatusCode http_status_code); |
| |
| virtual void Start() override; |
| virtual bool IsRedirectResponse(GURL* location, |
| int* http_status_code) override; |
| |
| private: |
| virtual ~URLRequestRedirectJob(); |
| |
| void StartAsync(); |
| |
| const GURL redirect_destination_; |
| const int http_status_code_; |
| |
| base::WeakPtrFactory<URLRequestRedirectJob> weak_factory_; |
| }; |
| |
| } // namespace net |
| |
| #endif // NET_URL_REQUEST_URL_REQUEST_REDIRECT_JOB_H_ |