123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160 |
- /* -*- Mode: C++; tab-width: 8; indent-tabs-mode: nil; c-basic-offset: 2 -*- */
- /* 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 mozilla_AppProcessChecker_h
- #define mozilla_AppProcessChecker_h
- #include <stdint.h>
- class nsIPrincipal;
- namespace mozilla {
- namespace dom {
- class TabContext;
- class PBrowserParent;
- class PContentParent;
- } // namespace dom
- namespace hal_sandbox {
- class PHalParent;
- } // namespace hal_sandbox
- enum AssertAppProcessType {
- ASSERT_APP_PROCESS_PERMISSION,
- ASSERT_APP_PROCESS_MANIFEST_URL,
- ASSERT_APP_HAS_PERMISSION
- };
- /**
- * Return true if the specified browser has the specified capability.
- * If this returns false, the browser didn't have the capability and
- * will be killed.
- */
- bool
- AssertAppProcess(mozilla::dom::PBrowserParent* aActor,
- AssertAppProcessType aType,
- const char* aCapability);
- /**
- * Return true if the specified app has the specified status.
- * If this returns false, the browser will be killed.
- */
- bool
- AssertAppStatus(mozilla::dom::PBrowserParent* aActor,
- unsigned short aStatus);
- /**
- * Return true if the specified browser has the specified capability.
- * If this returns false, the browser didn't have the capability and
- * will be killed.
- */
- bool
- AssertAppProcess(const mozilla::dom::TabContext& aContext,
- AssertAppProcessType aType,
- const char* aCapability);
- /**
- * Return true if the specified app has the specified status.
- * If this returns false, the browser will be killed.
- */
- bool
- AssertAppStatus(const mozilla::dom::TabContext& aContext,
- unsigned short aStatus);
- /**
- * Return true if any of the PBrowsers loaded in this content process
- * has the specified capability. If this returns false, the process
- * didn't have the capability and will be killed.
- */
- bool
- AssertAppProcess(mozilla::dom::PContentParent* aActor,
- AssertAppProcessType aType,
- const char* aCapability);
- /**
- * Return true if any of the PBrowsers loaded in this content process
- * has an app with the specified status. If this returns false, the process
- * didn't have the status and will be killed.
- */
- bool
- AssertAppStatus(mozilla::dom::PContentParent* aActor,
- unsigned short aStatus);
- bool
- AssertAppProcess(mozilla::hal_sandbox::PHalParent* aActor,
- AssertAppProcessType aType,
- const char* aCapability);
- // NB: when adding capability checks for other IPDL actors, please add
- // them to this file and have them delegate to the two functions above
- // as appropriate. For example,
- //
- // bool AppProcessHasCapability(PNeckoParent* aActor, AssertAppProcessType aType) {
- // return AssertAppProcess(aActor->Manager(), aType);
- // }
- bool
- AssertAppPrincipal(mozilla::dom::PContentParent* aParent,
- nsIPrincipal* aPrincipal);
- /**
- * Check if the specified principal is valid, and return the saved permission
- * value for permission `aPermission' on that principal.
- * See nsIPermissionManager.idl for possible return values.
- *
- * nsIPermissionManager::UNKNOWN_ACTION is retuned if the principal is invalid.
- */
- uint32_t
- CheckPermission(mozilla::dom::PContentParent* aParent,
- nsIPrincipal* aPrincipal, const char* aPermission);
- /**
- * Inline function for asserting the process's permission.
- */
- template<typename T>
- inline bool
- AssertAppProcessPermission(T* aActor,
- const char* aPermission) {
- return AssertAppProcess(aActor,
- ASSERT_APP_PROCESS_PERMISSION,
- aPermission);
- }
- /**
- * Inline function for asserting the process's manifest URL.
- */
- template<typename T>
- inline bool
- AssertAppProcessManifestURL(T* aActor,
- const char* aManifestURL) {
- return AssertAppProcess(aActor,
- ASSERT_APP_PROCESS_MANIFEST_URL,
- aManifestURL);
- }
- /**
- * Inline function for asserting the process's manifest URL.
- */
- template<typename T>
- inline bool
- AssertAppHasPermission(T* aActor,
- const char* aPermission) {
- return AssertAppProcess(aActor,
- ASSERT_APP_HAS_PERMISSION,
- aPermission);
- }
- template<typename T>
- inline bool
- AssertAppHasStatus(T* aActor,
- unsigned short aStatus) {
- return AssertAppStatus(aActor, aStatus);
- }
- } // namespace mozilla
- #endif // mozilla_AppProcessChecker_h
|