blob: 82be068eb15472516f6b8f4217084fe87ddc5be7 [file] [log] [blame]
// Copyright 2017 The Chromium Authors
// Use of this source code is governed by a BSD-style license that can be
// found in the LICENSE file.
#ifndef CONTENT_BROWSER_WAKE_LOCK_WAKE_LOCK_CONTEXT_HOST_H_
#define CONTENT_BROWSER_WAKE_LOCK_WAKE_LOCK_CONTEXT_HOST_H_
#include "base/memory/raw_ptr.h"
#include "content/public/browser/web_contents.h"
#include "mojo/public/cpp/bindings/remote.h"
#include "services/device/public/mojom/wake_lock_context.mojom.h"
#include "services/device/public/mojom/wake_lock_provider.mojom.h"
#include "ui/gfx/native_widget_types.h"
namespace content {
// On Android, WakeLockContext requires the NativeView associated with the
// context in order to lock the screen. WakeLockContextHost provides this
// functionality by mapping WakeLockContext IDs to the WebContents associated
// with those IDs.
class WakeLockContextHost {
public:
explicit WakeLockContextHost(WebContents* web_contents);
WakeLockContextHost(const WakeLockContextHost&) = delete;
WakeLockContextHost& operator=(const WakeLockContextHost&) = delete;
~WakeLockContextHost();
// This callback is passed into the DeviceService constructor in order to
// enable WakeLockContext to map a context ID to a Native View as necessary.
static gfx::NativeView GetNativeViewForContext(int context_id);
// Returns the WakeLockContext* to which this instance is connected.
device::mojom::WakeLockContext* GetWakeLockContext() {
return wake_lock_context_ ? wake_lock_context_.get() : nullptr;
}
private:
// This instance's ID.
int id_;
// The WebContents that owns this instance.
raw_ptr<WebContents> web_contents_;
// The WakeLockContext instance that is connected to this instance.
mojo::Remote<device::mojom::WakeLockContext> wake_lock_context_;
};
} // namespace content
#endif // CONTENT_BROWSER_WAKE_LOCK_WAKE_LOCK_CONTEXT_HOST_H_