blob: b85a84bc52c7548e2df864463a0ff5e3e1ae38f2 (
plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
|
// Copyright 2014 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 CONTENT_BROWSER_SERVICE_WORKER_SERVICE_WORKER_JOB_COORDINATOR_H_
#define CONTENT_BROWSER_SERVICE_WORKER_SERVICE_WORKER_JOB_COORDINATOR_H_
#include <deque>
#include <map>
#include "content/browser/service_worker/service_worker_register_job.h"
#include "content/browser/service_worker/service_worker_unregister_job.h"
#include "content/common/content_export.h"
#include "url/gurl.h"
namespace content {
class EmbeddedWorkerRegistry;
class ServiceWorkerProviderHost;
class ServiceWorkerRegistration;
class ServiceWorkerStorage;
// This class manages all in-flight registration or unregistration jobs.
class CONTENT_EXPORT ServiceWorkerJobCoordinator {
public:
explicit ServiceWorkerJobCoordinator(
base::WeakPtr<ServiceWorkerContextCore> context);
~ServiceWorkerJobCoordinator();
void Register(const GURL& pattern,
const GURL& script_url,
ServiceWorkerProviderHost* provider_host,
const ServiceWorkerRegisterJob::RegistrationCallback& callback);
void Unregister(
const GURL& pattern,
const ServiceWorkerUnregisterJob::UnregistrationCallback& callback);
void Update(ServiceWorkerRegistration* registration);
// Calls ServiceWorkerRegisterJobBase::Abort() on all jobs and removes them.
void AbortAll();
// Removes the job. A job that was not aborted must call FinishJob when it is
// done.
void FinishJob(const GURL& pattern, ServiceWorkerRegisterJobBase* job);
private:
class JobQueue {
public:
JobQueue();
~JobQueue();
// Adds a job to the queue. If an identical job is already in the queue, no
// new job is added. Returns the job in the queue, regardless of whether it
// was newly added.
ServiceWorkerRegisterJobBase* Push(
scoped_ptr<ServiceWorkerRegisterJobBase> job);
// Removes a job from the queue.
void Pop(ServiceWorkerRegisterJobBase* job);
bool empty() { return jobs_.empty(); }
// Aborts all jobs in the queue and removes them.
void AbortAll();
// Marks that the browser is shutting down, so jobs may be destroyed before
// finishing.
void ClearForShutdown();
private:
std::deque<ServiceWorkerRegisterJobBase*> jobs_;
};
typedef std::map<GURL, JobQueue> RegistrationJobMap;
// The ServiceWorkerContextCore object should always outlive the
// job coordinator, the core owns the coordinator.
base::WeakPtr<ServiceWorkerContextCore> context_;
RegistrationJobMap job_queues_;
DISALLOW_COPY_AND_ASSIGN(ServiceWorkerJobCoordinator);
};
} // namespace content
#endif // CONTENT_BROWSER_SERVICE_WORKER_SERVICE_WORKER_JOB_COORDINATOR_H_
|