1cyrus_selinux(8)             SELinux Policy cyrus             cyrus_selinux(8)
2
3
4

NAME

6       cyrus_selinux - Security Enhanced Linux Policy for the cyrus processes
7

DESCRIPTION

9       Security-Enhanced Linux secures the cyrus processes via flexible manda‐
10       tory access control.
11
12       The cyrus processes execute with the  cyrus_t  SELinux  type.  You  can
13       check  if  you have these processes running by executing the ps command
14       with the -Z qualifier.
15
16       For example:
17
18       ps -eZ | grep cyrus_t
19
20
21

ENTRYPOINTS

23       The cyrus_t SELinux type can be entered via the cyrus_exec_t file type.
24
25       The default entrypoint paths for the cyrus_t domain are the following:
26
27       /usr/lib/cyrus/master, /usr/lib/cyrus-imapd/cyrus-master
28

PROCESS TYPES

30       SELinux defines process types (domains) for each process running on the
31       system
32
33       You can see the context of a process using the -Z option to ps
34
35       Policy  governs  the  access confined processes have to files.  SELinux
36       cyrus policy is very flexible allowing users to setup their cyrus  pro‐
37       cesses in as secure a method as possible.
38
39       The following process types are defined for cyrus:
40
41       cyrus_t
42
43       Note:  semanage  permissive  -a cyrus_t can be used to make the process
44       type cyrus_t permissive. SELinux does not  deny  access  to  permissive
45       process  types, but the AVC (SELinux denials) messages are still gener‐
46       ated.
47
48

BOOLEANS

50       SELinux policy is customizable based on least access  required.   cyrus
51       policy is extremely flexible and has several booleans that allow you to
52       manipulate the policy and run cyrus with the tightest access possible.
53
54
55
56       If you want to allow users to resolve user passwd entries directly from
57       ldap  rather  then  using  a  sssd server, you must turn on the authlo‐
58       gin_nsswitch_use_ldap boolean. Disabled by default.
59
60       setsebool -P authlogin_nsswitch_use_ldap 1
61
62
63
64       If you want to allow all daemons to write corefiles to /, you must turn
65       on the daemons_dump_core boolean. Disabled by default.
66
67       setsebool -P daemons_dump_core 1
68
69
70
71       If  you  want  to enable cluster mode for daemons, you must turn on the
72       daemons_enable_cluster_mode boolean. Enabled by default.
73
74       setsebool -P daemons_enable_cluster_mode 1
75
76
77
78       If you want to allow all daemons to use tcp wrappers, you must turn  on
79       the daemons_use_tcp_wrapper boolean. Disabled by default.
80
81       setsebool -P daemons_use_tcp_wrapper 1
82
83
84
85       If  you  want to allow all daemons the ability to read/write terminals,
86       you must turn on the daemons_use_tty boolean. Disabled by default.
87
88       setsebool -P daemons_use_tty 1
89
90
91
92       If you want to deny any process from ptracing or  debugging  any  other
93       processes,  you  must  turn  on  the  deny_ptrace  boolean.  Enabled by
94       default.
95
96       setsebool -P deny_ptrace 1
97
98
99
100       If you want to allow any process  to  mmap  any  file  on  system  with
101       attribute  file_type,  you must turn on the domain_can_mmap_files bool‐
102       ean. Enabled by default.
103
104       setsebool -P domain_can_mmap_files 1
105
106
107
108       If you want to allow all domains write to kmsg_device, while kernel  is
109       executed  with  systemd.log_target=kmsg parameter, you must turn on the
110       domain_can_write_kmsg boolean. Disabled by default.
111
112       setsebool -P domain_can_write_kmsg 1
113
114
115
116       If you want to allow all domains to use other domains file descriptors,
117       you must turn on the domain_fd_use boolean. Enabled by default.
118
119       setsebool -P domain_fd_use 1
120
121
122
123       If  you  want to allow all domains to have the kernel load modules, you
124       must  turn  on  the  domain_kernel_load_modules  boolean.  Disabled  by
125       default.
126
127       setsebool -P domain_kernel_load_modules 1
128
129
130
131       If you want to allow all domains to execute in fips_mode, you must turn
132       on the fips_mode boolean. Enabled by default.
133
134       setsebool -P fips_mode 1
135
136
137
138       If you want to enable reading of urandom for all domains, you must turn
139       on the global_ssp boolean. Disabled by default.
140
141       setsebool -P global_ssp 1
142
143
144
145       If  you  want  to allow confined applications to run with kerberos, you
146       must turn on the kerberos_enabled boolean. Enabled by default.
147
148       setsebool -P kerberos_enabled 1
149
150
151
152       If you want to allow system to run with  NIS,  you  must  turn  on  the
153       nis_enabled boolean. Disabled by default.
154
155       setsebool -P nis_enabled 1
156
157
158
159       If  you  want to allow confined applications to use nscd shared memory,
160       you must turn on the nscd_use_shm boolean. Disabled by default.
161
162       setsebool -P nscd_use_shm 1
163
164
165

PORT TYPES

167       SELinux defines port types to represent TCP and UDP ports.
168
169       You can see the types associated with a port  by  using  the  following
170       command:
171
172       semanage port -l
173
174
175       Policy  governs  the  access  confined  processes  have to these ports.
176       SELinux cyrus policy is very flexible allowing  users  to  setup  their
177       cyrus processes in as secure a method as possible.
178
179       The following port types are defined for cyrus:
180
181
182       cyrus_imapd_port_t
183
184
185
186       Default Defined Ports:
187                 tcp 2005
188

MANAGED FILES

190       The SELinux process type cyrus_t can manage files labeled with the fol‐
191       lowing file types.  The paths listed are the default  paths  for  these
192       file types.  Note the processes UID still need to have DAC permissions.
193
194       cluster_conf_t
195
196            /etc/cluster(/.*)?
197
198       cluster_var_lib_t
199
200            /var/lib/pcsd(/.*)?
201            /var/lib/cluster(/.*)?
202            /var/lib/openais(/.*)?
203            /var/lib/pengine(/.*)?
204            /var/lib/corosync(/.*)?
205            /usr/lib/heartbeat(/.*)?
206            /var/lib/heartbeat(/.*)?
207            /var/lib/pacemaker(/.*)?
208
209       cluster_var_run_t
210
211            /var/run/crm(/.*)?
212            /var/run/cman_.*
213            /var/run/rsctmp(/.*)?
214            /var/run/aisexec.*
215            /var/run/heartbeat(/.*)?
216            /var/run/corosync-qnetd(/.*)?
217            /var/run/corosync-qdevice(/.*)?
218            /var/run/cpglockd.pid
219            /var/run/corosync.pid
220            /var/run/rgmanager.pid
221            /var/run/cluster/rgmanager.sk
222
223       cyrus_tmp_t
224
225
226       cyrus_var_lib_t
227
228            /var/imap(/.*)?
229            /var/lib/imap(/.*)?
230
231       cyrus_var_run_t
232
233            /var/run/cyrus.*
234
235       mail_spool_t
236
237            /var/mail(/.*)?
238            /var/spool/imap(/.*)?
239            /var/spool/mail(/.*)?
240            /var/spool/smtpd(/.*)?
241
242       root_t
243
244            /sysroot/ostree/deploy/.*-atomic.*/deploy(/.*)?
245            /
246            /initrd
247
248       snmpd_var_lib_t
249
250            /var/agentx(/.*)?
251            /var/net-snmp(/.*)
252            /var/lib/snmp(/.*)?
253            /var/net-snmp(/.*)?
254            /var/lib/net-snmp(/.*)?
255            /var/spool/snmptt(/.*)?
256            /usr/share/snmp/mibs/.index
257
258

FILE CONTEXTS

260       SELinux requires files to have an extended attribute to define the file
261       type.
262
263       You can see the context of a file using the -Z option to ls
264
265       Policy governs the access  confined  processes  have  to  these  files.
266       SELinux  cyrus  policy  is  very flexible allowing users to setup their
267       cyrus processes in as secure a method as possible.
268
269       STANDARD FILE CONTEXT
270
271       SELinux defines the file context types for the cyrus, if you wanted  to
272       store  files  with  these types in a diffent paths, you need to execute
273       the semanage command  to  sepecify  alternate  labeling  and  then  use
274       restorecon to put the labels on disk.
275
276       semanage fcontext -a -t cyrus_var_run_t '/srv/mycyrus_content(/.*)?'
277       restorecon -R -v /srv/mycyrus_content
278
279       Note:  SELinux  often  uses  regular expressions to specify labels that
280       match multiple files.
281
282       The following file types are defined for cyrus:
283
284
285
286       cyrus_exec_t
287
288       - Set files with the cyrus_exec_t type, if you want  to  transition  an
289       executable to the cyrus_t domain.
290
291
292       Paths:
293            /usr/lib/cyrus/master, /usr/lib/cyrus-imapd/cyrus-master
294
295
296       cyrus_initrc_exec_t
297
298       -  Set  files with the cyrus_initrc_exec_t type, if you want to transi‐
299       tion an executable to the cyrus_initrc_t domain.
300
301
302
303       cyrus_keytab_t
304
305       - Set files with the cyrus_keytab_t type, if  you  want  to  treat  the
306       files as kerberos keytab files.
307
308
309
310       cyrus_tmp_t
311
312       -  Set files with the cyrus_tmp_t type, if you want to store cyrus tem‐
313       porary files in the /tmp directories.
314
315
316
317       cyrus_var_lib_t
318
319       - Set files with the cyrus_var_lib_t type, if you  want  to  store  the
320       cyrus files under the /var/lib directory.
321
322
323       Paths:
324            /var/imap(/.*)?, /var/lib/imap(/.*)?
325
326
327       cyrus_var_run_t
328
329       -  Set  files  with  the cyrus_var_run_t type, if you want to store the
330       cyrus files under the /run or /var/run directory.
331
332
333
334       Note: File context can be temporarily modified with the chcon  command.
335       If  you want to permanently change the file context you need to use the
336       semanage fcontext command.  This will modify the SELinux labeling data‐
337       base.  You will need to use restorecon to apply the labels.
338
339

COMMANDS

341       semanage  fcontext  can also be used to manipulate default file context
342       mappings.
343
344       semanage permissive can also be used to manipulate  whether  or  not  a
345       process type is permissive.
346
347       semanage  module can also be used to enable/disable/install/remove pol‐
348       icy modules.
349
350       semanage port can also be used to manipulate the port definitions
351
352       semanage boolean can also be used to manipulate the booleans
353
354
355       system-config-selinux is a GUI tool available to customize SELinux pol‐
356       icy settings.
357
358

AUTHOR

360       This manual page was auto-generated using sepolicy manpage .
361
362

SEE ALSO

364       selinux(8), cyrus(8), semanage(8), restorecon(8), chcon(1), sepolicy(8)
365       , setsebool(8)
366
367
368
369cyrus                              19-04-25                   cyrus_selinux(8)
Impressum