mirror of
https://github.com/SELinuxProject/setools
synced 2025-01-30 19:51:39 +00:00
285 lines
5.2 KiB
Plaintext
285 lines
5.2 KiB
Plaintext
class infoflow
|
|
class infoflow2
|
|
class infoflow3
|
|
class infoflow4
|
|
class infoflow5
|
|
class infoflow6
|
|
class infoflow7
|
|
|
|
sid kernel
|
|
sid security
|
|
|
|
common infoflow
|
|
{
|
|
low_w
|
|
med_w
|
|
hi_w
|
|
low_r
|
|
med_r
|
|
hi_r
|
|
}
|
|
|
|
class infoflow
|
|
inherits infoflow
|
|
|
|
class infoflow2
|
|
inherits infoflow
|
|
{
|
|
super_w
|
|
super_r
|
|
}
|
|
|
|
class infoflow3
|
|
{
|
|
null
|
|
}
|
|
|
|
class infoflow4
|
|
inherits infoflow
|
|
|
|
class infoflow5
|
|
inherits infoflow
|
|
|
|
class infoflow6
|
|
inherits infoflow
|
|
|
|
class infoflow7
|
|
inherits infoflow
|
|
{
|
|
super_w
|
|
super_r
|
|
super_none
|
|
super_both
|
|
super_unmapped
|
|
}
|
|
|
|
sensitivity s0;
|
|
sensitivity s1;
|
|
sensitivity s2;
|
|
sensitivity s3;
|
|
sensitivity s4;
|
|
sensitivity s5;
|
|
sensitivity s6;
|
|
|
|
dominance { s0 s1 s2 s3 s4 s5 s6 }
|
|
|
|
category c0;
|
|
category c1;
|
|
category c2;
|
|
category c3;
|
|
category c4;
|
|
|
|
#level decl
|
|
level s0:c0.c4;
|
|
level s1:c0.c4;
|
|
level s2:c0.c4;
|
|
level s3:c0.c4;
|
|
level s4:c0.c4;
|
|
level s5:c0.c4;
|
|
level s6:c0.c4;
|
|
|
|
|
|
#some constraints
|
|
mlsconstrain infoflow hi_r ((l1 dom l2) or (t1 == mls_exempt));
|
|
|
|
attribute mls_exempt;
|
|
|
|
type system;
|
|
role system;
|
|
role system types system;
|
|
|
|
role role30_r;
|
|
role role31a_r;
|
|
role role31b_r;
|
|
role role31c_r;
|
|
|
|
role role30_r types system;
|
|
role role31a_r types system;
|
|
role role31b_r types system;
|
|
role role31c_r types system;
|
|
|
|
type type40;
|
|
type type41a;
|
|
type type41b;
|
|
type type41c;
|
|
role system types { type40 type41a type41b type41c };
|
|
|
|
################################################################################
|
|
# Type enforcement declarations and rules
|
|
|
|
allow system system:infoflow3 null;
|
|
|
|
################################################################################
|
|
|
|
#users
|
|
user system roles { system role30_r role31a_r role31b_r role31c_r } level s0 range s0 - s6:c0.c4;
|
|
user user20 roles system level s0 range s0 - s2:c0.c4;
|
|
user user21a roles system level s0 range s0 - s2:c0.c4;
|
|
user user21b roles system level s0 range s0 - s2:c0.c4;
|
|
user user21c roles system level s0 range s0 - s2:c0.c4;
|
|
|
|
#normal constraints
|
|
constrain infoflow hi_w (u1 == u2);
|
|
|
|
#isids
|
|
sid kernel system:system:system:s0
|
|
sid security system:system:system:s0
|
|
|
|
#fs_use
|
|
fs_use_trans devpts system:object_r:system:s0;
|
|
fs_use_xattr ext3 system:object_r:system:s0;
|
|
fs_use_task pipefs system:object_r:system:s0;
|
|
|
|
#genfscon
|
|
genfscon proc / system:object_r:system:s1
|
|
genfscon proc /sys system:object_r:system:s0
|
|
genfscon selinuxfs / system:object_r:system:s2:c0.c4
|
|
|
|
portcon tcp 80 system:object_r:system:s0
|
|
|
|
netifcon eth0 system:object_r:system:s0 system:object_r:system:s0
|
|
|
|
# test 1:
|
|
# name: test1, exact
|
|
# port: unset
|
|
# user: unset
|
|
# role: unset
|
|
# type: unset
|
|
# range: unset
|
|
ibendportcon test1 1 system:system:system:s0:c0.c1
|
|
|
|
# test 2:
|
|
# name: test2(a|b), regex
|
|
# port: unset
|
|
# user: unset
|
|
# role: unset
|
|
# type: unset
|
|
# range: unset
|
|
ibendportcon test2a 2 system:system:system:s0:c0.c1
|
|
ibendportcon test2b 3 system:system:system:s0:c0.c1
|
|
ibendportcon test2c 4 system:system:system:s0:c0.c1
|
|
|
|
# test 10:
|
|
# name: unset
|
|
# port: 10
|
|
# user: unset
|
|
# role: unset
|
|
# type: unset
|
|
# range: unset
|
|
ibendportcon test10 10 system:system:system:s0:c0.c1
|
|
|
|
# test 20:
|
|
# name: unset
|
|
# port: unset
|
|
# user: user20, exact
|
|
# role: unset
|
|
# type: unset
|
|
# range: unset
|
|
ibendportcon test20 20 user20:system:system:s0:c0.c1
|
|
|
|
# test 21:
|
|
# name: unset
|
|
# port: unset
|
|
# user: user21(a|b), regex
|
|
# role: unset
|
|
# type: unset
|
|
# range: unset
|
|
ibendportcon test21a 21 user21a:system:system:s0:c0.c1
|
|
ibendportcon test21b 22 user21b:system:system:s0:c0.c1
|
|
ibendportcon test21c 23 user21c:system:system:s0:c0.c1
|
|
|
|
# test 30:
|
|
# name: unset
|
|
# port: unset
|
|
# user: unset
|
|
# role: role30_r, exact
|
|
# type: unset
|
|
# range: unset
|
|
ibendportcon test30 30 system:role30_r:system:s0:c0.c1
|
|
|
|
# test 31:
|
|
# name: unset
|
|
# port: unset
|
|
# user: unset
|
|
# role: role30(a|c)_r, regex
|
|
# type: unset
|
|
# range: unset
|
|
ibendportcon test31a 31 system:role31a_r:system:s0:c0.c1
|
|
ibendportcon test31b 32 system:role31b_r:system:s0:c0.c1
|
|
ibendportcon test31c 33 system:role31c_r:system:s0:c0.c1
|
|
|
|
# test 40:
|
|
# name: unset
|
|
# port: unset
|
|
# user: unset
|
|
# role: unset
|
|
# type: type40
|
|
# range: unset
|
|
ibendportcon test40 40 system:system:type40:s0:c0.c1
|
|
|
|
# test 41:
|
|
# name: unset
|
|
# port: unset
|
|
# user: unset
|
|
# role: unset
|
|
# type: type41(b|c)
|
|
# range: unset
|
|
ibendportcon test41a 41 system:system:type41a:s0:c0.c1
|
|
ibendportcon test41b 42 system:system:type41b:s0:c0.c1
|
|
ibendportcon test41c 43 system:system:type41c:s0:c0.c1
|
|
|
|
# test 50:
|
|
# name: unset
|
|
# port: unset
|
|
# user: unset
|
|
# role: unset
|
|
# type: unset
|
|
# range: equal
|
|
ibendportcon test50 50 system:system:system:s0:c1 - s0:c0.c4
|
|
|
|
# test 51:
|
|
# name: unset
|
|
# port: unset
|
|
# user: unset
|
|
# role: unset
|
|
# type: unset
|
|
# range: overlap
|
|
ibendportcon test51 51 system:system:system:s1:c1 - s1:c1.c3
|
|
|
|
# test 52:
|
|
# name: unset
|
|
# port: unset
|
|
# user: unset
|
|
# role: unset
|
|
# type: unset
|
|
# range: subset
|
|
ibendportcon test52 52 system:system:system:s2:c1 - s2:c1.c3
|
|
|
|
# test 53:
|
|
# name: unset
|
|
# port: unset
|
|
# user: unset
|
|
# role: unset
|
|
# type: unset
|
|
# range: superset
|
|
ibendportcon test53 53 system:system:system:s3:c1 - s3:c1.c3
|
|
|
|
# test 54:
|
|
# name: unset
|
|
# port: unset
|
|
# user: unset
|
|
# role: unset
|
|
# type: unset
|
|
# range: proper subset
|
|
ibendportcon test54 54 system:system:system:s4:c1 - s4:c1.c3
|
|
|
|
# test 55:
|
|
# name: unset
|
|
# port: unset
|
|
# user: unset
|
|
# role: unset
|
|
# type: unset
|
|
# range: proper superset
|
|
ibendportcon test55 55 system:system:system:s5:c1 - s5:c1.c3
|
|
|