#include <sbuild-chroot.h>
Inheritance diagram for sbuild::chroot:
Public Types | |
typedef custom_error< error_code > | error |
Exception type. | |
typedef std::tr1::shared_ptr< chroot > | ptr |
A shared_ptr to a chroot object. | |
SETUP_START | |
Activate a chroot. | |
SETUP_RECOVER | |
Reactivate a chroot. | |
SETUP_STOP | |
Deactivate a chroot. | |
EXEC_START | |
Start executing a command in an active chroot. | |
EXEC_STOP | |
End executing a command in an active chroot. | |
SESSION_CREATE = 1 << 0 | |
The chroot supports session creation. | |
CHROOT_CREATE | |
Chroot creation failed. | |
CHROOT_DEVICE | |
Chroot device name not set. | |
CHROOT_TYPE | |
Unknown chroot type. | |
DEVICE_ABS | |
Device must have an absolute path. | |
DEVICE_LOCK | |
Failed to lock device. | |
DEVICE_NOTBLOCK | |
File is not a block device. | |
DEVICE_STAT | |
Failed to stat device. | |
DEVICE_UNLOCK | |
Failed to unlock device. | |
FILE_ABS | |
File must have an absolute path. | |
FILE_LOCK | |
Failed to acquire lock. | |
FILE_NOTREG | |
File is not a regular file. | |
FILE_OWNER | |
File is not owned by user root. | |
FILE_PERMS | |
File has write permissions for others. | |
FILE_STAT | |
Failed to stat file. | |
FILE_UNLOCK | |
Failed to discard lock. | |
LOCATION_ABS | |
Location must have an absolute path. | |
SESSION_UNLINK | |
Failed to unlink session file. | |
SESSION_WRITE | |
Failed to write session file. | |
enum | setup_type { SETUP_START, SETUP_RECOVER, SETUP_STOP, EXEC_START, EXEC_STOP } |
Type of setup to perform. More... | |
enum | session_flags { SESSION_CREATE = 1 << 0 } |
Chroot session properties. More... | |
enum | error_code { CHROOT_CREATE, CHROOT_DEVICE, CHROOT_TYPE, DEVICE_ABS, DEVICE_LOCK, DEVICE_NOTBLOCK, DEVICE_STAT, DEVICE_UNLOCK, FILE_ABS, FILE_LOCK, FILE_NOTREG, FILE_OWNER, FILE_PERMS, FILE_STAT, FILE_UNLOCK, LOCATION_ABS, SESSION_UNLINK, SESSION_WRITE } |
Error codes. More... | |
Public Member Functions | |
virtual | ~chroot () |
The destructor. | |
virtual ptr | clone () const =0 |
Copy the chroot. | |
std::string const & | get_name () const |
Get the name of the chroot. | |
void | set_name (std::string const &name) |
Set the name of the chroot. | |
std::string const & | get_description () const |
Get the description of the chroot. | |
void | set_description (std::string const &description) |
Set the description of the chroot. | |
virtual std::string const & | get_mount_location () const |
Get the mount location of the chroot. | |
void | set_mount_location (std::string const &location) |
Set the mount location of the chroot. | |
virtual std::string const & | get_location () const |
Get the location of the chroot. | |
virtual std::string | get_path () const |
Get the path to the chroot. | |
virtual std::string const & | get_mount_device () const |
Get the mount device of the chroot. | |
void | set_mount_device (std::string const &device) |
Set the mount device of the chroot. | |
unsigned int | get_priority () const |
Get the priority of the chroot. | |
void | set_priority (unsigned int priority) |
Set the priority of a chroot. | |
string_list const & | get_users () const |
Get the users allowed to access the chroot. | |
void | set_users (string_list const &users) |
Set the users allowed to access the chroot. | |
string_list const & | get_groups () const |
Get the groups allowed to access the chroot. | |
void | set_groups (string_list const &groups) |
Set the users allowed to access the chroot. | |
string_list const & | get_root_users () const |
Get the users allowed to access the chroot as root. | |
void | set_root_users (string_list const &users) |
Set the users allowed to access the chroot as root. | |
string_list const & | get_root_groups () const |
Get the groups allowed to access the chroot as root. | |
void | set_root_groups (string_list const &groups) |
Set the groups allowed to access the chroot as root. | |
string_list const & | get_aliases () const |
Get the aliases of the chroot. | |
void | set_aliases (string_list const &aliases) |
Set the aliases of the chroot. | |
bool | get_active () const |
Get the activity status of the chroot. | |
void | set_active (bool active) |
Set the activity status of the chroot. | |
bool | get_original () const |
Get the originality of the chroot. | |
void | set_original (bool original) |
Set the originality of the chroot. | |
bool | get_run_setup_scripts () const |
Check if chroot setup scripts will be run. | |
void | set_run_setup_scripts (bool run_setup_scripts) |
Set whether chroot setup scripts will be run. | |
bool | get_run_exec_scripts () const |
Check if chroot exec scripts will be run. | |
void | set_run_exec_scripts (bool run_exec_scripts) |
Set whether chroot exec scripts will be run. | |
string_list const & | get_command_prefix () const |
Get the command_prefix for the chroot. | |
void | set_command_prefix (string_list const &command_prefix) |
Set the command_prefix for the chroot. | |
personality const & | get_persona () const |
Get the process execution domain for the chroot. | |
void | set_persona (personality const &persona) |
Set the process execution domain for the chroot. | |
virtual std::string const & | get_chroot_type () const =0 |
Get the type of the chroot. | |
virtual void | setup_env (environment &env) |
Set environment. | |
void | lock (setup_type type) |
Lock a chroot during setup. | |
void | unlock (setup_type type, int status) |
Unlock a chroot during setup. | |
virtual session_flags | get_session_flags () const =0 |
Get the session flags of the chroot. | |
Static Public Member Functions | |
static ptr | create (std::string const &type) |
Create a chroot. | |
Protected Member Functions | |
chroot () | |
The constructor. | |
virtual void | set_location (std::string const &location) |
Set the location of the chroot. | |
virtual void | setup_session_info (bool start) |
Set up persistent session information. | |
virtual void | setup_lock (setup_type type, bool lock, int status)=0 |
Unlock a chroot during setup. | |
virtual void | get_details (format_detail &detail) const |
Get detailed information about the chroot for output. | |
void | print_details (std::ostream &stream) const |
Print detailed information about the chroot to a stream. | |
virtual void | get_keyfile (keyfile &keyfile) const |
Copy the chroot properties into a keyfile. | |
virtual void | set_keyfile (keyfile const &keyfile) |
Set the chroot properties from a keyfile. | |
Private Attributes | |
std::string | name |
Chroot name. | |
std::string | description |
Chroot description. | |
unsigned int | priority |
Chroot prioroty. | |
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. | |
std::string | mount_location |
Location to mount chroot in the filesystem (if any). | |
std::string | location |
Location inside the mount location root. | |
std::string | mount_device |
Block device to mount (if any). | |
bool | active |
Chroot activity status. | |
bool | original |
Was the chroot automatically generated? | |
bool | run_setup_scripts |
Run chroot setup scripts? | |
bool | run_exec_scripts |
Run chroot exec scripts? | |
string_list | command_prefix |
Command prefix. | |
personality | persona |
Process execution domain (Linux only). | |
Friends | |
std::ostream & | operator<< (std::ostream &stream, ptr const &rhs) |
Print detailed information about the chroot to a stream. | |
keyfile const & | operator>> (keyfile const &keyfile, ptr &rhs) |
Chroot initialisation from a keyfile. | |
keyfile & | operator<< (keyfile &keyfile, ptr const &rhs) |
Chroot serialisation to a keyfile. |
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.
typedef custom_error<error_code> sbuild::chroot::error |
Exception type.
typedef std::tr1::shared_ptr<chroot> sbuild::chroot::ptr |
A shared_ptr to a chroot object.
Error codes.
sbuild::chroot::chroot | ( | ) | [protected] |
The constructor.
sbuild::chroot::~chroot | ( | ) | [virtual] |
The destructor.
virtual ptr sbuild::chroot::clone | ( | ) | const [pure virtual] |
Copy the chroot.
This is a virtual copy constructor.
Implemented in sbuild::chroot_block_device, sbuild::chroot_directory, sbuild::chroot_file, sbuild::chroot_lvm_snapshot, and sbuild::chroot_plain.
sbuild::chroot::ptr sbuild::chroot::create | ( | std::string const & | type | ) | [static] |
Create a chroot.
This is a factory function.
type | the type of chroot to create. |
bool sbuild::chroot::get_active | ( | ) | const |
Get the activity status of the chroot.
string_list const & sbuild::chroot::get_aliases | ( | ) | const |
Get the aliases of the chroot.
These are alternative names for the chroot.
virtual std::string const& sbuild::chroot::get_chroot_type | ( | ) | const [pure virtual] |
Get the type of the chroot.
Implemented in sbuild::chroot_block_device, sbuild::chroot_directory, sbuild::chroot_file, sbuild::chroot_lvm_snapshot, and sbuild::chroot_plain.
string_list const & sbuild::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.
std::string const & sbuild::chroot::get_description | ( | ) | const |
Get the description of the chroot.
void sbuild::chroot::get_details | ( | format_detail & | detail | ) | const [protected, virtual] |
Get detailed information about the chroot for output.
detail | the details to output to. |
Reimplemented in sbuild::chroot_block_device, sbuild::chroot_directory, sbuild::chroot_file, sbuild::chroot_lvm_snapshot, and sbuild::chroot_source.
string_list const & sbuild::chroot::get_groups | ( | ) | const |
Get the groups allowed to access the chroot.
void sbuild::chroot::get_keyfile | ( | keyfile & | keyfile | ) | const [protected, virtual] |
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. |
Reimplemented in sbuild::chroot_block_device, sbuild::chroot_directory, sbuild::chroot_file, sbuild::chroot_lvm_snapshot, and sbuild::chroot_source.
std::string const & sbuild::chroot::get_location | ( | ) | const [virtual] |
Get the location of the chroot.
This is the path to the root of the chroot, and is typically the same as the mount location, but is overridden by the chroot type if required.
Reimplemented in sbuild::chroot_block_device, and sbuild::chroot_directory.
std::string const & sbuild::chroot::get_mount_device | ( | ) | const [virtual] |
Get the mount device of the chroot.
Reimplemented in sbuild::chroot_block_device, and sbuild::chroot_lvm_snapshot.
std::string const & sbuild::chroot::get_mount_location | ( | ) | const [virtual] |
Get the mount location of the chroot.
std::string const & sbuild::chroot::get_name | ( | ) | const |
Get the name of the chroot.
bool sbuild::chroot::get_original | ( | ) | const |
Get the originality of the chroot.
std::string sbuild::chroot::get_path | ( | ) | const [virtual] |
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.
Reimplemented in sbuild::chroot_directory.
personality const & sbuild::chroot::get_persona | ( | ) | const |
Get the process execution domain for the chroot.
unsigned int sbuild::chroot::get_priority | ( | ) | const |
Get the priority of the chroot.
This is a number indicating whether than a ditribution is older than another.
string_list const & sbuild::chroot::get_root_groups | ( | ) | const |
Get the groups allowed to access the chroot as root.
Mmebers of these groups can switch to root without authenticating themselves.
string_list const & sbuild::chroot::get_root_users | ( | ) | const |
Get the users allowed to access the chroot as root.
Mmebers of these users can switch to root without authenticating themselves.
bool sbuild::chroot::get_run_exec_scripts | ( | ) | const |
Check if chroot exec scripts will be run.
bool sbuild::chroot::get_run_setup_scripts | ( | ) | const |
Check if chroot setup scripts will be run.
virtual session_flags sbuild::chroot::get_session_flags | ( | ) | const [pure virtual] |
Get the session flags of the chroot.
These determine how the Session controlling the chroot will operate.
Implemented in sbuild::chroot_block_device, sbuild::chroot_directory, sbuild::chroot_file, and sbuild::chroot_lvm_snapshot.
string_list const & sbuild::chroot::get_users | ( | ) | const |
Get the users allowed to access the chroot.
void sbuild::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 |
void sbuild::chroot::print_details | ( | std::ostream & | stream | ) | const [protected] |
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. |
void sbuild::chroot::set_active | ( | bool | active | ) |
Set the activity status of the chroot.
active | true if active, false if inactive |
void sbuild::chroot::set_aliases | ( | string_list const & | aliases | ) |
Set the aliases of the chroot.
These are alternative names for the chroot.
aliases | a list of names. |
void sbuild::chroot::set_command_prefix | ( | string_list const & | 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. |
void sbuild::chroot::set_description | ( | std::string const & | description | ) |
Set the description of the chroot.
description | the description. |
void sbuild::chroot::set_groups | ( | string_list const & | groups | ) |
Set the users allowed to access the chroot.
groups | a list of groups. |
void sbuild::chroot::set_keyfile | ( | keyfile const & | keyfile | ) | [protected, virtual] |
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. |
Reimplemented in sbuild::chroot_block_device, sbuild::chroot_directory, sbuild::chroot_file, sbuild::chroot_lvm_snapshot, and sbuild::chroot_source.
void sbuild::chroot::set_location | ( | std::string const & | location | ) | [protected, virtual] |
Set the location of the chroot.
This is the path to the root of the chroot, and is typically the same as the mount location, but is overridden by the chroot type if required.
location | the mount location. |
Reimplemented in sbuild::chroot_block_device, and sbuild::chroot_directory.
void sbuild::chroot::set_mount_device | ( | std::string const & | device | ) |
Set the mount device of the chroot.
device | the device. |
void sbuild::chroot::set_mount_location | ( | std::string const & | location | ) |
Set the mount location of the chroot.
location | the mount location. |
void sbuild::chroot::set_name | ( | std::string const & | name | ) |
Set the name of the chroot.
name | the name. |
void sbuild::chroot::set_original | ( | bool | original | ) |
Set the originality of the chroot.
original | true if original, false if geneated. |
void sbuild::chroot::set_persona | ( | personality const & | persona | ) |
Set the process execution domain for the chroot.
persona | the personality. |
void sbuild::chroot::set_priority | ( | unsigned int | priority | ) |
Set the priority of a chroot.
This is a number indicating whether a distribution is older than another. For example, "oldstable" and "oldstable-security" might be 0, while "stable" and "stable-security" 1, "testing" 2 and "unstable" 3. The values are not important, but the difference between them is.
priority | the priority. |
void sbuild::chroot::set_root_groups | ( | string_list const & | groups | ) |
Set the groups allowed to access the chroot as root.
Mmebers of these groups can switch to root without authenticating themselves.
groups | a list of groups. |
void sbuild::chroot::set_root_users | ( | string_list const & | users | ) |
Set the users allowed to access the chroot as root.
Mmebers of these users can switch to root without authenticating themselves.
users | a list of users. |
void sbuild::chroot::set_run_exec_scripts | ( | bool | run_exec_scripts | ) |
Set whether chroot exec scripts will be run.
run_exec_scripts | true if exec scripts will be run, otherwise false. |
void sbuild::chroot::set_run_setup_scripts | ( | bool | run_setup_scripts | ) |
Set whether chroot setup scripts will be run.
run_setup_scripts | true if setup scripts will be run, otherwise false. |
void sbuild::chroot::set_users | ( | string_list const & | users | ) |
Set the users allowed to access the chroot.
users | a list of users. |
void sbuild::chroot::setup_env | ( | environment & | env | ) | [virtual] |
Set environment.
Set the environment that the setup scripts will see during execution.
env | the environment to set. |
Reimplemented in sbuild::chroot_block_device, sbuild::chroot_file, sbuild::chroot_lvm_snapshot, and sbuild::chroot_source.
virtual void sbuild::chroot::setup_lock | ( | setup_type | type, | |
bool | lock, | |||
int | status | |||
) | [protected, pure virtual] |
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). |
Implemented in sbuild::chroot_block_device, sbuild::chroot_directory, sbuild::chroot_file, and sbuild::chroot_lvm_snapshot.
void sbuild::chroot::setup_session_info | ( | bool | start | ) | [protected, virtual] |
Set up persistent session information.
start | true if startion, or false if ending a session. |
void sbuild::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). |
Chroot serialisation to a keyfile.
std::ostream& operator<< | ( | std::ostream & | stream, | |
ptr const & | rhs | |||
) | [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 initialisation from a keyfile.
bool sbuild::chroot::active [private] |
Chroot activity status.
string_list sbuild::chroot::aliases [private] |
Alternative names for the chroot.
string_list sbuild::chroot::command_prefix [private] |
Command prefix.
std::string sbuild::chroot::description [private] |
Chroot description.
string_list sbuild::chroot::groups [private] |
Groups allowed to access the chroot.
std::string sbuild::chroot::location [private] |
Location inside the mount location root.
std::string sbuild::chroot::mount_device [private] |
Block device to mount (if any).
std::string sbuild::chroot::mount_location [private] |
Location to mount chroot in the filesystem (if any).
std::string sbuild::chroot::name [private] |
Chroot name.
bool sbuild::chroot::original [private] |
Was the chroot automatically generated?
personality sbuild::chroot::persona [private] |
Process execution domain (Linux only).
unsigned int sbuild::chroot::priority [private] |
Chroot prioroty.
string_list sbuild::chroot::root_groups [private] |
Groups allowed to access the chroot as root.
string_list sbuild::chroot::root_users [private] |
Users allowed to access the chroot as root.
bool sbuild::chroot::run_exec_scripts [private] |
Run chroot exec scripts?
bool sbuild::chroot::run_setup_scripts [private] |
Run chroot setup scripts?
string_list sbuild::chroot::users [private] |
Users allowed to access the chroot.