/* -*- Mode: C++; tab-width: 2; indent-tabs-mode: nil; c-basic-offset: 2 -*- */ /* vim:set ts=2 sw=2 sts=2 et cindent: */ /* This Source Code Form is subject to the terms of the Mozilla Public * License, v. 2.0. If a copy of the MPL was not distributed with this * file, You can obtain one at http://mozilla.org/MPL/2.0/. */ #ifndef DOM_MEDIA_EME_MEDIAKEYSYSTEMACCESSPERMISSIONREQUEST_H_ #define DOM_MEDIA_EME_MEDIAKEYSYSTEMACCESSPERMISSIONREQUEST_H_ #include "mozilla/MozPromise.h" #include "nsContentPermissionHelper.h" class nsGlobalWindowInner; namespace mozilla::dom { /** * This class encapsulates a permission request to allow media key system * access. The intention is not for this class to be used in all cases of EME, * but only when we need to seek explicit approval from an application using * Gecko, such as an application embedding via GeckoView. * * media.eme.require-app-approval should be used to gate this functionality in * gecko code, and is also used as the testing pref for * ContentPermissionRequestBase. I.e. CheckPromptPrefs() will respond to having * `media.eme.require-app-approval.prompt.testing` and * `media.eme.require-app-approval.prompt.testing.allow` being set to true or * false and will return an appropriate value to allow for test code to short * circuit showing a prompt. Note that the code using this class needs to call * CheckPromptPrefs and implement test specific logic, it is *not* handled by * this class or ContentPermissionRequestBase. * * Expects to be used on main thread as ContentPermissionRequestBase uses * PContentPermissionRequest which is managed by PContent which is main thread * to main thread communication. */ class MediaKeySystemAccessPermissionRequest : public ContentPermissionRequestBase { public: NS_DECL_ISUPPORTS_INHERITED NS_DECL_CYCLE_COLLECTION_CLASS_INHERITED( MediaKeySystemAccessPermissionRequest, ContentPermissionRequestBase) using RequestPromise = MozPromise; // Create a MediaKeySystemAccessPermissionRequest. // @param aWindow The window associated with this request. static already_AddRefed Create( nsPIDOMWindowInner* aWindow); // Returns a promise that will be resolved if this request is allowed or // rejected in the case the request is denied. If allowed the promise // will resolve with true, otherwise it will resolve with false. already_AddRefed GetPromise(); // Helper function that triggers the request. This function will check // prefs and cancel or allow the request if the appropriate prefs are set, // otherwise it will fire the request to the associated window. nsresult Start(); // nsIContentPermissionRequest methods NS_IMETHOD Cancel(void) override; NS_IMETHOD Allow(JS::Handle choices) override; private: explicit MediaKeySystemAccessPermissionRequest(nsGlobalWindowInner* aWindow); ~MediaKeySystemAccessPermissionRequest(); MozPromiseHolder mPromiseHolder; }; } // namespace mozilla::dom #endif // DOM_MEDIA_EME_MEDIAKEYSYSTEMACCESSPERMISSIONREQUEST_H_