sbuild
1.7.1
|
Common chroot data. More...
#include <chroot.h>
Public Types | |
enum | setup_type { SETUP_START, SETUP_RECOVER, SETUP_STOP, EXEC_START, EXEC_STOP } |
Type of setup to perform. More... | |
enum | verbosity { VERBOSITY_QUIET, VERBOSITY_NORMAL, VERBOSITY_VERBOSE } |
Message verbosity. More... | |
enum | error_code { CHROOT_CREATE, CHROOT_DEVICE, CHROOT_TYPE, DEVICE_ABS, DEVICE_LOCK, DEVICE_NOTBLOCK, DEVICE_UNLOCK, DIRECTORY_ABS, FACET_ABSENT, FACET_INVALID, FACET_PRESENT, FILE_ABS, FILE_LOCK, FILE_NOTREG, FILE_OWNER, FILE_PERMS, FILE_UNLOCK, LOCATION_ABS, NAME_INVALID, SCRIPT_CONFIG_CV, SESSION_UNLINK, SESSION_WRITE, VERBOSITY_INVALID } |
Error codes. More... | |
typedef custom_error< error_code > | error |
Exception type. | |
typedef std::shared_ptr< chroot > | ptr |
A shared_ptr to a chroot object. | |
typedef std::shared_ptr< const chroot > | const_ptr |
A shared_ptr to a const chroot object. | |
typedef std::shared_ptr < facet::facet > | facet_ptr |
A shared pointer to a chroot facet. | |
typedef std::list< facet_ptr > | facet_list |
A list of chroot facets. | |
Public Member Functions | |
chroot () | |
The constructor. | |
chroot (const chroot &rhs) | |
The copy constructor. More... | |
virtual | ~chroot () |
The destructor. | |
chroot::ptr | clone () const |
Copy the chroot. More... | |
chroot::ptr | clone_session (const std::string &session_id, const std::string &alias, const std::string &user, bool root) const |
Create a session chroot. More... | |
chroot::ptr | clone_source () const |
Create a source chroot. More... | |
std::string const & | get_name () const |
Get the name of the chroot. More... | |
void | set_name (const std::string &name) |
Set the name of the chroot. More... | |
std::string const & | get_description () const |
Get the description of the chroot. More... | |
void | set_description (const std::string &description) |
Set the description of the chroot. More... | |
std::string const & | get_mount_location () const |
Get the mount location of the chroot. More... | |
void | set_mount_location (const std::string &location) |
Set the mount location of the chroot. More... | |
std::string | get_path () const |
Get the path to the chroot. More... | |
string_list const & | get_users () const |
Get the users allowed to access the chroot. More... | |
void | set_users (const string_list &users) |
Set the users allowed to access the chroot. More... | |
string_list const & | get_groups () const |
Get the groups allowed to access the chroot. More... | |
void | set_groups (const string_list &groups) |
Set the users allowed to access the chroot. More... | |
string_list const & | get_root_users () const |
Get the users allowed to access the chroot as root. More... | |
void | set_root_users (const string_list &users) |
Set the users allowed to access the chroot as root. More... | |
string_list const & | get_root_groups () const |
Get the groups allowed to access the chroot as root. More... | |
void | set_root_groups (const string_list &groups) |
Set the groups allowed to access the chroot as root. More... | |
string_list const & | get_aliases () const |
Get the aliases of the chroot. More... | |
void | set_aliases (const string_list &aliases) |
Set the aliases of the chroot. More... | |
bool | get_preserve_environment () const |
Check if the environment should be preserved in the chroot. More... | |
void | set_preserve_environment (bool preserve_environment) |
Set if the environment should be preserved in the chroot. More... | |
std::string const & | get_default_shell () const |
Get default shell. More... | |
void | set_default_shell (const std::string &default_shell) |
Set the default shell. More... | |
regex const & | get_environment_filter () const |
Get the environment filter of the chroot. More... | |
void | set_environment_filter (const regex &environment_filter) |
Set the environment filter of the chroot. More... | |
bool | get_active () const |
Get the activity status of the chroot. More... | |
bool | get_original () const |
Get the originality of the chroot. More... | |
void | set_original (bool original) |
Set the originality of the chroot. More... | |
bool | get_run_setup_scripts () const |
Check if chroot setup scripts will be run. More... | |
std::string const & | get_script_config () const |
Get the script configuration file for the chroot. More... | |
void | set_script_config (const std::string &script_config) |
Set the script configuration file for the chroot. More... | |
std::string const & | get_profile () const |
Get the configuration profile for the chroot. More... | |
void | set_profile (const std::string &profile) |
Set configuration profile for the chroot. More... | |
string_list const & | get_command_prefix () const |
Get the command_prefix for the chroot. More... | |
void | set_command_prefix (const string_list &command_prefix) |
Set the command_prefix for the chroot. More... | |
verbosity | get_verbosity () const |
Get the message verbosity. More... | |
const char * | get_verbosity_string () const |
Get the message verbosity as a readable string. More... | |
void | set_verbosity (verbosity verbosity) |
Set the message verbosity. More... | |
void | set_verbosity (const std::string &verbosity) |
Set the message verbosity. More... | |
std::string const & | get_chroot_type () const |
Get the type of the chroot. More... | |
void | setup_env (environment &env) const |
Set environment. More... | |
void | lock (setup_type type) |
Lock a chroot during setup. More... | |
void | unlock (setup_type type, int status) |
Unlock a chroot during setup. More... | |
template<typename T > | |
std::shared_ptr< T > | get_facet () |
Get a chroot facet. More... | |
template<typename T > | |
const std::shared_ptr< const T > | get_facet () const |
Get a chroot facet. More... | |
template<typename T > | |
std::shared_ptr< T > | get_facet_strict () |
Get a chroot facet. More... | |
template<typename T > | |
const std::shared_ptr< const T > | get_facet_strict () const |
Get a chroot facet. More... | |
facet_list & | get_facets () |
Get the list of all chroot facets. More... | |
const facet_list & | get_facets () const |
Get the list of all chroot facets. More... | |
template<typename T > | |
void | add_facet (std::shared_ptr< T > facet, bool copy=false) |
Add a chroot facet. More... | |
void | add_facet_by_name (facet::facet::ptr facet, bool copy=false) |
Add a chroot facet by name (rather than type). More... | |
template<typename T > | |
void | remove_facet () |
Remove a chroot facet. More... | |
template<typename T > | |
void | remove_facet (std::shared_ptr< T > facet) |
Remove a chroot facet. More... | |
template<typename T > | |
void | replace_facet (std::shared_ptr< T > facet) |
Replace an existing chroot facet with a new facet. More... | |
string_list | list_facets () const |
List all registered chroot facets. More... | |
facet::facet::session_flags | get_session_flags () const |
Get the session flags of the chroot. More... | |
void | get_details (format_detail &detail) const |
Get detailed information about the chroot for output. More... | |
void | print_details (std::ostream &stream) const |
Print detailed information about the chroot to a stream. More... | |
void | get_keyfile (keyfile &keyfile) const |
Copy the chroot properties into a keyfile. More... | |
void | set_keyfile (const keyfile &keyfile) |
Set the chroot properties from a keyfile. More... | |
string_list | get_used_keys () const |
Get a list of the keys used during keyfile parsing. More... | |
Static Public Member Functions | |
static chroot::ptr | create (const std::string &type) |
Create a chroot. More... | |
Protected Member Functions | |
void | setup_lock (setup_type type, bool lock, int status) |
Unlock a chroot during setup. More... | |
Private Attributes | |
std::string | name |
Chroot name. | |
std::string | description |
Chroot description. | |
string_list | users |
Users allowed to access the chroot. | |
string_list | groups |
Groups allowed to access the chroot. | |
string_list | root_users |
Users allowed to access the chroot as root. | |
string_list | root_groups |
Groups allowed to access the chroot as root. | |
string_list | aliases |
Alternative names for the chroot. | |
bool | preserve_environment |
Preserve environment? | |
std::string | default_shell |
Default shell. | |
regex | environment_filter |
Environment filter regex. | |
std::string | mount_location |
Location to mount chroot in the filesystem (if any). | |
bool | original |
Was the chroot automatically generated? | |
std::string | script_config |
Configuration of the setup and exec scripts. | |
std::string | profile |
Configuration profile for setup scripts (replaces script_config). | |
string_list | command_prefix |
Command prefix. | |
verbosity | message_verbosity |
The message verbosity. | |
facet_list | facets |
Contained chroot facets. | |
Friends | |
std::ostream & | operator<< (std::ostream &stream, const ptr &rhs) |
Print detailed information about the chroot to a stream. More... | |
keyfile const & | operator>> (const keyfile &keyfile, ptr &rhs) |
Chroot initialisation from a keyfile. More... | |
keyfile & | operator<< (keyfile &keyfile, const ptr &rhs) |
Chroot serialisation to a keyfile. More... | |
Common chroot data.
This class contains all of the metadata associated with a single chroot, for all chroot types. This is the in-core representation of a chroot definition in the configuration file, and may be initialised directly from an open keyfile.
Error codes.
sbuild::chroot::chroot::chroot | ( | const chroot & | rhs) |
void sbuild::chroot::chroot::add_facet | ( | std::shared_ptr< T > | facet, |
bool | copy = false |
||
) |
Add a chroot facet.
facet | the facet to add. |
copy | true if the facet has been copied, or false if this is a new instance. |
References FACET_INVALID, FACET_PRESENT, and facets.
Referenced by replace_facet(), sbuild::chroot::facet::lvm_snapshot::set_chroot(), sbuild::chroot::facet::loopback::set_chroot(), sbuild::chroot::facet::file::set_chroot(), sbuild::chroot::facet::directory::set_chroot(), sbuild::chroot::facet::btrfs_snapshot::set_chroot(), sbuild::chroot::facet::block_device::set_chroot(), sbuild::chroot::facet::custom::set_chroot(), sbuild::chroot::facet::block_device_base::set_chroot(), sbuild::chroot::facet::custom::set_session_cloneable(), and sbuild::chroot::facet::custom::set_source_cloneable().
|
inline |
Add a chroot facet by name (rather than type).
Any facet with the same name will be removed, prior to this facet being added.
facet | the facet to add. |
copy | true if the facet has been copied, or false if this is a new instance. |
References facets.
Referenced by chroot().
chroot::ptr sbuild::chroot::chroot::clone | ( | ) | const |
Copy the chroot.
This is a virtual copy constructor.
References chroot().
Referenced by sbuild::chroot::facet::session_clonable::clone_session(), and sbuild::chroot::facet::source_clonable::clone_source().
chroot::ptr sbuild::chroot::chroot::clone_session | ( | const std::string & | session_id, |
const std::string & | alias, | ||
const std::string & | user, | ||
bool | root | ||
) | const |
Create a session chroot.
session_id | the identifier (session_id) for the new session. |
alias | the alias used to initially identify the chroot. |
user | the user creating the session. |
root | true if the user has root access, otherwise false. |
chroot::ptr sbuild::chroot::chroot::clone_source | ( | ) | const |
Create a source chroot.
|
static |
Create a chroot.
This is a factory function.
type | the type of chroot to create. |
References chroot(), and CHROOT_TYPE.
bool sbuild::chroot::chroot::get_active | ( | ) | const |
Get the activity status of the chroot.
The chroot is active if it has been cloned as a session.
string_list const & sbuild::chroot::chroot::get_aliases | ( | ) | const |
Get the aliases of the chroot.
These are alternative names for the chroot.
References aliases.
Referenced by get_details(), and get_keyfile().
std::string const & sbuild::chroot::chroot::get_chroot_type | ( | ) | const |
Get the type of the chroot.
References sbuild::chroot::facet::facet::get_name().
Referenced by get_details(), get_keyfile(), and setup_env().
string_list const & sbuild::chroot::chroot::get_command_prefix | ( | ) | const |
Get the command_prefix for the chroot.
This is a command to prefix to any command run in the chroot.
References command_prefix.
Referenced by get_details(), and get_keyfile().
std::string const & sbuild::chroot::chroot::get_default_shell | ( | ) | const |
Get default shell.
References default_shell.
Referenced by get_details(), and get_keyfile().
std::string const & sbuild::chroot::chroot::get_description | ( | ) | const |
Get the description of the chroot.
References description.
Referenced by get_details(), get_keyfile(), and setup_env().
void sbuild::chroot::chroot::get_details | ( | format_detail & | detail) | const |
Get detailed information about the chroot for output.
detail | the details to output to. |
References sbuild::_(), sbuild::format_detail::add(), facets, get_aliases(), get_chroot_type(), get_command_prefix(), get_default_shell(), get_description(), get_environment_filter(), get_groups(), get_mount_location(), get_name(), get_path(), get_preserve_environment(), get_profile(), get_root_groups(), get_root_users(), get_run_setup_scripts(), get_script_config(), get_session_flags(), get_users(), get_verbosity_string(), sbuild::chroot::facet::facet::SESSION_CLONE, sbuild::chroot::facet::facet::SESSION_CREATE, and sbuild::chroot::facet::facet::SESSION_PURGE.
Referenced by print_details().
regex const & sbuild::chroot::chroot::get_environment_filter | ( | ) | const |
Get the environment filter of the chroot.
This is a POSIX extended regular expression used to remove insecure environment variables from the chroot environment.
References environment_filter.
Referenced by get_details(), and get_keyfile().
std::shared_ptr< T > sbuild::chroot::chroot::get_facet | ( | ) |
Get a chroot facet.
This is a templated method; use the correct type for the facet required.
References facets.
Referenced by sbuild::chroot::facet::block_device::chroot_session_setup(), sbuild::chroot::facet::loopback::chroot_session_setup(), sbuild::chroot::facet::mountable::get_keyfile(), sbuild::chroot::facet::lvm_snapshot::get_keyfile(), sbuild::chroot::facet::file::get_keyfile(), sbuild::chroot::facet::btrfs_snapshot::get_keyfile(), sbuild::chroot::facet::block_device_base::get_path(), sbuild::chroot::facet::loopback::get_path(), sbuild::chroot::facet::lvm_snapshot::get_session_flags(), sbuild::chroot::facet::custom::get_session_flags(), sbuild::chroot::facet::file::get_session_flags(), sbuild::chroot::facet::btrfs_snapshot::get_session_flags(), sbuild::chroot::facet::source_clonable::get_session_flags(), sbuild::chroot::facet::fsunion::get_session_flags(), sbuild::chroot::facet::lvm_snapshot::set_chroot(), sbuild::chroot::facet::loopback::set_chroot(), sbuild::chroot::facet::file::set_chroot(), sbuild::chroot::facet::btrfs_snapshot::set_chroot(), sbuild::chroot::facet::directory::set_chroot(), sbuild::chroot::facet::block_device::set_chroot(), sbuild::chroot::facet::custom::set_chroot(), sbuild::chroot::facet::block_device_base::set_chroot(), sbuild::chroot::facet::mountable::set_keyfile(), sbuild::chroot::facet::lvm_snapshot::set_keyfile(), sbuild::chroot::facet::custom::set_keyfile(), sbuild::chroot::facet::file::set_keyfile(), sbuild::chroot::facet::btrfs_snapshot::set_keyfile(), sbuild::chroot::facet::fsunion::set_keyfile(), and sbuild::chroot::facet::lvm_snapshot::set_snapshot_device().
const std::shared_ptr< const T > sbuild::chroot::chroot::get_facet | ( | ) | const |
Get a chroot facet.
This is a templated method; use the correct type for the facet required.
References facets.
std::shared_ptr< T > sbuild::chroot::chroot::get_facet_strict | ( | ) |
Get a chroot facet.
This is a templated method; use the correct type for the facet required.
References FACET_ABSENT.
const std::shared_ptr< const T > sbuild::chroot::chroot::get_facet_strict | ( | ) | const |
Get a chroot facet.
This is a templated method; use the correct type for the facet required.
References FACET_ABSENT.
chroot::facet_list & sbuild::chroot::chroot::get_facets | ( | ) |
const chroot::facet_list & sbuild::chroot::chroot::get_facets | ( | ) | const |
string_list const & sbuild::chroot::chroot::get_groups | ( | ) | const |
Get the groups allowed to access the chroot.
References groups.
Referenced by get_details(), and get_keyfile().
void sbuild::chroot::chroot::get_keyfile | ( | keyfile & | keyfile) | const |
Copy the chroot properties into a keyfile.
The keyfile group with the name of the chroot will be set; if it already exists, it will be removed before setting it.
keyfile | the keyfile to use. |
References facets, get_aliases(), get_chroot_type(), get_command_prefix(), get_default_shell(), get_description(), get_environment_filter(), get_groups(), get_mount_location(), get_name(), get_preserve_environment(), get_profile(), get_root_groups(), get_root_users(), get_script_config(), get_users(), get_verbosity_string(), sbuild::keyfile::remove_group(), sbuild::keyfile::set_object_list_value(), and sbuild::keyfile::set_object_value().
Referenced by sbuild::chroot::facet::userdata::set_data(), and sbuild::chroot::facet::session::setup_session_info().
std::string const & sbuild::chroot::chroot::get_mount_location | ( | ) | const |
Get the mount location of the chroot.
References mount_location.
Referenced by get_details(), get_keyfile(), sbuild::chroot::facet::block_device_base::get_path(), sbuild::chroot::facet::directory::get_path(), sbuild::chroot::facet::loopback::get_path(), sbuild::chroot::facet::custom::get_path(), sbuild::chroot::facet::btrfs_snapshot::get_path(), sbuild::chroot::facet::file::get_path(), and setup_env().
std::string const & sbuild::chroot::chroot::get_name | ( | ) | const |
Get the name of the chroot.
References name.
Referenced by sbuild::chroot::facet::lvm_snapshot::chroot_session_setup(), sbuild::chroot::facet::btrfs_snapshot::chroot_session_setup(), sbuild::chroot::facet::fsunion::chroot_session_setup(), sbuild::chroot::facet::session::get_details(), get_details(), sbuild::chroot::facet::personality::get_keyfile(), sbuild::chroot::facet::directory_base::get_keyfile(), sbuild::chroot::facet::userdata::get_keyfile(), sbuild::chroot::facet::block_device_base::get_keyfile(), sbuild::chroot::facet::loopback::get_keyfile(), sbuild::chroot::facet::session::get_keyfile(), sbuild::chroot::facet::mountable::get_keyfile(), sbuild::chroot::facet::lvm_snapshot::get_keyfile(), sbuild::chroot::facet::custom::get_keyfile(), sbuild::chroot::facet::unshare::get_keyfile(), sbuild::chroot::facet::file::get_keyfile(), sbuild::chroot::facet::btrfs_snapshot::get_keyfile(), sbuild::chroot::facet::source_clonable::get_keyfile(), sbuild::chroot::facet::fsunion::get_keyfile(), get_keyfile(), sbuild::chroot::facet::personality::set_keyfile(), sbuild::chroot::facet::directory_base::set_keyfile(), sbuild::chroot::facet::userdata::set_keyfile(), sbuild::chroot::facet::block_device_base::set_keyfile(), sbuild::chroot::facet::loopback::set_keyfile(), sbuild::chroot::facet::session::set_keyfile(), sbuild::chroot::facet::mountable::set_keyfile(), sbuild::chroot::facet::lvm_snapshot::set_keyfile(), sbuild::chroot::facet::custom::set_keyfile(), sbuild::chroot::facet::unshare::set_keyfile(), sbuild::chroot::facet::file::set_keyfile(), sbuild::chroot::facet::btrfs_snapshot::set_keyfile(), sbuild::chroot::facet::source_clonable::set_keyfile(), sbuild::chroot::facet::fsunion::set_keyfile(), set_keyfile(), setup_env(), and sbuild::chroot::facet::session::setup_session_info().
bool sbuild::chroot::chroot::get_original | ( | ) | const |
Get the originality of the chroot.
References original.
std::string sbuild::chroot::chroot::get_path | ( | ) | const |
Get the path to the chroot.
This is the absolute path to the root of the chroot, and is typically the same as the mount location and location concatenated together, but is overridden by the chroot type if required.
Referenced by get_details(), and setup_env().
bool sbuild::chroot::chroot::get_preserve_environment | ( | ) | const |
Check if the environment should be preserved in the chroot.
References preserve_environment.
Referenced by get_details(), and get_keyfile().
std::string const & sbuild::chroot::chroot::get_profile | ( | ) | const |
Get the configuration profile for the chroot.
This is a directory, either relative to the configured pkgsysconfdir or an absolute path.
References profile.
Referenced by chroot(), get_details(), get_keyfile(), and setup_env().
string_list const & sbuild::chroot::chroot::get_root_groups | ( | ) | const |
Get the groups allowed to access the chroot as root.
Members of these groups can switch to root without authenticating themselves.
References root_groups.
Referenced by get_details(), and get_keyfile().
string_list const & sbuild::chroot::chroot::get_root_users | ( | ) | const |
Get the users allowed to access the chroot as root.
Members of these users can switch to root without authenticating themselves.
References root_users.
Referenced by get_details(), and get_keyfile().
bool sbuild::chroot::chroot::get_run_setup_scripts | ( | ) | const |
Check if chroot setup scripts will be run.
Referenced by get_details().
std::string const & sbuild::chroot::chroot::get_script_config | ( | ) | const |
Get the script configuration file for the chroot.
This is a filename, either relative to the configured pkgsysconfdir or an absolute path.
References script_config.
Referenced by get_details(), get_keyfile(), and setup_env().
facet::facet::session_flags sbuild::chroot::chroot::get_session_flags | ( | ) | const |
Get the session flags of the chroot.
These determine how the Session controlling the chroot will operate.
References facets, and sbuild::chroot::facet::facet::SESSION_NOFLAGS.
Referenced by get_details(), and setup_env().
string_list sbuild::chroot::chroot::get_used_keys | ( | ) | const |
Get a list of the keys used during keyfile parsing.
References facets.
Referenced by sbuild::chroot::facet::userdata::set_data(), and sbuild::chroot::facet::userdata::set_keyfile().
string_list const & sbuild::chroot::chroot::get_users | ( | ) | const |
Get the users allowed to access the chroot.
References users.
Referenced by get_details(), and get_keyfile().
chroot::verbosity sbuild::chroot::chroot::get_verbosity | ( | ) | const |
const char * sbuild::chroot::chroot::get_verbosity_string | ( | ) | const |
Get the message verbosity as a readable string.
References sbuild::DEBUG_CRITICAL, sbuild::log_debug(), message_verbosity, VERBOSITY_NORMAL, VERBOSITY_QUIET, and VERBOSITY_VERBOSE.
Referenced by get_details(), and get_keyfile().
string_list sbuild::chroot::chroot::list_facets | ( | ) | const |
void sbuild::chroot::chroot::lock | ( | setup_type | type) |
Lock a chroot during setup.
The locking technique (if any) may vary depending upon the chroot type and setup stage. For example, during creation of an LVM snapshot a block device might require locking, but afterwards this will change to the new block device.
An error will be thrown on failure.
type | the type of setup being performed |
References setup_lock().
void sbuild::chroot::chroot::print_details | ( | std::ostream & | stream) | const |
Print detailed information about the chroot to a stream.
The information is printed in plain text with one line per property.
stream | the stream to output to. |
References sbuild::_(), and get_details().
void sbuild::chroot::chroot::remove_facet | ( | ) |
Remove a chroot facet.
This is a templated method; use the correct type for the facet to remove.
References facets.
Referenced by sbuild::chroot::facet::fsunion::chroot_session_setup(), sbuild::chroot::facet::fsunion::chroot_source_setup(), sbuild::chroot::facet::custom::set_session_cloneable(), and sbuild::chroot::facet::custom::set_source_cloneable().
void sbuild::chroot::chroot::remove_facet | ( | std::shared_ptr< T > | facet) |
Remove a chroot facet.
facet | the facet to remove. |
void sbuild::chroot::chroot::replace_facet | ( | std::shared_ptr< T > | facet) |
Replace an existing chroot facet with a new facet.
facet | the replacement facet. |
References add_facet().
Referenced by sbuild::chroot::facet::lvm_snapshot::chroot_source_setup(), and sbuild::chroot::facet::btrfs_snapshot::chroot_source_setup().
void sbuild::chroot::chroot::set_aliases | ( | const string_list & | aliases) |
Set the aliases of the chroot.
These are alternative names for the chroot.
aliases | a list of names. |
References sbuild::_(), aliases, sbuild::is_valid_sessionname(), NAME_INVALID, sbuild::chroot::config::namespace_separator, and sbuild::error_base::set_reason().
Referenced by set_keyfile().
void sbuild::chroot::chroot::set_command_prefix | ( | const string_list & | command_prefix) |
Set the command_prefix for the chroot.
This is a command to prefix to any command run in the chroot.
command_prefix | the command prefix. |
References command_prefix.
Referenced by set_keyfile().
void sbuild::chroot::chroot::set_default_shell | ( | const std::string & | default_shell) |
Set the default shell.
This is the default interactive shell.
default_shell | the default shell. |
References default_shell.
Referenced by set_keyfile().
void sbuild::chroot::chroot::set_description | ( | const std::string & | description) |
Set the description of the chroot.
description | the description. |
References description.
Referenced by set_keyfile().
void sbuild::chroot::chroot::set_environment_filter | ( | const regex & | environment_filter) |
Set the environment filter of the chroot.
This is a POSIX extended regular expression used to remove insecure environment variables from the chroot environment.
environment_filter | the filter. |
References environment_filter.
Referenced by set_keyfile().
void sbuild::chroot::chroot::set_groups | ( | const string_list & | groups) |
Set the users allowed to access the chroot.
groups | a list of groups. |
References groups.
Referenced by set_keyfile().
void sbuild::chroot::chroot::set_keyfile | ( | const keyfile & | keyfile) |
Set the chroot properties from a keyfile.
The chroot name must have previously been set, so that the correct keyfile group may be determined.
keyfile | the keyfile to get the properties from. |
References facets, get_name(), sbuild::keyfile::get_object_list_value(), sbuild::keyfile::get_object_value(), sbuild::keyfile::PRIORITY_DEPRECATED, sbuild::keyfile::PRIORITY_DISALLOWED, sbuild::keyfile::PRIORITY_OPTIONAL, sbuild::keyfile::PRIORITY_REQUIRED, set_aliases(), set_command_prefix(), set_default_shell(), set_description(), set_environment_filter(), set_groups(), set_mount_location(), set_name(), set_preserve_environment(), set_profile(), set_root_groups(), set_root_users(), set_script_config(), set_users(), and set_verbosity().
Referenced by sbuild::chroot::facet::userdata::set_data().
void sbuild::chroot::chroot::set_mount_location | ( | const std::string & | location) |
Set the mount location of the chroot.
location | the mount location. |
References sbuild::is_absname(), LOCATION_ABS, and mount_location.
Referenced by set_keyfile().
void sbuild::chroot::chroot::set_name | ( | const std::string & | name) |
Set the name of the chroot.
name | the name. |
References sbuild::_(), sbuild::is_valid_sessionname(), name, NAME_INVALID, sbuild::chroot::config::namespace_separator, and sbuild::error_base::set_reason().
Referenced by set_keyfile().
void sbuild::chroot::chroot::set_original | ( | bool | original) |
Set the originality of the chroot.
original | true if original, false if generated. |
References original.
void sbuild::chroot::chroot::set_preserve_environment | ( | bool | preserve_environment) |
Set if the environment should be preserved in the chroot.
preserve_environment | true to preserve or false to clean. |
References preserve_environment.
Referenced by set_keyfile().
void sbuild::chroot::chroot::set_profile | ( | const std::string & | profile) |
Set configuration profile for the chroot.
This is a directory, either relative to the configured pkgsysconfdir or an absolute path.
profile | the script configuration file. |
References profile.
Referenced by chroot(), and set_keyfile().
void sbuild::chroot::chroot::set_root_groups | ( | const string_list & | groups) |
Set the groups allowed to access the chroot as root.
Members of these groups can switch to root without authenticating themselves.
groups | a list of groups. |
References groups, and root_groups.
Referenced by set_keyfile().
void sbuild::chroot::chroot::set_root_users | ( | const string_list & | users) |
Set the users allowed to access the chroot as root.
Members of these users can switch to root without authenticating themselves.
users | a list of users. |
References root_users, and users.
Referenced by set_keyfile().
void sbuild::chroot::chroot::set_script_config | ( | const std::string & | script_config) |
Set the script configuration file for the chroot.
This is a filename, either relative to the configured pkgsysconfdir or an absolute path.
script_config | the script configuration file. |
References profile, and script_config.
Referenced by set_keyfile().
void sbuild::chroot::chroot::set_users | ( | const string_list & | users) |
Set the users allowed to access the chroot.
users | a list of users. |
References users.
Referenced by set_keyfile().
void sbuild::chroot::chroot::set_verbosity | ( | chroot::verbosity | verbosity) |
Set the message verbosity.
verbosity | the verbosity level. |
References message_verbosity.
Referenced by set_keyfile().
void sbuild::chroot::chroot::set_verbosity | ( | const std::string & | verbosity) |
Set the message verbosity.
verbosity | the verbosity level. |
References message_verbosity, VERBOSITY_INVALID, VERBOSITY_NORMAL, VERBOSITY_QUIET, and VERBOSITY_VERBOSE.
void sbuild::chroot::chroot::setup_env | ( | environment & | env) | const |
Set environment.
Set the environment that the setup scripts will see during execution.
env | the environment to set. |
References sbuild::environment::add(), facets, get_chroot_type(), get_description(), get_mount_location(), get_name(), get_path(), get_profile(), get_script_config(), get_session_flags(), sbuild::normalname(), sbuild::chroot::facet::facet::SESSION_CLONE, sbuild::chroot::facet::facet::SESSION_CREATE, and sbuild::chroot::facet::facet::SESSION_PURGE.
|
protected |
Unlock a chroot during setup.
The locking technique (if any) may vary depending upon the chroot type and setup stage. For example, during creation of an LVM snapshot a block device might require locking, but afterwards this will change to the new block device.
An error will be thrown on failure.
type | the type of setup being performed |
lock | true to lock, false to unlock |
status | the exit status of the setup commands (0 for success, nonzero for failure). |
Referenced by lock(), and unlock().
void sbuild::chroot::chroot::unlock | ( | setup_type | type, |
int | status | ||
) |
Unlock a chroot during setup.
The locking technique (if any) may vary depending upon the chroot type and setup stage. For example, during creation of an LVM snapshot a block device might require locking, but afterwards this will change to the new block device.
An error will be thrown on failure.
type | the type of setup being performed |
status | the exit status of the setup commands (0 for success, nonzero for failure). |
References setup_lock().
|
friend |
Print detailed information about the chroot to a stream.
The information is printed in plain text with one line per property.
stream | the stream to output to. |
rhs | the chroot to output. |
Chroot serialisation to a keyfile.
keyfile | the keyfile to use. |
rhs | the chroot to output. |
Chroot initialisation from a keyfile.
keyfile | the keyfile to get the properties from. |
rhs | the chroot to output. |