summaryrefslogtreecommitdiffstats
path: root/dom/plugins/ipc/FunctionBrokerParent.h
blob: 5ad26678b8399c4e5c93de6b47a37036944b6ac3 (plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
/* -*- Mode: C++; tab-width: 4; indent-tabs-mode: nil; c-basic-offset: 2 -*-
 * vim: sw=2 ts=4 et :
 * 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_plugins_functionbrokerparent_h
#define mozilla_plugins_functionbrokerparent_h

#include "mozilla/plugins/PFunctionBrokerParent.h"
#if defined(XP_WIN) && defined(MOZ_SANDBOX)
#  include "sandboxPermissions.h"
#endif

namespace mozilla {
namespace plugins {

class FunctionBrokerThread;

/**
 * Top-level actor run on the process to which we broker calls from sandboxed
 * plugin processes.
 */
class FunctionBrokerParent : public PFunctionBrokerParent {
 public:
  static FunctionBrokerParent* Create(
      Endpoint<PFunctionBrokerParent>&& aParentEnd);
  static void Destroy(FunctionBrokerParent* aInst);

  void ActorDestroy(ActorDestroyReason aWhy) override;

  mozilla::ipc::IPCResult RecvBrokerFunction(const FunctionHookId& aFunctionId,
                                             const IpdlTuple& aInTuple,
                                             IpdlTuple* aOutTuple) override;

#if defined(XP_WIN) && defined(MOZ_SANDBOX)
  static mozilla::SandboxPermissions* GetSandboxPermissions() {
    return &sSandboxPermissions;
  }
#endif  // defined(XP_WIN) && defined(MOZ_SANDBOX)

 private:
  explicit FunctionBrokerParent(FunctionBrokerThread* aThread,
                                Endpoint<PFunctionBrokerParent>&& aParentEnd);
  ~FunctionBrokerParent();
  void ShutdownOnBrokerThread();
  void Bind(Endpoint<PFunctionBrokerParent>&& aEnd);

  static bool RunBrokeredFunction(base::ProcessId aClientId,
                                  const FunctionHookId& aFunctionId,
                                  const IPC::IpdlTuple& aInTuple,
                                  IPC::IpdlTuple* aOutTuple);

#if defined(XP_WIN) && defined(MOZ_SANDBOX)
  static void RemovePermissionsForProcess(base::ProcessId aClientId);
  static mozilla::SandboxPermissions sSandboxPermissions;
#endif  // defined(XP_WIN) && defined(MOZ_SANDBOX)

  UniquePtr<FunctionBrokerThread> mThread;
  Monitor mMonitor;
  bool mShutdownDone;
};

}  // namespace plugins
}  // namespace mozilla

#endif  // mozilla_plugins_functionbrokerparent_hk