setools/tests/ibendportconquery.conf
2018-11-25 10:51:23 -05:00

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