sbuild  1.7.1
Public Types | Public Member Functions | Static Public Member Functions | Protected Member Functions | Private Attributes | Friends | List of all members
sbuild::chroot::facet::lvm_snapshot Class Reference

A chroot stored on an LVM logical volume (LV). More...

#include <lvm-snapshot.h>

+ Inheritance diagram for sbuild::chroot::facet::lvm_snapshot:
+ Collaboration diagram for sbuild::chroot::facet::lvm_snapshot:

Public Types

typedef std::shared_ptr
< lvm_snapshot
ptr
 A shared_ptr to a chroot facet object.
 
typedef std::shared_ptr< const
lvm_snapshot
const_ptr
 A shared_ptr to a const chroot facet object.
 
- Public Types inherited from sbuild::chroot::facet::block_device_base
typedef chroot::error error
 Exception type.
 
- Public Types inherited from sbuild::chroot::facet::facet
enum  session_flags { SESSION_NOFLAGS = 0, SESSION_CREATE = 1 << 0, SESSION_CLONE = 1 << 1, SESSION_PURGE = 1 << 2 }
 Chroot session properties. More...
 
typedef std::shared_ptr< facetptr
 A shared_ptr to a chroot facet object.
 
typedef std::shared_ptr< const
facet
const_ptr
 A shared_ptr to a const chroot facet object.
 
- Public Types inherited from sbuild::chroot::facet::storage
typedef std::shared_ptr< storageptr
 A shared_ptr to a chroot storage object.
 
typedef std::shared_ptr< const
storage
const_ptr
 A shared_ptr to a const chroot storage object.
 
- Public Types inherited from sbuild::chroot::facet::session_setup
typedef std::shared_ptr
< session_setup
ptr
 A shared_ptr to a chroot session_setup object.
 
typedef std::shared_ptr< const
session_setup
const_ptr
 A shared_ptr to a const chroot session_setup object.
 
- Public Types inherited from sbuild::chroot::facet::source_setup
typedef std::shared_ptr
< source_setup
ptr
 A shared_ptr to a chroot source_setup object.
 
typedef std::shared_ptr< const
source_setup
const_ptr
 A shared_ptr to a const chroot source_setup object.
 

Public Member Functions

virtual ~lvm_snapshot ()
 The destructor.
 
virtual std::string const & get_name () const
 Get the name of the chroot facet. More...
 
facet::ptr clone () const
 Copy the chroot facet. More...
 
std::string const & get_snapshot_device () const
 Get the logical volume snapshot device name. More...
 
void set_snapshot_device (const std::string &snapshot_device)
 Set the logical volume snapshot device name. More...
 
std::string const & get_snapshot_options () const
 Get the logical volume snapshot options. More...
 
void set_snapshot_options (const std::string &snapshot_options)
 Set the logical volume snapshot options. More...
 
virtual void setup_env (environment &env) const
 Set environment. More...
 
virtual session_flags get_session_flags () const
 Get the session flags of the chroot. More...
 
- Public Member Functions inherited from sbuild::chroot::facet::block_device_base
virtual ~block_device_base ()
 The destructor.
 
std::string const & get_device () const
 Get the block device of the chroot. More...
 
void set_device (const std::string &device)
 Set the block device of the chroot. More...
 
virtual std::string get_path () const
 Get the path to the chroot. More...
 
- Public Member Functions inherited from sbuild::chroot::facet::facet
virtual ~facet ()
 The destructor.
 
- Public Member Functions inherited from sbuild::chroot::facet::storage
virtual ~storage ()
 The destructor.
 
- Public Member Functions inherited from sbuild::chroot::facet::session_setup
virtual ~session_setup ()
 The destructor.
 
- Public Member Functions inherited from sbuild::chroot::facet::source_setup
virtual ~source_setup ()
 The destructor.
 

Static Public Member Functions

static ptr create ()
 Create a chroot facet. More...
 

Protected Member Functions

 lvm_snapshot ()
 The constructor.
 
 lvm_snapshot (const lvm_snapshot &rhs)
 The copy constructor.
 
void set_chroot (chroot &chroot, bool copy)
 Set containing chroot. More...
 
virtual void setup_lock (chroot::setup_type type, bool lock, int status)
 
virtual void get_details (format_detail &detail) const
 Get detailed information about the chroot for output. More...
 
virtual void get_used_keys (string_list &used_keys) const
 Get a list of the keys used during keyfile parsing. More...
 
virtual void get_keyfile (keyfile &keyfile) const
 Copy the chroot properties into a keyfile. More...
 
virtual void set_keyfile (const keyfile &keyfile)
 Set the chroot properties from a keyfile. More...
 
virtual void chroot_session_setup (const chroot &parent, const std::string &session_id, const std::string &alias, const std::string &user, bool root)
 Set up a newly-cloned session chroot. More...
 
virtual void chroot_source_setup (const chroot &parent)
 Set up a newly-cloned source chroot. More...
 
- Protected Member Functions inherited from sbuild::chroot::facet::block_device_base
 block_device_base ()
 The constructor.
 
 block_device_base (const block_device_base &rhs)
 The copy constructor.
 
- Protected Member Functions inherited from sbuild::chroot::facet::facet
 facet ()
 The constructor.
 
- Protected Member Functions inherited from sbuild::chroot::facet::storage
 storage ()
 The constructor.
 
- Protected Member Functions inherited from sbuild::chroot::facet::session_setup
 session_setup ()
 The constructor.
 
- Protected Member Functions inherited from sbuild::chroot::facet::source_setup
 source_setup ()
 The constructor.
 

Private Attributes

std::string snapshot_device
 LVM snapshot device name for lvcreate.
 
std::string snapshot_options
 LVM snapshot options for lvcreate.
 

Friends

class chroot
 

Additional Inherited Members

- Protected Attributes inherited from sbuild::chroot::facet::block_device_base
std::string device
 The block device to use.
 

Detailed Description

A chroot stored on an LVM logical volume (LV).

A snapshot LV will be created and mounted on demand.

Member Function Documentation

void sbuild::chroot::facet::lvm_snapshot::chroot_session_setup ( const chroot parent,
const std::string &  session_id,
const std::string &  alias,
const std::string &  user,
bool  root 
)
protectedvirtual

Set up a newly-cloned session chroot.

Parameters
parentthe parent of the cloned chroot.
session_idthe identifier (session_id) for the new session.
aliasused to initially identify the chroot.
userthe user creating the session.
roottrue if the user has root access, otherwise false.

Implements sbuild::chroot::facet::session_setup.

References sbuild::chroot::facet::block_device_base::device, sbuild::dirname(), sbuild::chroot::facet::block_device_base::get_device(), sbuild::chroot::chroot::get_name(), sbuild::chroot::facet::facet::owner, and set_snapshot_device().

void sbuild::chroot::facet::lvm_snapshot::chroot_source_setup ( const chroot parent)
protectedvirtual

Set up a newly-cloned source chroot.

Parameters
parentthe parent of the cloned chroot.

Implements sbuild::chroot::facet::source_setup.

References sbuild::chroot::facet::block_device::create(), sbuild::chroot::facet::facet::owner, and sbuild::chroot::chroot::replace_facet().

facet::ptr sbuild::chroot::facet::lvm_snapshot::clone ( ) const
virtual

Copy the chroot facet.

This is a virtual copy constructor.

Returns
a shared_ptr to the new copy of the chroot facet.

Implements sbuild::chroot::facet::facet.

References lvm_snapshot().

lvm_snapshot::ptr sbuild::chroot::facet::lvm_snapshot::create ( )
static

Create a chroot facet.

Returns
a shared_ptr to the new chroot facet.

References lvm_snapshot().

void sbuild::chroot::facet::lvm_snapshot::get_details ( format_detail detail) const
protectedvirtual

Get detailed information about the chroot for output.

Parameters
detailthe details to output to.

Reimplemented from sbuild::chroot::facet::block_device_base.

References sbuild::_(), sbuild::format_detail::add(), sbuild::chroot::facet::block_device_base::get_details(), get_snapshot_device(), get_snapshot_options(), snapshot_device, and snapshot_options.

void sbuild::chroot::facet::lvm_snapshot::get_keyfile ( keyfile keyfile) const
protectedvirtual

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.

Parameters
keyfilethe keyfile to use.

Reimplemented from sbuild::chroot::facet::block_device_base.

References sbuild::chroot::chroot::get_facet(), sbuild::chroot::facet::block_device_base::get_keyfile(), sbuild::chroot::chroot::get_name(), get_snapshot_device(), get_snapshot_options(), sbuild::chroot::facet::facet::owner, and sbuild::keyfile::set_object_value().

std::string const & sbuild::chroot::facet::lvm_snapshot::get_name ( ) const
virtual

Get the name of the chroot facet.

Returns
the chroot facet name.

Implements sbuild::chroot::facet::facet.

facet::session_flags sbuild::chroot::facet::lvm_snapshot::get_session_flags ( ) const
virtual

Get the session flags of the chroot.

These determine how the Session controlling the chroot will operate.

Parameters
chrootthe chroot to use.
Returns
the session flags.

Reimplemented from sbuild::chroot::facet::facet.

References sbuild::chroot::chroot::get_facet(), sbuild::chroot::facet::facet::owner, sbuild::chroot::facet::facet::SESSION_NOFLAGS, and sbuild::chroot::facet::facet::SESSION_PURGE.

std::string const & sbuild::chroot::facet::lvm_snapshot::get_snapshot_device ( ) const

Get the logical volume snapshot device name.

This is used by lvcreate.

Returns
the device name.

References snapshot_device.

Referenced by get_details(), get_keyfile(), and setup_env().

+ Here is the caller graph for this function:

std::string const & sbuild::chroot::facet::lvm_snapshot::get_snapshot_options ( ) const

Get the logical volume snapshot options.

These are used by lvcreate.

Returns
the options.

References snapshot_options.

Referenced by get_details(), get_keyfile(), and setup_env().

+ Here is the caller graph for this function:

void sbuild::chroot::facet::lvm_snapshot::get_used_keys ( string_list used_keys) const
protectedvirtual

Get a list of the keys used during keyfile parsing.

Returns
a list of key names.

Reimplemented from sbuild::chroot::facet::block_device_base.

References sbuild::chroot::facet::block_device_base::get_used_keys().

void sbuild::chroot::facet::lvm_snapshot::set_chroot ( chroot chroot,
bool  copy 
)
protectedvirtual

Set containing chroot.

The copy parameter is used to inform the facet if it is new or a copy; this is intended to allow additional facets to only be added if the facet is new, for example, to avoid re-adding removed facets when copying a chroot.

Parameters
chrootthe chroot containing this facet.
copytrue if the facet has been copied, or false if this is a new instance.

Reimplemented from sbuild::chroot::facet::block_device_base.

References sbuild::chroot::chroot::add_facet(), sbuild::chroot::facet::session_clonable::create(), sbuild::chroot::facet::source_clonable::create(), sbuild::chroot::chroot::get_facet(), sbuild::chroot::facet::facet::owner, and sbuild::chroot::facet::block_device_base::set_chroot().

void sbuild::chroot::facet::lvm_snapshot::set_keyfile ( const keyfile keyfile)
protectedvirtual

Set the chroot properties from a keyfile.

The chroot name must have previously been set, so that the correct keyfile group may be determined.

Parameters
keyfilethe keyfile to get the properties from.

Reimplemented from sbuild::chroot::facet::block_device_base.

References sbuild::chroot::chroot::get_facet(), sbuild::chroot::chroot::get_name(), sbuild::keyfile::get_object_value(), sbuild::chroot::facet::facet::owner, sbuild::keyfile::PRIORITY_DEPRECATED, sbuild::keyfile::PRIORITY_DISALLOWED, sbuild::keyfile::PRIORITY_REQUIRED, sbuild::chroot::facet::block_device_base::set_keyfile(), set_snapshot_device(), and set_snapshot_options().

void sbuild::chroot::facet::lvm_snapshot::set_snapshot_device ( const std::string &  snapshot_device)

Set the logical volume snapshot device name.

This is used by lvcreate.

Parameters
snapshot_devicethe device name.

References sbuild::chroot::chroot::DEVICE_ABS, sbuild::chroot::chroot::get_facet(), sbuild::is_absname(), sbuild::chroot::facet::facet::owner, and snapshot_device.

Referenced by chroot_session_setup(), and set_keyfile().

+ Here is the caller graph for this function:

void sbuild::chroot::facet::lvm_snapshot::set_snapshot_options ( const std::string &  snapshot_options)

Set the logical volume snapshot options.

These are used by lvcreate.

Parameters
snapshot_optionsthe options.

References snapshot_options.

Referenced by set_keyfile().

+ Here is the caller graph for this function:

void sbuild::chroot::facet::lvm_snapshot::setup_env ( environment env) const
virtual

Set environment.

Set the environment that the setup scripts will see during execution.

Parameters
envthe environment to set.

Reimplemented from sbuild::chroot::facet::block_device_base.

References sbuild::environment::add(), sbuild::basename(), get_snapshot_device(), get_snapshot_options(), and sbuild::chroot::facet::block_device_base::setup_env().


The documentation for this class was generated from the following files: