OLD | NEW |
---|---|
1 // Copyright 2014 The Chromium Authors. All rights reserved. | 1 // Copyright 2014 The Chromium Authors. All rights reserved. |
2 // Use of this source code is governed by a BSD-style license that can be | 2 // Use of this source code is governed by a BSD-style license that can be |
3 // found in the LICENSE file. | 3 // found in the LICENSE file. |
4 | 4 |
5 #ifndef CONTENT_BROWSER_GEOLOCATION_GEOLOCATION_SERVICE_CONTEXT_H_ | 5 #ifndef CONTENT_BROWSER_GEOLOCATION_GEOLOCATION_SERVICE_CONTEXT_H_ |
6 #define CONTENT_BROWSER_GEOLOCATION_GEOLOCATION_SERVICE_CONTEXT_H_ | 6 #define CONTENT_BROWSER_GEOLOCATION_GEOLOCATION_SERVICE_CONTEXT_H_ |
7 | 7 |
8 #include "base/memory/scoped_vector.h" | |
9 #include "content/browser/geolocation/geolocation_service_impl.h" | 8 #include "content/browser/geolocation/geolocation_service_impl.h" |
9 #include "content/common/geolocation_service.mojom.h" | |
10 #include "content/public/browser/web_contents_user_data.h" | |
11 #include "mojo/common/service_set.h" | |
10 | 12 |
11 namespace content { | 13 namespace content { |
14 struct Geoposition; | |
12 | 15 |
13 // Provides information to a set of GeolocationServiceImpl instances that are | 16 // Provides information to a set of GeolocationServiceImpl instances that are |
14 // associated with a given context. Notably, allows pausing and resuming | 17 // associated with a given context. Notably, allows pausing and resuming |
15 // geolocation on these instances. | 18 // geolocation on these instances. |
16 class GeolocationServiceContext { | 19 class GeolocationServiceContext |
20 : public WebContentsUserData<GeolocationServiceContext> { | |
17 public: | 21 public: |
18 GeolocationServiceContext(); | 22 explicit GeolocationServiceContext(WebContents* web_contents); |
Michael van Ouwerkerk
2015/11/11 11:20:56
The constructor and destructor should be private n
Sam McNally
2015/11/13 00:49:59
Done.
| |
19 virtual ~GeolocationServiceContext(); | 23 ~GeolocationServiceContext() override; |
20 | 24 |
21 // Creates a GeolocationServiceImpl that is weakly bound to |request|. | 25 static GeolocationServiceContext* GetOrCreateForWebContents( |
22 // |update_callback| will be called when services send | 26 WebContents* web_contents); |
23 // location updates to their clients. | |
24 void CreateService(const base::Closure& update_callback, | |
25 mojo::InterfaceRequest<GeolocationService> request); | |
26 | 27 |
27 // Called when a service has a connection error. After this call, it is no | 28 // Creates a GeolocationServiceImpl that is bound to |request|. |
28 // longer safe to access |service|. | 29 static void CreateService(RenderFrameHost* render_frame_host, |
29 void ServiceHadConnectionError(GeolocationServiceImpl* service); | 30 mojo::InterfaceRequest<GeolocationService> request); |
30 | 31 |
31 // Pauses and resumes geolocation. Resuming when nothing is paused is a | 32 // Pauses and resumes geolocation. Resuming when nothing is paused is a |
32 // no-op. If a service is added while geolocation is paused, that service | 33 // no-op. If a service is added while geolocation is paused, that service |
33 // will not get geolocation updates until geolocation is resumed. | 34 // will not get geolocation updates until geolocation is resumed. |
34 void PauseUpdates(); | 35 void PauseUpdates(); |
35 void ResumeUpdates(); | 36 void ResumeUpdates(); |
36 | 37 |
37 // Returns whether geolocation updates are currently paused. | 38 // Returns whether geolocation updates are currently paused. |
38 bool paused() { return paused_; } | 39 bool paused() const { return paused_; } |
40 | |
41 // Returns the current position override, or nullptr if there isn't one. | |
42 const Geoposition* position_override() const { | |
43 return geoposition_override_.get(); | |
44 } | |
45 | |
46 void DestroyService(GeolocationServiceImpl* service); | |
39 | 47 |
40 // Enables geolocation override. This method can be used to trigger possible | 48 // Enables geolocation override. This method can be used to trigger possible |
41 // location-specific behavior in a particular context. | 49 // location-specific behavior in a particular context. |
42 void SetOverride(scoped_ptr<Geoposition> geoposition); | 50 void SetOverride(scoped_ptr<Geoposition> geoposition); |
43 | 51 |
44 // Disables geolocation override. | 52 // Disables geolocation override. |
45 void ClearOverride(); | 53 void ClearOverride(); |
46 | 54 |
47 private: | 55 private: |
48 ScopedVector<GeolocationServiceImpl> services_; | 56 void CreateServiceImpl(RenderFrameHost* render_frame_host, |
57 mojo::InterfaceRequest<GeolocationService> request); | |
58 | |
59 mojo::ServiceSet<GeolocationService, GeolocationServiceImpl> services_; | |
49 bool paused_; | 60 bool paused_; |
50 | 61 |
51 scoped_ptr<Geoposition> geoposition_override_; | 62 scoped_ptr<Geoposition> geoposition_override_; |
52 | 63 |
53 DISALLOW_COPY_AND_ASSIGN(GeolocationServiceContext); | 64 DISALLOW_COPY_AND_ASSIGN(GeolocationServiceContext); |
54 }; | 65 }; |
55 | 66 |
56 } // namespace content | 67 } // namespace content |
57 | 68 |
58 #endif // CONTENT_BROWSER_GEOLOCATION_GEOLOCATION_SERVICE_CONTEXT_H_ | 69 #endif // CONTENT_BROWSER_GEOLOCATION_GEOLOCATION_SERVICE_CONTEXT_H_ |
OLD | NEW |