summaryrefslogtreecommitdiff
path: root/sbuild/chroot-btrfs-snapshot.cc
diff options
context:
space:
mode:
Diffstat (limited to 'sbuild/chroot-btrfs-snapshot.cc')
-rw-r--r--sbuild/chroot-btrfs-snapshot.cc268
1 files changed, 268 insertions, 0 deletions
diff --git a/sbuild/chroot-btrfs-snapshot.cc b/sbuild/chroot-btrfs-snapshot.cc
new file mode 100644
index 00000000..dbc42aeb
--- /dev/null
+++ b/sbuild/chroot-btrfs-snapshot.cc
@@ -0,0 +1,268 @@
+/* Copyright © 2005-2013 Roger Leigh <rleigh@debian.org>
+ *
+ * schroot is free software: you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License as published by
+ * the Free Software Foundation, either version 3 of the License, or
+ * (at your option) any later version.
+ *
+ * schroot is distributed in the hope that it will be useful, but
+ * WITHOUT ANY WARRANTY; without even the implied warranty of
+ * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
+ * General Public License for more details.
+ *
+ * You should have received a copy of the GNU General Public License
+ * along with this program. If not, see
+ * <http://www.gnu.org/licenses/>.
+ *
+ *********************************************************************/
+
+#include <config.h>
+
+#include "chroot-btrfs-snapshot.h"
+#include "chroot-directory.h"
+#include "chroot-facet-session.h"
+#include "chroot-facet-session-clonable.h"
+#include "chroot-facet-source-clonable.h"
+#include "format-detail.h"
+#include "lock.h"
+
+#include <cassert>
+#include <cerrno>
+
+#include <boost/format.hpp>
+
+using std::endl;
+using boost::format;
+using namespace sbuild;
+
+chroot_btrfs_snapshot::chroot_btrfs_snapshot ():
+ chroot(),
+ source_subvolume(),
+ snapshot_directory(),
+ snapshot_name()
+{
+ add_facet(chroot_facet_source_clonable::create());
+}
+
+chroot_btrfs_snapshot::chroot_btrfs_snapshot (const chroot_btrfs_snapshot& rhs):
+ chroot(rhs),
+ source_subvolume(rhs.source_subvolume),
+ snapshot_directory(rhs.snapshot_directory),
+ snapshot_name(rhs.snapshot_name)
+{
+}
+
+chroot_btrfs_snapshot::~chroot_btrfs_snapshot ()
+{
+}
+
+sbuild::chroot::ptr
+chroot_btrfs_snapshot::clone () const
+{
+ return ptr(new chroot_btrfs_snapshot(*this));
+}
+
+sbuild::chroot::ptr
+chroot_btrfs_snapshot::clone_session (std::string const& session_id,
+ std::string const& alias,
+ std::string const& user,
+ bool root) const
+{
+ chroot_facet_session_clonable::const_ptr psess
+ (get_facet<chroot_facet_session_clonable>());
+ assert(psess);
+
+ ptr session(new chroot_btrfs_snapshot(*this));
+ psess->clone_session_setup(*this, session, session_id, alias, user, root);
+
+ return session;
+}
+
+sbuild::chroot::ptr
+chroot_btrfs_snapshot::clone_source () const
+{
+ ptr clone(new chroot_directory(*this));
+
+ chroot_facet_source_clonable::const_ptr psrc
+ (get_facet<chroot_facet_source_clonable>());
+ assert(psrc);
+
+ psrc->clone_source_setup(*this, clone);
+
+ return clone;
+}
+
+std::string const&
+chroot_btrfs_snapshot::get_source_subvolume () const
+{
+ return this->source_subvolume;
+}
+
+void
+chroot_btrfs_snapshot::set_source_subvolume (std::string const& source_subvolume)
+{
+ if (!is_absname(source_subvolume))
+ throw error(source_subvolume, DIRECTORY_ABS);
+
+ this->source_subvolume = source_subvolume;
+}
+
+std::string const&
+chroot_btrfs_snapshot::get_snapshot_directory () const
+{
+ return this->snapshot_directory;
+}
+
+void
+chroot_btrfs_snapshot::set_snapshot_directory (std::string const& snapshot_directory)
+{
+ if (!is_absname(snapshot_directory))
+ throw error(source_subvolume, DIRECTORY_ABS);
+
+ this->snapshot_directory = snapshot_directory;
+}
+
+std::string const&
+chroot_btrfs_snapshot::get_snapshot_name () const
+{
+ return this->snapshot_name;
+}
+
+void
+chroot_btrfs_snapshot::set_snapshot_name (std::string const& snapshot_name)
+{
+ if (!is_absname(snapshot_name))
+ throw error(source_subvolume, DIRECTORY_ABS);
+
+ this->snapshot_name = snapshot_name;
+}
+
+std::string const&
+chroot_btrfs_snapshot::get_chroot_type () const
+{
+ static const std::string type("btrfs-snapshot");
+
+ return type;
+}
+
+std::string
+chroot_btrfs_snapshot::get_path () const
+{
+ return get_mount_location();
+}
+
+void
+chroot_btrfs_snapshot::setup_env (chroot const& chroot,
+ environment& env) const
+{
+ chroot::setup_env(chroot, env);
+
+ env.add("CHROOT_BTRFS_SOURCE_SUBVOLUME", get_source_subvolume());
+ env.add("CHROOT_BTRFS_SNAPSHOT_DIRECTORY", get_snapshot_directory());
+ env.add("CHROOT_BTRFS_SNAPSHOT_NAME", get_snapshot_name());
+}
+
+void
+chroot_btrfs_snapshot::setup_lock (chroot::setup_type type,
+ bool lock,
+ int status)
+{
+ /* Create or unlink session information. */
+ if ((type == SETUP_START && lock == true) ||
+ (type == SETUP_STOP && lock == false && status == 0))
+ {
+ bool start = (type == SETUP_START);
+ setup_session_info(start);
+ }
+}
+
+sbuild::chroot::session_flags
+chroot_btrfs_snapshot::get_session_flags (chroot const& chroot) const
+{
+ session_flags flags = SESSION_NOFLAGS;
+
+ if (get_facet<chroot_facet_session>())
+ flags = flags | SESSION_PURGE;
+
+ return flags;
+}
+
+void
+chroot_btrfs_snapshot::get_details (chroot const& chroot,
+ format_detail& detail) const
+{
+ chroot::get_details(chroot, detail);
+
+ if (!this->get_source_subvolume().empty())
+ detail.add(_("Btrfs Source Subvolume"), get_source_subvolume());
+ if (!this->get_snapshot_directory().empty())
+ detail.add(_("Btrfs Snapshot Directory"), get_snapshot_directory());
+ if (!this->get_snapshot_name().empty())
+ detail.add(_("Btrfs Snapshot Name"), get_snapshot_name());
+}
+
+void
+chroot_btrfs_snapshot::get_used_keys (string_list& used_keys) const
+{
+ chroot::get_used_keys(used_keys);
+
+ used_keys.push_back("btrfs-source-subvolume");
+ used_keys.push_back("btrfs-snapshot-directory");
+ used_keys.push_back("btrfs-snapshot-name");
+}
+
+void
+chroot_btrfs_snapshot::get_keyfile (chroot const& chroot,
+ keyfile& keyfile) const
+{
+ chroot::get_keyfile(chroot, keyfile);
+
+ bool session = static_cast<bool>(get_facet<chroot_facet_session>());
+
+ if (!session)
+ keyfile::set_object_value(*this,
+ &chroot_btrfs_snapshot::get_source_subvolume,
+ keyfile, get_name(),
+ "btrfs-source-subvolume");
+
+ if (!session)
+ keyfile::set_object_value(*this,
+ &chroot_btrfs_snapshot::get_snapshot_directory,
+ keyfile, get_name(),
+ "btrfs-snapshot-directory");
+
+ if (session)
+ keyfile::set_object_value(*this,
+ &chroot_btrfs_snapshot::get_snapshot_name,
+ keyfile, get_name(),
+ "btrfs-snapshot-name");
+}
+
+void
+chroot_btrfs_snapshot::set_keyfile (chroot& chroot,
+ keyfile const& keyfile)
+{
+ chroot::set_keyfile(chroot, keyfile);
+
+ bool session = static_cast<bool>(get_facet<chroot_facet_session>());
+
+ keyfile::get_object_value(*this, &chroot_btrfs_snapshot::set_source_subvolume,
+ keyfile, get_name(), "btrfs-source-subvolume",
+ session ?
+ keyfile::PRIORITY_DISALLOWED :
+ keyfile::PRIORITY_REQUIRED
+ ); // Only needed for creating snapshot, not using snapshot
+
+ keyfile::get_object_value(*this, &chroot_btrfs_snapshot::set_snapshot_directory,
+ keyfile, get_name(), "btrfs-snapshot-directory",
+ session ?
+ keyfile::PRIORITY_DISALLOWED :
+ keyfile::PRIORITY_REQUIRED
+ ); // Only needed for creating snapshot, not using snapshot
+
+ keyfile::get_object_value(*this, &chroot_btrfs_snapshot::set_snapshot_name,
+ keyfile, get_name(), "btrfs-snapshot-name",
+ session ?
+ keyfile::PRIORITY_REQUIRED :
+ keyfile::PRIORITY_DISALLOWED);
+}