blob: 91ba6c0ea3f8ce1e98d25c8c45e838617bc01408 [file] [log] [blame]
/*
* Copyright (C) 2011 Google Inc. All rights reserved.
*
* Redistribution and use in source and binary forms, with or without
* modification, are permitted provided that the following conditions are
* met:
*
* * Redistributions of source code must retain the above copyright
* notice, this list of conditions and the following disclaimer.
* * Redistributions in binary form must reproduce the above
* copyright notice, this list of conditions and the following disclaimer
* in the documentation and/or other materials provided with the
* distribution.
* * Neither the name of Google Inc. nor the names of its
* contributors may be used to endorse or promote products derived from
* this software without specific prior written permission.
*
* THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS
* "AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT
* LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR
* A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT
* OWNER OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL,
* SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT
* LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE,
* DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY
* THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT
* (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE
* OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
*/
#ifndef THIRD_PARTY_BLINK_PUBLIC_WEB_WEB_SCOPED_USER_GESTURE_H_
#define THIRD_PARTY_BLINK_PUBLIC_WEB_WEB_SCOPED_USER_GESTURE_H_
#include <memory>
#include "third_party/blink/public/platform/web_common.h"
namespace blink {
class UserGestureIndicator;
class WebLocalFrame;
class WebUserGestureToken;
// An instance of this class, while kept alive, will indicate that we are in
// the context of a known user gesture. To use, create one, perform whatever
// actions were done under color of a known user gesture, and then delete it.
// Usually this will be done on the stack.
//
// SECURITY WARNING: Do not create several instances of this class for the same
// user gesture. Doing so might enable malicious code to work around certain
// restrictions such as opening multiple windows.
// Instead, obtain the current WebUserGestureToken from the
// WebUserGestureIndicator, and use this token to create a
// WebScopedUserGesture. If the token was alrady consumed, the new
// WebScopedUserGesture will not indicate that we are in the context of a user
// gesture.
class WebScopedUserGesture {
public:
BLINK_EXPORT explicit WebScopedUserGesture(const WebUserGestureToken& token);
BLINK_EXPORT WebScopedUserGesture(WebLocalFrame*);
BLINK_EXPORT ~WebScopedUserGesture();
private:
std::unique_ptr<UserGestureIndicator> indicator_;
};
} // namespace blink
#endif // THIRD_PARTY_BLINK_PUBLIC_WEB_WEB_SCOPED_USER_GESTURE_H_