1 // Copyright 2015 The Chromium Authors. All rights reserved.
2 // Use of this source code is governed by a BSD-style license that can be
3 // found in the LICENSE file.
5 #ifndef MOJO_FETCHER_ABOUT_FETCHER_H_
6 #define MOJO_FETCHER_ABOUT_FETCHER_H_
8 #include "mojo/shell/fetcher.h"
10 #include "base/macros.h"
11 #include "mojo/services/network/public/interfaces/url_loader.mojom.h"
17 // Implements Fetcher for about: URLs.
18 class AboutFetcher
: public shell::Fetcher
{
20 static const char kAboutScheme
[];
21 static const char kAboutBlankURL
[];
23 static void Start(const GURL
& url
, const FetchCallback
& loader_callback
);
26 AboutFetcher(const GURL
& url
, const FetchCallback
& loader_callback
);
27 ~AboutFetcher() override
;
31 // Must be called exactly once to run the loader callback (asynchrously). On
32 // success, the ownership of this object is passed to the loader callback;
33 // otherwise, the callback is run with a nullptr and this object is destroyed.
34 void PostToRunCallback(bool success
);
36 // shell::Fetcher implementation.
37 const GURL
& GetURL() const override
;
38 GURL
GetRedirectURL() const override
;
39 GURL
GetRedirectReferer() const override
;
40 URLResponsePtr
AsURLResponse(base::TaskRunner
* task_runner
,
41 uint32_t skip
) override
;
43 base::TaskRunner
* task_runner
,
44 base::Callback
<void(const base::FilePath
&, bool)> callback
) override
;
45 std::string
MimeType() override
;
46 bool HasMojoMagic() override
;
47 bool PeekFirstLine(std::string
* line
) override
;
50 URLResponsePtr response_
;
52 DISALLOW_COPY_AND_ASSIGN(AboutFetcher
);
55 } // namespace fetcher
58 #endif // MOJO_FETCHER_ABOUT_FETCHER_H_