1
0
mirror of git://sourceware.org/git/lvm2.git synced 2025-01-02 01:18:26 +03:00

dumpconfig: add --type, --atversion and --validate arg

lvm dumpconfig [--type {current|default|missing|new}] [--atversion] [--validate]

This patch adds above-mentioned args to lvm dumpconfig and it maps them
to creation and writing out a configuration tree of a specific type
(see also previous commit):

  - current maps to CFG_TYPE_CURRENT
  - default maps to CFG_TYPE_DEFAULT
  - missing maps to CFG_TYPE_MISSING
  - new maps to CFG_TYPE_NEW

If --type is not defined, dumpconfig defaults to "--type current"
which is the original behaviour of dumpconfig before all these changes.

The --validate option just validates current configuration tree
(lvm.conf/--config) and it writes a simple status message:

  "LVM configuration valid" or "LVM configuration invalid"
This commit is contained in:
Peter Rajnoha 2013-03-05 17:48:29 +01:00
parent 245b85692e
commit 34350963d1
5 changed files with 91 additions and 10 deletions

View File

@ -488,7 +488,7 @@ static int _config_def_check_node(const char *vp, char *pvp, char *rp, char *prp
def->flags |= CFG_USED; def->flags |= CFG_USED;
if (!_config_def_check_node_value(rp, cn->v, def, suppress_messages)) if (!_config_def_check_node_value(rp, cn->v, def, suppress_messages))
return 0; return 0;
def->flags |= CFG_VALID; def->flags |= CFG_VALID;
return 1; return 1;

View File

@ -79,6 +79,9 @@ arg(force_long_ARG, '\0', "force", NULL, ARG_COUNTABLE)
arg(stripes_long_ARG, '\0', "stripes", int_arg, 0) arg(stripes_long_ARG, '\0', "stripes", int_arg, 0)
arg(sysinit_ARG, '\0', "sysinit", NULL, 0) arg(sysinit_ARG, '\0', "sysinit", NULL, 0)
arg(thinpool_ARG, '\0', "thinpool", string_arg, 0) arg(thinpool_ARG, '\0', "thinpool", string_arg, 0)
arg(configtype_ARG, '\0', "type", string_arg, 0)
arg(atversion_ARG, '\0', "atversion", string_arg, 0)
arg(validate_ARG, '\0', "validate", NULL, 0)
/* Allow some variations */ /* Allow some variations */
arg(resizable_ARG, '\0', "resizable", yes_no_arg, 0) arg(resizable_ARG, '\0', "resizable", yes_no_arg, 0)

View File

@ -29,12 +29,15 @@ xx(e2fsadm,
*********/ *********/
xx(dumpconfig, xx(dumpconfig,
"Dump active configuration", "Dump configuration",
PERMITTED_READ_ONLY, PERMITTED_READ_ONLY,
"dumpconfig " "dumpconfig\n"
"\t[-f|--file filename] " "\n" "\t[-f|--file filename] \n"
"[ConfigurationVariable...]\n", "\t[--type {current|default|missing|new} \n"
file_ARG) "\t[--atversion version]] \n"
"\t[--validate]\n"
"\t[ConfigurationNode...]\n",
file_ARG, configtype_ARG, atversion_ARG, validate_ARG)
xx(formats, xx(formats,
"List available metadata formats", "List available metadata formats",

View File

@ -15,14 +15,88 @@
#include "tools.h" #include "tools.h"
static int _get_vsn(struct cmd_context *cmd, unsigned int *major,
unsigned int *minor, unsigned int *patchlevel)
{
const char *atversion = arg_str_value(cmd, atversion_ARG, NULL);
if (!atversion)
atversion = LVM_VERSION;
if (sscanf(atversion, "%u.%u.%u", major, minor, patchlevel) != 3) {
log_error("Incorrect version format.");
return 0;
}
return 1;
}
int dumpconfig(struct cmd_context *cmd, int argc, char **argv) int dumpconfig(struct cmd_context *cmd, int argc, char **argv)
{ {
const char *file = arg_str_value(cmd, file_ARG, NULL); const char *file = arg_str_value(cmd, file_ARG, NULL);
const char *type = arg_str_value(cmd, configtype_ARG, "current");
unsigned int major, minor, patchlevel;
struct config_def_tree_spec tree_spec = {0};
struct dm_config_tree *cft;
int r = ECMD_PROCESSED;
if (!config_write(cmd->cft, file, argc, argv)) { if (arg_count(cmd, configtype_ARG) && arg_count(cmd, validate_ARG)) {
stack; log_error("Only one of --type and --validate permitted.");
return ECMD_FAILED; return EINVALID_CMD_LINE;
} }
return ECMD_PROCESSED; if (arg_count(cmd, atversion_ARG) && !arg_count(cmd, configtype_ARG)) {
log_error("--atversion requires --type");
return EINVALID_CMD_LINE;
}
if (arg_count(cmd, validate_ARG)) {
if (config_def_check(cmd, 1, 1, 0)) {
log_print("LVM configuration valid.");
return ECMD_PROCESSED;
} else {
log_error("LVM configuration invalid.");
return ECMD_FAILED;
}
}
if (!strcmp(type, "current")) {
if (arg_count(cmd, atversion_ARG)) {
log_error("--atversion has no effect with --type current");
return EINVALID_CMD_LINE;
}
cft = cmd->cft;
tree_spec.type = CFG_DEF_TREE_CURRENT;
config_def_check(cmd, 1, 1, 1);
}
else if (!strcmp(type, "default"))
tree_spec.type = CFG_DEF_TREE_DEFAULT;
else if (!strcmp(type, "missing"))
tree_spec.type = CFG_DEF_TREE_MISSING;
else if (!strcmp(type, "new"))
tree_spec.type = CFG_DEF_TREE_NEW;
else {
log_error("Incorrect type of configuration specified. "
"Expected one of: current, default, missing, new.");
return EINVALID_CMD_LINE;
}
if (tree_spec.type != CFG_DEF_TREE_CURRENT) {
if (!_get_vsn(cmd, &major, &minor, &patchlevel))
return EINVALID_CMD_LINE;
tree_spec.version = vsn(major, minor, patchlevel);
cft = config_def_create_tree(&tree_spec);
}
if (!config_write(cft, file, argc, argv)) {
stack;
r = ECMD_FAILED;
}
/* cmd->cft (the "current" tree) is destroyed with cmd context destroy! */
if (tree_spec.type != CFG_DEF_TREE_CURRENT && cft)
dm_pool_destroy(cft->mem);
return r;
} }

View File

@ -29,6 +29,7 @@
#include "archiver.h" #include "archiver.h"
#include "lvmcache.h" #include "lvmcache.h"
#include "lvmetad.h" #include "lvmetad.h"
#include "lvm-version.h"
#include "config.h" #include "config.h"
#include "defaults.h" #include "defaults.h"
#include "dev-cache.h" #include "dev-cache.h"