2005-08-22 21:17:10 +00:00
|
|
|
## <summary>Fast incremental file transfer for synchronization</summary>
|
2006-04-21 15:08:21 +00:00
|
|
|
|
|
|
|
########################################
|
|
|
|
## <summary>
|
|
|
|
## Make rsync an entry point for
|
|
|
|
## the specified domain.
|
|
|
|
## </summary>
|
|
|
|
## <param name="domain">
|
|
|
|
## <summary>
|
|
|
|
## The domain for which init scripts are an entrypoint.
|
|
|
|
## </summary>
|
|
|
|
## </param>
|
|
|
|
# cjp: added for portage
|
|
|
|
interface(`rsync_entry_type',`
|
|
|
|
gen_require(`
|
|
|
|
type rsync_exec_t;
|
|
|
|
')
|
|
|
|
|
2008-07-23 21:38:39 +00:00
|
|
|
domain_entry_file($1, rsync_exec_t)
|
2006-04-21 15:08:21 +00:00
|
|
|
')
|
|
|
|
|
|
|
|
########################################
|
|
|
|
## <summary>
|
|
|
|
## Execute a rsync in a specified domain.
|
|
|
|
## </summary>
|
|
|
|
## <desc>
|
2008-12-03 19:16:20 +00:00
|
|
|
## <p>
|
2006-04-21 15:08:21 +00:00
|
|
|
## Execute a rsync in a specified domain.
|
2008-12-03 19:16:20 +00:00
|
|
|
## </p>
|
|
|
|
## <p>
|
|
|
|
## No interprocess communication (signals, pipes,
|
|
|
|
## etc.) is provided by this interface since
|
|
|
|
## the domains are not owned by this module.
|
|
|
|
## </p>
|
2006-04-21 15:08:21 +00:00
|
|
|
## </desc>
|
|
|
|
## <param name="source_domain">
|
|
|
|
## <summary>
|
|
|
|
## Domain to transition from.
|
|
|
|
## </summary>
|
|
|
|
## </param>
|
|
|
|
## <param name="target_domain">
|
|
|
|
## <summary>
|
|
|
|
## Domain to transition to.
|
|
|
|
## </summary>
|
|
|
|
## </param>
|
|
|
|
# cjp: added for portage
|
|
|
|
interface(`rsync_entry_spec_domtrans',`
|
|
|
|
gen_require(`
|
|
|
|
type rsync_exec_t;
|
|
|
|
')
|
|
|
|
|
2008-07-23 21:38:39 +00:00
|
|
|
domain_trans($1, rsync_exec_t, $2)
|
2006-04-21 15:08:21 +00:00
|
|
|
')
|
|
|
|
|
|
|
|
########################################
|
|
|
|
## <summary>
|
|
|
|
## Execute a rsync in a specified domain.
|
|
|
|
## </summary>
|
|
|
|
## <desc>
|
2008-12-03 19:16:20 +00:00
|
|
|
## <p>
|
2006-04-21 15:08:21 +00:00
|
|
|
## Execute a rsync in a specified domain.
|
2008-12-03 19:16:20 +00:00
|
|
|
## </p>
|
|
|
|
## <p>
|
|
|
|
## No interprocess communication (signals, pipes,
|
|
|
|
## etc.) is provided by this interface since
|
|
|
|
## the domains are not owned by this module.
|
|
|
|
## </p>
|
2006-04-21 15:08:21 +00:00
|
|
|
## </desc>
|
|
|
|
## <param name="source_domain">
|
|
|
|
## <summary>
|
|
|
|
## Domain to transition from.
|
|
|
|
## </summary>
|
|
|
|
## </param>
|
|
|
|
## <param name="target_domain">
|
|
|
|
## <summary>
|
|
|
|
## Domain to transition to.
|
|
|
|
## </summary>
|
|
|
|
## </param>
|
|
|
|
# cjp: added for portage
|
|
|
|
interface(`rsync_entry_domtrans',`
|
|
|
|
gen_require(`
|
|
|
|
type rsync_exec_t;
|
|
|
|
')
|
|
|
|
|
2008-07-23 21:38:39 +00:00
|
|
|
domain_auto_trans($1, rsync_exec_t, $2)
|
2006-04-21 15:08:21 +00:00
|
|
|
')
|
2006-04-28 18:30:02 +00:00
|
|
|
|
|
|
|
########################################
|
|
|
|
## <summary>
|
|
|
|
## Execute rsync in the caller domain domain.
|
|
|
|
## </summary>
|
|
|
|
## <param name="domain">
|
|
|
|
## <summary>
|
|
|
|
## Domain allowed access.
|
|
|
|
## </summary>
|
|
|
|
## </param>
|
2006-09-06 22:07:25 +00:00
|
|
|
## <rolecap/>
|
2006-04-28 18:30:02 +00:00
|
|
|
#
|
|
|
|
interface(`rsync_exec',`
|
|
|
|
gen_require(`
|
|
|
|
type rsync_exec_t;
|
|
|
|
')
|
|
|
|
|
2008-07-23 21:38:39 +00:00
|
|
|
can_exec($1, rsync_exec_t)
|
2006-04-28 18:30:02 +00:00
|
|
|
')
|
2010-01-05 15:26:14 +00:00
|
|
|
|
|
|
|
########################################
|
|
|
|
## <summary>
|
|
|
|
## Read rsync config files.
|
|
|
|
## </summary>
|
|
|
|
## <param name="domain">
|
|
|
|
## <summary>
|
|
|
|
## Domain allowed.
|
|
|
|
## </summary>
|
|
|
|
## </param>
|
|
|
|
#
|
|
|
|
interface(`rsync_read_config',`
|
|
|
|
gen_require(`
|
|
|
|
type rsync_etc_t;
|
|
|
|
')
|
|
|
|
|
2010-02-08 18:38:48 +00:00
|
|
|
allow $1 rsync_etc_t:file read_file_perms;
|
2010-01-05 15:26:14 +00:00
|
|
|
files_search_etc($1)
|
|
|
|
')
|
|
|
|
|
|
|
|
########################################
|
|
|
|
## <summary>
|
|
|
|
## Write to rsync config files.
|
|
|
|
## </summary>
|
|
|
|
## <param name="domain">
|
|
|
|
## <summary>
|
|
|
|
## Domain allowed.
|
|
|
|
## </summary>
|
|
|
|
## </param>
|
|
|
|
#
|
|
|
|
interface(`rsync_write_config',`
|
|
|
|
gen_require(`
|
|
|
|
type rsync_etc_t;
|
|
|
|
')
|
|
|
|
|
2010-02-08 18:38:48 +00:00
|
|
|
allow $1 rsync_etc_t:file read_file_perms;
|
2010-01-05 15:26:14 +00:00
|
|
|
files_search_etc($1)
|
|
|
|
')
|