• Home
  • Line#
  • Scopes#
  • Navigate#
  • Raw
  • Download
1# FLASK
2
3#
4# Define the security object classes
5#
6
7class security
8class process
9class system
10class capability
11
12# file-related classes
13class filesystem
14class file
15class dir
16class fd
17class lnk_file
18class chr_file
19class blk_file
20class sock_file
21class fifo_file
22
23# network-related classes
24class socket
25class tcp_socket
26class udp_socket
27class rawip_socket
28class node
29class netif
30class netlink_socket
31class packet_socket
32class key_socket
33class unix_stream_socket
34class unix_dgram_socket
35
36# sysv-ipc-related clases
37class sem
38class msg
39class msgq
40class shm
41class ipc
42
43# FLASK
44# FLASK
45
46#
47# Define initial security identifiers
48#
49
50sid kernel
51
52
53# FLASK
54#
55# Define common prefixes for access vectors
56#
57# common common_name { permission_name ... }
58
59
60#
61# Define a common prefix for file access vectors.
62#
63
64common file
65{
66	ioctl
67	read
68	write
69	create
70	getattr
71	setattr
72	lock
73	relabelfrom
74	relabelto
75	append
76	unlink
77	link
78	rename
79	execute
80	swapon
81	quotaon
82	mounton
83}
84
85
86#
87# Define a common prefix for socket access vectors.
88#
89
90common socket
91{
92# inherited from file
93	ioctl
94	read
95	write
96	create
97	getattr
98	setattr
99	lock
100	relabelfrom
101	relabelto
102	append
103# socket-specific
104	bind
105	connect
106	listen
107	accept
108	getopt
109	setopt
110	shutdown
111	recvfrom
112	sendto
113	recv_msg
114	send_msg
115	name_bind
116}
117
118#
119# Define a common prefix for ipc access vectors.
120#
121
122common ipc
123{
124	create
125	destroy
126	getattr
127	setattr
128	read
129	write
130	associate
131	unix_read
132	unix_write
133}
134
135#
136# Define the access vectors.
137#
138# class class_name [ inherits common_name ] { permission_name ... }
139
140
141#
142# Define the access vector interpretation for file-related objects.
143#
144
145class filesystem
146{
147	mount
148	remount
149	unmount
150	getattr
151	relabelfrom
152	relabelto
153	transition
154	associate
155	quotamod
156	quotaget
157}
158
159class dir
160inherits file
161{
162	add_name
163	remove_name
164	reparent
165	search
166	rmdir
167}
168
169class file
170inherits file
171{
172	execute_no_trans
173	entrypoint
174}
175
176class lnk_file
177inherits file
178
179class chr_file
180inherits file
181
182class blk_file
183inherits file
184
185class sock_file
186inherits file
187
188class fifo_file
189inherits file
190
191class fd
192{
193	use
194}
195
196
197#
198# Define the access vector interpretation for network-related objects.
199#
200
201class socket
202inherits socket
203
204class tcp_socket
205inherits socket
206{
207	connectto
208	newconn
209	acceptfrom
210}
211
212class udp_socket
213inherits socket
214
215class rawip_socket
216inherits socket
217
218class node
219{
220	tcp_recv
221	tcp_send
222	udp_recv
223	udp_send
224	rawip_recv
225	rawip_send
226	enforce_dest
227}
228
229class netif
230{
231	tcp_recv
232	tcp_send
233	udp_recv
234	udp_send
235	rawip_recv
236	rawip_send
237}
238
239class netlink_socket
240inherits socket
241
242class packet_socket
243inherits socket
244
245class key_socket
246inherits socket
247
248class unix_stream_socket
249inherits socket
250{
251	connectto
252	newconn
253	acceptfrom
254}
255
256class unix_dgram_socket
257inherits socket
258
259
260#
261# Define the access vector interpretation for process-related objects
262#
263
264class process
265{
266	fork
267	transition
268	sigchld # commonly granted from child to parent
269	sigkill # cannot be caught or ignored
270	sigstop # cannot be caught or ignored
271	signull # for kill(pid, 0)
272	signal  # all other signals
273	ptrace
274	getsched
275	setsched
276	getsession
277	getpgid
278	setpgid
279	getcap
280	setcap
281	share
282}
283
284
285#
286# Define the access vector interpretation for ipc-related objects
287#
288
289class ipc
290inherits ipc
291
292class sem
293inherits ipc
294
295class msgq
296inherits ipc
297{
298	enqueue
299}
300
301class msg
302{
303	send
304	receive
305}
306
307class shm
308inherits ipc
309{
310	lock
311}
312
313
314#
315# Define the access vector interpretation for the security server.
316#
317
318class security
319{
320	compute_av
321	transition_sid
322	member_sid
323	sid_to_context
324	context_to_sid
325	load_policy
326	get_sids
327	change_sid
328	get_user_sids
329}
330
331
332#
333# Define the access vector interpretation for system operations.
334#
335
336class system
337{
338	ipc_info
339	avc_toggle
340	nfsd_control
341	bdflush
342	syslog_read
343	syslog_mod
344	syslog_console
345	ichsid
346}
347
348#
349# Define the access vector interpretation for controlling capabilities
350#
351
352class capability
353{
354	# The capabilities are defined in include/linux/capability.h
355	# Care should be taken to ensure that these are consistent with
356	# those definitions. (Order matters)
357
358	chown
359	dac_override
360	dac_read_search
361	fowner
362	fsetid
363	kill
364	setgid
365	setuid
366	setpcap
367	linux_immutable
368	net_bind_service
369	net_broadcast
370	net_admin
371	net_raw
372	ipc_lock
373	ipc_owner
374	sys_module
375	sys_rawio
376	sys_chroot
377	sys_ptrace
378	sys_pacct
379	sys_admin
380	sys_boot
381	sys_nice
382	sys_resource
383	sys_time
384	sys_tty_config
385	mknod
386	lease
387}
388
389ifdef(`enable_mls',`
390sensitivity s0;
391
392#
393# Define the ordering of the sensitivity levels (least to greatest)
394#
395dominance { s0 }
396
397
398#
399# Define the categories
400#
401# Each category has a name and zero or more aliases.
402#
403category c0; category c1; category c2; category c3;
404category c4; category c5; category c6; category c7;
405category c8; category c9; category c10; category c11;
406category c12; category c13; category c14; category c15;
407category c16; category c17; category c18; category c19;
408category c20; category c21; category c22; category c23;
409
410level s0:c0.c23;
411
412mlsconstrain file { write setattr append unlink link rename ioctl lock execute relabelfrom }
413	( h1 dom h2 );
414')
415
416####################################
417####################################
418#####################################
419
420#g_b stands for global base
421
422type enable_optional;
423
424#decorative type for finding this decl, every block should have one
425type tag_g_b;
426
427attribute g_b_attr_1;
428attribute g_b_attr_2;
429attribute g_b_attr_3;
430attribute g_b_attr_4;
431attribute g_b_attr_5;
432attribute g_b_attr_6;
433
434type g_b_type_1, g_b_attr_1;
435type g_b_type_2, g_b_attr_2;
436type g_b_type_3;
437
438role g_b_role_1;
439role g_b_role_2;
440role g_b_role_3;
441role g_b_role_4;
442role g_b_role_1 types g_b_type_1;
443role g_b_role_2 types g_b_type_2;
444role g_b_role_3 types g_b_type_2;
445role g_b_role_4 types g_b_type_2;
446
447bool g_b_bool_1 false;
448bool g_b_bool_2 true;
449
450allow g_b_type_1 g_b_type_2 : security { compute_av load_policy };
451allow g_b_type_1 g_b_type_2 : file *; # test *
452allow g_b_type_1 g_b_type_2 : process ~ptrace; #test ~
453
454typealias g_b_type_3 alias g_b_alias_1;
455
456if (g_b_bool_1) {
457	allow g_b_type_1 g_b_type_2: lnk_file read;
458}
459
460
461optional {
462	require {
463		type enable_optional;
464		attribute g_m1_attr_2;
465	}
466	type tag_o1_b;
467
468	attribute o1_b_attr_1;
469	type o1_b_type_1, o1_b_attr_1;
470	bool o1_b_bool_1 true;
471	role o1_b_role_1;
472	role o1_b_role_1 types o1_b_type_1;
473	role o1_b_role_2;
474	role o1_b_role_2 types o1_b_type_1;
475
476	attribute o1_b_attr_2;
477
478	type o1_b_type_2, g_m1_attr_2;
479
480	if (o1_b_bool_1) {
481		allow o1_b_type_1 o1_b_type_2: lnk_file write;
482	}
483
484}
485
486optional {
487	require {
488		# this should be activated by module 1
489		type g_m1_type_1;
490		attribute o3_m1_attr_2;
491	}
492	type tag_o2_b;
493
494	type o2_b_type_1, o3_m1_attr_2;
495}
496
497optional {
498	require {
499		#this block should not come on
500		type invalid_type;
501	}
502	type tag_o3_b;
503
504
505	attribute o3_b_attr_1;
506	type o3_b_type_1;
507	bool o3_b_bool_1 true;
508
509	role o3_b_role_1;
510	role o3_b_role_1 types o3_b_type_1;
511
512	allow g_b_type_1 invalid_type : sem { create destroy };
513}
514
515optional {
516	require {
517		# also should be enabled by module 1
518		type enable_optional;
519		type g_m1_type_1;
520		attribute o3_m1_attr_1;
521		attribute g_m1_attr_3;
522	}
523
524	type tag_o4_b;
525
526	attribute o4_b_attr_1;
527
528	role o4_b_role_1;
529	role o4_b_role_1 types g_m1_type_1;
530
531	# test for attr declared in module optional, added to in base optional
532	type o4_b_type_1, o3_m1_attr_1;
533
534	type o4_b_type_2, g_m1_attr_3;
535}
536
537optional {
538	require {
539		attribute g_m1_attr_4;
540		attribute o4_m1_attr_1;
541	}
542	type tag_o5_b;
543
544	type o5_b_type_1, g_m1_attr_4;
545	type o5_b_type_2, o4_m1_attr_1;
546}
547
548optional {
549	require {
550		type enable_optional;
551	}
552	type tag_o6_b;
553
554	typealias g_b_type_3 alias g_b_alias_2;
555}
556
557optional {
558	require {
559		type g_m_alias_1;
560	}
561	type tag_o7_b;
562
563	allow g_m_alias_1 enable_optional:file read;
564}
565
566gen_user(g_b_user_1,, g_b_role_1, s0, s0 - s0:c0.c23)
567gen_user(g_b_user_2,, g_b_role_1, s0, s0 - s0:c0, c1, c3, c4, c5)
568
569####################################
570#line 1 "initial_sid_contexts"
571
572sid kernel	gen_context(g_b_user_1:g_b_role_1:g_b_type_1, s0)
573
574
575############################################
576#line 1 "fs_use"
577#
578fs_use_xattr ext2 gen_context(g_b_user_1:object_r:g_b_type_1, s0);
579fs_use_xattr ext3 gen_context(g_b_user_1:object_r:g_b_type_1, s0);
580fs_use_xattr reiserfs gen_context(g_b_user_1:object_r:g_b_type_1, s0);
581
582
583genfscon proc /				gen_context(g_b_user_1:object_r:g_b_type_1, s0)
584
585
586####################################
587#line 1 "net_contexts"
588
589#portcon tcp 21 g_b_user_1:object_r:net_foo_t:s0
590
591#netifcon lo g_b_user_1:object_r:net_foo_t g_b_user_1:object_r:net_foo_t:s0
592
593#
594#nodecon 127.0.0.1 255.255.255.255 g_b_user_1:object_r:net_foo_t:s0
595
596nodecon ::1 FFFF:FFFF:FFFF:FFFF:FFFF:FFFF:FFFF:FFFF gen_context(g_b_user_1:object_r:g_b_type_1, s0)
597
598
599
600
601