1*7c604eeaShaad /* $NetBSD: vgcfgrestore.c,v 1.1.1.2 2009/12/02 00:25:56 haad Exp $ */
256a34939Shaad
356a34939Shaad /*
456a34939Shaad * Copyright (C) 2001-2004 Sistina Software, Inc. All rights reserved.
5*7c604eeaShaad * Copyright (C) 2004-2009 Red Hat, Inc. All rights reserved.
656a34939Shaad *
756a34939Shaad * This file is part of LVM2.
856a34939Shaad *
956a34939Shaad * This copyrighted material is made available to anyone wishing to use,
1056a34939Shaad * modify, copy, or redistribute it subject to the terms and conditions
1156a34939Shaad * of the GNU Lesser General Public License v.2.1.
1256a34939Shaad *
1356a34939Shaad * You should have received a copy of the GNU Lesser General Public License
1456a34939Shaad * along with this program; if not, write to the Free Software Foundation,
1556a34939Shaad * Inc., 59 Temple Place, Suite 330, Boston, MA 02111-1307 USA
1656a34939Shaad */
1756a34939Shaad
1856a34939Shaad #include "tools.h"
1956a34939Shaad
vgcfgrestore(struct cmd_context * cmd,int argc,char ** argv)2056a34939Shaad int vgcfgrestore(struct cmd_context *cmd, int argc, char **argv)
2156a34939Shaad {
2256a34939Shaad char *vg_name = NULL;
2356a34939Shaad
2456a34939Shaad if (argc == 1) {
2556a34939Shaad vg_name = skip_dev_dir(cmd, argv[0], NULL);
2656a34939Shaad if (!validate_name(vg_name)) {
2756a34939Shaad log_error("Volume group name \"%s\" is invalid", vg_name);
2856a34939Shaad return ECMD_FAILED;
2956a34939Shaad }
3056a34939Shaad } else if (!(arg_count(cmd, list_ARG) && arg_count(cmd, file_ARG))) {
31*7c604eeaShaad log_error("Please specify a *single* volume group to restore.");
3256a34939Shaad return ECMD_FAILED;
3356a34939Shaad }
3456a34939Shaad
3556a34939Shaad /*
3656a34939Shaad * FIXME: overloading the -l arg for now to display a
3756a34939Shaad * list of archive files for a particular vg
3856a34939Shaad */
3956a34939Shaad if (arg_count(cmd, list_ARG)) {
4056a34939Shaad if (!(arg_count(cmd,file_ARG) ?
4156a34939Shaad archive_display_file(cmd,
4256a34939Shaad arg_str_value(cmd, file_ARG, "")) :
43*7c604eeaShaad archive_display(cmd, vg_name))) {
44*7c604eeaShaad stack;
4556a34939Shaad return ECMD_FAILED;
46*7c604eeaShaad }
4756a34939Shaad return ECMD_PROCESSED;
4856a34939Shaad }
4956a34939Shaad
50*7c604eeaShaad if (!lock_vol(cmd, vg_name, LCK_VG_WRITE)) {
51*7c604eeaShaad log_error("Unable to lock volume group %s", vg_name);
52*7c604eeaShaad return ECMD_FAILED;
53*7c604eeaShaad }
54*7c604eeaShaad
5556a34939Shaad if (!lock_vol(cmd, VG_ORPHANS, LCK_VG_WRITE)) {
5656a34939Shaad log_error("Unable to lock orphans");
57*7c604eeaShaad unlock_vg(cmd, vg_name);
5856a34939Shaad return ECMD_FAILED;
5956a34939Shaad }
6056a34939Shaad
61*7c604eeaShaad cmd->handles_unknown_segments = 1;
6256a34939Shaad
6356a34939Shaad if (!(arg_count(cmd, file_ARG) ?
6456a34939Shaad backup_restore_from_file(cmd, vg_name,
6556a34939Shaad arg_str_value(cmd, file_ARG, "")) :
6656a34939Shaad backup_restore(cmd, vg_name))) {
6756a34939Shaad unlock_vg(cmd, VG_ORPHANS);
68*7c604eeaShaad unlock_vg(cmd, vg_name);
69*7c604eeaShaad log_error("Restore failed.");
7056a34939Shaad return ECMD_FAILED;
7156a34939Shaad }
7256a34939Shaad
7356a34939Shaad log_print("Restored volume group %s", vg_name);
7456a34939Shaad
7556a34939Shaad unlock_vg(cmd, VG_ORPHANS);
76*7c604eeaShaad unlock_vg(cmd, vg_name);
7756a34939Shaad return ECMD_PROCESSED;
7856a34939Shaad }
79