summaryrefslogtreecommitdiffstats
path: root/sandbox/sandbox.gyp
blob: 598de3f9262096fd08ad5e7ac2d3259c1910b92c (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
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
154
155
156
157
158
159
160
161
162
163
164
165
166
167
168
169
170
171
172
173
174
175
176
177
178
179
180
181
182
183
184
185
186
187
188
189
190
191
192
193
194
195
196
197
198
199
200
201
202
203
204
205
206
207
208
209
210
211
212
213
214
215
216
217
218
219
220
221
222
223
224
225
226
227
228
229
230
231
232
233
234
235
236
237
238
239
240
241
242
243
244
245
246
247
248
249
250
251
252
253
254
255
256
257
258
259
260
261
262
263
264
265
266
267
268
269
270
271
272
273
274
275
276
277
278
279
280
281
282
283
284
285
286
287
288
289
290
291
292
293
294
295
296
297
298
299
300
301
302
303
304
305
306
307
308
309
310
311
312
313
314
315
316
317
318
319
320
321
322
323
324
325
326
327
328
329
330
331
332
333
334
335
336
337
338
339
340
341
342
343
344
# Copyright (c) 2009 The Chromium Authors. All rights reserved.
# Use of this source code is governed by a BSD-style license that can be
# found in the LICENSE file.

{
  'conditions': [
    [ 'OS=="linux" and selinux==0', {
      'targets': [
        {
          'target_name': 'chrome_sandbox',
          'type': 'executable',
          'sources': [
            'linux/suid/sandbox.c',
          ],
          'include_dirs': [
            '..',
          ],
        },
        {
          'target_name': 'sandbox',
          'type': '<(library)',
          'dependencies': [
            '../base/base.gyp:base',
          ],
          'conditions': [
            ['target_arch!="arm"', {
              'sources': [
                'linux/seccomp/access.cc',
                'linux/seccomp/clone.cc',
                'linux/seccomp/exit.cc',
                'linux/seccomp/debug.cc',
                'linux/seccomp/getpid.cc',
                'linux/seccomp/gettid.cc',
                'linux/seccomp/ioctl.cc',
                'linux/seccomp/ipc.cc',
                'linux/seccomp/library.cc',
                'linux/seccomp/library.h',
                'linux/seccomp/linux_syscall_support.h',
                'linux/seccomp/madvise.cc',
                'linux/seccomp/maps.cc',
                'linux/seccomp/maps.h',
                'linux/seccomp/mmap.cc',
                'linux/seccomp/mprotect.cc',
                'linux/seccomp/munmap.cc',
                'linux/seccomp/mutex.h',
                'linux/seccomp/open.cc',
                'linux/seccomp/sandbox.cc',
                'linux/seccomp/sandbox.h',
                'linux/seccomp/sandbox_impl.h',
                'linux/seccomp/securemem.cc',
                'linux/seccomp/securemem.h',
                'linux/seccomp/socketcall.cc',
                'linux/seccomp/stat.cc',
                'linux/seccomp/syscall.cc',
                'linux/seccomp/syscall.h',
                'linux/seccomp/syscall_table.c',
                'linux/seccomp/syscall_table.h',
                'linux/seccomp/tls.h',
                'linux/seccomp/trusted_process.cc',
                'linux/seccomp/trusted_thread.cc',
                'linux/seccomp/x86_decode.cc',
                'linux/seccomp/x86_decode.h',
              ],
            },
          ],
        ]},
      ],
    }],
    [ 'OS=="linux" and selinux==1', {
      # GYP requires that each file have at least one target defined.
      'targets': [
        {
          'target_name': 'sandbox',
          'type': 'settings',
        },
      ],
    }],
    [ 'OS=="win"', {
      'targets': [
        {
          'target_name': 'sandbox',
          'type': '<(library)',
          'dependencies': [
            '../testing/gtest.gyp:gtest',
            '../base/base.gyp:base',
          ],
          'msvs_guid': '881F6A97-D539-4C48-B401-DF04385B2343',
          'sources': [
            'src/acl.cc',
            'src/acl.h',
            'src/dep.cc',
            'src/dep.h',
            'src/job.cc',
            'src/job.h',
            'src/restricted_token.cc',
            'src/restricted_token.h',
            'src/restricted_token_utils.cc',
            'src/restricted_token_utils.h',
            'src/security_level.h',
            'src/sid.cc',
            'src/sid.h',
            'src/eat_resolver.cc',
            'src/eat_resolver.h',
            'src/interception.cc',
            'src/interception.h',
            'src/interception_agent.cc',
            'src/interception_agent.h',
            'src/interception_internal.h',
            'src/resolver.cc',
            'src/resolver.h',
            'src/service_resolver.cc',
            'src/service_resolver.h',
            'src/sidestep_resolver.cc',
            'src/sidestep_resolver.h',
            'src/target_interceptions.cc',
            'src/target_interceptions.h',
            'src/Wow64.cc',
            'src/Wow64.h',
            'src/sidestep\ia32_modrm_map.cpp',
            'src/sidestep\ia32_opcode_map.cpp',
            'src/sidestep\mini_disassembler.cpp',
            'src/sidestep\mini_disassembler.h',
            'src/sidestep\mini_disassembler_types.h',
            'src/sidestep\preamble_patcher.h',
            'src/sidestep\preamble_patcher_with_stub.cpp',
            'src/nt_internals.h',
            'src/policy_target.cc',
            'src/policy_target.h',
            'src/sandbox_nt_types.h',
            'src/sandbox_nt_util.cc',
            'src/sandbox_nt_util.h',
            'src/filesystem_dispatcher.cc',
            'src/filesystem_dispatcher.h',
            'src/filesystem_interception.cc',
            'src/filesystem_interception.h',
            'src/filesystem_policy.cc',
            'src/filesystem_policy.h',
            'src/named_pipe_dispatcher.cc',
            'src/named_pipe_dispatcher.h',
            'src/named_pipe_interception.cc',
            'src/named_pipe_interception.h',
            'src/named_pipe_policy.cc',
            'src/named_pipe_policy.h',
            'src/policy_params.h',
            'src/process_thread_dispatcher.cc',
            'src/process_thread_dispatcher.h',
            'src/process_thread_interception.cc',
            'src/process_thread_interception.h',
            'src/process_thread_policy.cc',
            'src/process_thread_policy.h',
            'src/registry_dispatcher.cc',
            'src/registry_dispatcher.h',
            'src/registry_interception.cc',
            'src/registry_interception.h',
            'src/registry_policy.cc',
            'src/registry_policy.h',
            'src/sync_dispatcher.cc',
            'src/sync_dispatcher.h',
            'src/sync_interception.cc',
            'src/sync_interception.h',
            'src/sync_policy.cc',
            'src/sync_policy.h',
            'src/crosscall_client.h',
            'src/crosscall_params.h',
            'src/crosscall_server.cc',
            'src/crosscall_server.h',
            'src/ipc_tags.h',
            'src/sharedmem_ipc_client.cc',
            'src/sharedmem_ipc_client.h',
            'src/sharedmem_ipc_server.cc',
            'src/sharedmem_ipc_server.h',
            'src/policy_engine_opcodes.cc',
            'src/policy_engine_opcodes.h',
            'src/policy_engine_params.h',
            'src/policy_engine_processor.cc',
            'src/policy_engine_processor.h',
            'src/policy_low_level.cc',
            'src/policy_low_level.h',
            'src/sandbox_policy_base.cc',
            'src/sandbox_policy_base.h',
            'src/broker_services.cc',
            'src/broker_services.h',
            'src/internal_types.h',
            'src/policy_broker.cc',
            'src/policy_broker.h',
            'src/sandbox.cc',
            'src/sandbox.h',
            'src/sandbox_factory.h',
            'src/sandbox_policy.h',
            'src/sandbox_types.h',
            'src/sandbox_utils.cc',
            'src/sandbox_utils.h',
            'src/shared_handles.cc',
            'src/shared_handles.h',
            'src/target_process.cc',
            'src/target_process.h',
            'src/target_services.cc',
            'src/target_services.h',
            'src/win2k_threadpool.cc',
            'src/win2k_threadpool.h',
            'src/win_utils.cc',
            'src/win_utils.h',
            'src/window.h',
            'src/window.cc',
          ],
          'include_dirs': [
            '..',
          ],
          'copies': [
            {
              'destination': '<(PRODUCT_DIR)',
              'files': [
                'wow_helper/wow_helper.exe',
                'wow_helper/wow_helper.pdb',
              ],
            },
          ],
          'direct_dependent_settings': {
            'include_dirs': [
              'src',
              '..',
            ],
          },
        },
        {
          'target_name': 'sbox_integration_tests',
          'type': 'executable',
          'dependencies': [
            'sandbox',
            '../testing/gtest.gyp:gtest',
          ],
          'sources': [
            'tests/common/controller.cc',
            'tests/common/controller.h',
            'tests/integration_tests/integration_tests.cc',
            'src/dep_test.cc',
            'src/file_policy_test.cc',
            'tests/integration_tests/integration_tests_test.cc',
            'src/integrity_level_test.cc',
            'src/ipc_ping_test.cc',
            'src/named_pipe_policy_test.cc',
            'src/policy_target_test.cc',
            'src/process_policy_test.cc',
            'src/registry_policy_test.cc',
            'src/sync_policy_test.cc',
            'src/unload_dll_test.cc',
          ],
        },
        {
          'target_name': 'sbox_validation_tests',
          'type': 'executable',
          'dependencies': [
            'sandbox',
            '../testing/gtest.gyp:gtest',
          ],
          'sources': [
            'tests/common/controller.cc',
            'tests/common/controller.h',
            'tests/validation_tests/unit_tests.cc',
            'tests/validation_tests/commands.cc',
            'tests/validation_tests/commands.h',
            'tests/validation_tests/suite.cc',
          ],
        },
        {
          'target_name': 'sbox_unittests',
          'type': 'executable',
          'dependencies': [
            'sandbox',
            '../testing/gtest.gyp:gtest',
          ],
          'sources': [
            'tests/unit_tests/unit_tests.cc',
            'src/interception_unittest.cc',
            'src/service_resolver_unittest.cc',
            'src/restricted_token_unittest.cc',
            'src/job_unittest.cc',
            'src/sid_unittest.cc',
            'src/policy_engine_unittest.cc',
            'src/policy_low_level_unittest.cc',
            'src/policy_opcodes_unittest.cc',
            'src/ipc_unittest.cc',
            'src/threadpool_unittest.cc',
          ],
        },
        {
          'target_name': 'sandbox_poc',
          'type': 'executable',
          'dependencies': [
            'sandbox',
            'pocdll',
          ],
          'sources': [
            'sandbox_poc/main_ui_window.cc',
            'sandbox_poc/main_ui_window.h',
            'sandbox_poc/resource.h',
            'sandbox_poc/sandbox.cc',
            'sandbox_poc/sandbox.h',
            'sandbox_poc/sandbox.ico',
            'sandbox_poc/sandbox.rc',
          ],
          'link_settings': {
            'libraries': [
              '-lcomctl32.lib',
            ],
          },
          'msvs_settings': {
            'VCLinkerTool': {
              'SubSystem': '2',         # Set /SUBSYSTEM:WINDOWS
            },
          },
        },
        {
          'target_name': 'pocdll',
          'type': 'shared_library',
          'sources': [
            'sandbox_poc/pocdll/exports.h',
            'sandbox_poc/pocdll/fs.cc',
            'sandbox_poc/pocdll/handles.cc',
            'sandbox_poc/pocdll/invasive.cc',
            'sandbox_poc/pocdll/network.cc',
            'sandbox_poc/pocdll/pocdll.cc',
            'sandbox_poc/pocdll/processes_and_threads.cc',
            'sandbox_poc/pocdll/registry.cc',
            'sandbox_poc/pocdll/spyware.cc',
            'sandbox_poc/pocdll/utils.h',
          ],
          'defines': [
            'POCDLL_EXPORTS',
          ],
          'include_dirs': [
            '..',
          ],
        },
      ],
    }],
  ],
}

# Local Variables:
# tab-width:2
# indent-tabs-mode:nil
# End:
# vim: set expandtab tabstop=2 shiftwidth=2: