blob: 63f58bde1ad044e9199a1070944f0c09215382f1 (
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
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
|
#pragma once
#include <memory>
#include <vector>
#include <cstdint>
#include "WaylandProtocol.hpp"
#include "security-context-v1.hpp"
class CSecurityContext {
public:
CSecurityContext(SP<CWpSecurityContextV1> resource_, int listenFD_, int closeFD_);
~CSecurityContext();
bool good();
std::string sandboxEngine, appID, instanceID;
int listenFD = -1, closeFD = -1;
void onListen(uint32_t mask);
void onClose(uint32_t mask);
private:
SP<CWpSecurityContextV1> resource;
wl_event_source * listenSource = nullptr, *closeSource = nullptr;
bool committed = false;
};
class CSecurityContextManagerResource {
public:
CSecurityContextManagerResource(SP<CWpSecurityContextManagerV1> resource_);
bool good();
private:
SP<CWpSecurityContextManagerV1> resource;
};
class CSecurityContextSandboxedClient;
struct CSecurityContextSandboxedClientDestroyWrapper {
wl_listener listener;
CSecurityContextSandboxedClient* parent = nullptr;
};
class CSecurityContextSandboxedClient {
public:
static SP<CSecurityContextSandboxedClient> create(int clientFD);
~CSecurityContextSandboxedClient();
void onDestroy();
CSecurityContextSandboxedClientDestroyWrapper destroyListener;
private:
CSecurityContextSandboxedClient(int clientFD_);
wl_client* client = nullptr;
int clientFD = -1;
friend class CSecurityContextProtocol;
friend class CSecurityContext;
};
class CSecurityContextProtocol : public IWaylandProtocol {
public:
CSecurityContextProtocol(const wl_interface* iface, const int& ver, const std::string& name);
virtual void bindManager(wl_client* client, void* data, uint32_t ver, uint32_t id);
bool isClientSandboxed(const wl_client* client);
private:
void destroyResource(CSecurityContextManagerResource* resource);
void destroyContext(CSecurityContext* context);
//
std::vector<SP<CSecurityContextManagerResource>> m_vManagers;
std::vector<SP<CSecurityContext>> m_vContexts;
std::vector<SP<CSecurityContextSandboxedClient>> m_vSandboxedClients;
friend class CSecurityContextManagerResource;
friend class CSecurityContext;
friend class CSecurityContextSandboxedClient;
};
namespace PROTO {
inline UP<CSecurityContextProtocol> securityContext;
};
|