blob: c402b7f215bc4127a76a15982ff286cd2c331c02 [file] [log] [blame]
// Copyright 2015 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_PUBLIC_BROWSER_BACKGROUND_SYNC_CONTROLLER_H_
#define CONTENT_PUBLIC_BROWSER_BACKGROUND_SYNC_CONTROLLER_H_
#include <stdint.h>
#include "base/time/time.h"
#include "content/common/content_export.h"
#include "third_party/blink/public/common/service_worker/service_worker_status_code.h"
#include "third_party/blink/public/mojom/background_sync/background_sync.mojom-shared.h"
namespace url {
class Origin;
} // namespace url
namespace content {
struct BackgroundSyncParameters;
// An interface that the Background Sync API uses to access services from the
// embedder. Must only be used on the UI thread.
class CONTENT_EXPORT BackgroundSyncController {
public:
class BackgroundSyncEventKeepAlive {
public:
virtual ~BackgroundSyncEventKeepAlive() = default;
protected:
BackgroundSyncEventKeepAlive() = default;
};
virtual ~BackgroundSyncController() {}
// This function allows the controller to alter the parameters used by
// background sync. Note that disable can be overridden from false to true
// but overrides from true to false will be ignored.
virtual void GetParameterOverrides(BackgroundSyncParameters* parameters) {}
// Notification that a service worker registration with origin |origin| just
// registered a background sync event. Also includes information about the
// registration.
virtual void NotifyBackgroundSyncRegistered(const url::Origin& origin,
bool can_fire,
bool is_reregistered) {}
// Notification that a service worker registration with origin |origin| just
// completed a background sync registration. Also include the |status_code|
// the registration finished with, the number of attempts, and the max
// allowed number of attempts.
virtual void NotifyBackgroundSyncCompleted(
const url::Origin& origin,
blink::ServiceWorkerStatusCode status_code,
int num_attempts,
int max_attempts) {}
// Calculates the soonest wakeup delta across all storage partitions and
// schedules a background task to wake up the browser.
virtual void RunInBackground() {}
// Calculates the delay after which the next sync event should be fired
// for a BackgroundSync registration. The delay is based on the |sync_type|.
virtual base::TimeDelta GetNextEventDelay(
const url::Origin& origin,
int64_t min_interval,
int num_attempts,
blink::mojom::BackgroundSyncType sync_type,
BackgroundSyncParameters* parameters) = 0;
// Keeps the browser alive to allow a one-shot Background Sync registration
// to finish firing one sync event.
virtual std::unique_ptr<BackgroundSyncEventKeepAlive>
CreateBackgroundSyncEventKeepAlive() = 0;
};
} // namespace content
#endif // CONTENT_PUBLIC_BROWSER_BACKGROUND_SYNC_CONTROLLER_H_