2001-12-20 19:05:14 +03:00
/*
2008-01-30 17:00:02 +03:00
* Copyright ( C ) 2001 - 2004 Sistina Software , Inc . All rights reserved .
2007-08-21 00:55:30 +04:00
* Copyright ( C ) 2004 - 2007 Red Hat , Inc . All rights reserved .
2001-12-20 19:05:14 +03:00
*
2004-03-30 23:35:44 +04:00
* This file is part of LVM2 .
*
* This copyrighted material is made available to anyone wishing to use ,
* modify , copy , or redistribute it subject to the terms and conditions
2007-08-21 00:55:30 +04:00
* of the GNU Lesser General Public License v .2 .1 .
2004-03-30 23:35:44 +04:00
*
2007-08-21 00:55:30 +04:00
* You should have received a copy of the GNU Lesser General Public License
2004-03-30 23:35:44 +04:00
* along with this program ; if not , write to the Free Software Foundation ,
2016-01-21 13:49:46 +03:00
* Inc . , 51 Franklin Street , Fifth Floor , Boston , MA 02110 - 1301 USA
2001-12-20 19:05:14 +03:00
*/
# include "tools.h"
2004-06-19 22:55:29 +04:00
static char * _expand_filename ( const char * template , const char * vg_name ,
char * * last_filename )
{
char * filename ;
2017-11-05 20:39:05 +03:00
if ( security_level ( ) ) {
2018-06-08 15:40:53 +03:00
if ( ! ( filename = strdup ( template ) ) ) {
2017-11-05 20:39:05 +03:00
log_error ( " Failed to allocate filename. " ) ;
return NULL ;
}
goto out ;
}
2004-06-19 22:55:29 +04:00
2018-06-08 15:40:53 +03:00
if ( ! ( filename = malloc ( PATH_MAX ) ) ) {
2006-05-10 21:49:25 +04:00
log_error ( " Failed to allocate filename. " ) ;
return NULL ;
}
2012-02-08 15:40:02 +04:00
if ( dm_snprintf ( filename , PATH_MAX , template , vg_name ) < 0 ) {
2004-06-19 22:55:29 +04:00
log_error ( " Error processing filename template %s " ,
template ) ;
2018-06-08 15:40:53 +03:00
free ( filename ) ;
2004-06-19 22:55:29 +04:00
return NULL ;
}
2008-08-13 16:44:24 +04:00
if ( * last_filename & & ! strncmp ( * last_filename , filename , PATH_MAX ) ) {
2004-06-19 22:55:29 +04:00
log_error ( " VGs must be backed up into different files. "
" Use %%s in filename for VG name. " ) ;
2018-06-08 15:40:53 +03:00
free ( filename ) ;
2004-06-19 22:55:29 +04:00
return NULL ;
}
2017-11-05 20:39:05 +03:00
out :
2018-06-08 15:40:53 +03:00
free ( * last_filename ) ;
2004-06-19 22:55:29 +04:00
* last_filename = filename ;
return filename ;
}
2017-10-18 17:57:46 +03:00
static int _vg_backup_single ( struct cmd_context * cmd , const char * vg_name ,
struct volume_group * vg ,
struct processing_handle * handle )
2001-12-20 19:05:14 +03:00
{
2014-11-27 17:02:13 +03:00
char * * last_filename = ( char * * ) handle - > custom_handle ;
2004-06-19 22:55:29 +04:00
char * filename ;
2016-06-22 00:24:52 +03:00
if ( arg_is_set ( cmd , file_ARG ) ) {
2004-06-19 22:55:29 +04:00
if ( ! ( filename = _expand_filename ( arg_value ( cmd , file_ARG ) ,
2013-07-01 13:27:22 +04:00
vg - > name , last_filename ) ) )
return_ECMD_FAILED ;
2002-01-07 12:05:31 +03:00
2013-07-01 13:27:22 +04:00
if ( ! backup_to_file ( filename , vg - > cmd - > cmd_line , vg ) )
return_ECMD_FAILED ;
2002-01-07 12:05:31 +03:00
} else {
2009-07-01 21:00:50 +04:00
if ( vg_read_error ( vg ) = = FAILED_INCONSISTENT ) {
2002-11-18 17:04:08 +03:00
log_error ( " No backup taken: specify filename with -f "
" to backup an inconsistent VG " ) ;
return ECMD_FAILED ;
}
2019-02-06 22:46:35 +03:00
if ( vg_missing_pv_count ( vg ) ) {
log_error ( " No backup taken: specify filename with -f to backup with missing PVs. " ) ;
return ECMD_FAILED ;
}
if ( vg_has_unknown_segments ( vg ) ) {
log_error ( " No backup taken: specify filename with -f to backup with unknown segments. " ) ;
return ECMD_FAILED ;
}
2002-01-07 12:05:31 +03:00
/* just use the normal backup code */
2005-05-17 17:46:38 +04:00
backup_enable ( cmd , 1 ) ; /* force a backup */
2013-07-01 13:27:22 +04:00
if ( ! backup ( vg ) )
return_ECMD_FAILED ;
2001-12-20 19:05:14 +03:00
}
config: add silent mode
Accept -q as the short form of --quiet.
Suppress non-essential standard output if -q is given twice.
Treat log/silent in lvm.conf as equivalent to -qq.
Review all log_print messages and change some to
log_print_unless_silent.
When silent, the following commands still produce output:
dumpconfig, lvdisplay, lvmdiskscan, lvs, pvck, pvdisplay,
pvs, version, vgcfgrestore -l, vgdisplay, vgs.
[Needs checking.]
Non-essential messages are shifted from log level 4 to log level 5
for syslog and lvm2_log_fn purposes.
2012-08-25 23:35:48 +04:00
log_print_unless_silent ( " Volume group \" %s \" successfully backed up. " , vg_name ) ;
2013-07-01 13:27:11 +04:00
2003-10-22 02:06:07 +04:00
return ECMD_PROCESSED ;
2001-12-20 19:05:14 +03:00
}
2002-02-11 23:50:53 +03:00
int vgcfgbackup ( struct cmd_context * cmd , int argc , char * * argv )
2001-12-20 19:05:14 +03:00
{
2003-04-30 19:25:34 +04:00
int ret ;
2004-06-19 22:55:29 +04:00
char * last_filename = NULL ;
2015-02-13 12:36:06 +03:00
struct processing_handle * handle = NULL ;
2016-05-31 13:24:05 +03:00
if ( ! ( handle = init_processing_handle ( cmd , NULL ) ) ) {
2015-02-13 12:36:06 +03:00
log_error ( " Failed to initialize processing handle. " ) ;
return ECMD_FAILED ;
}
handle - > custom_handle = & last_filename ;
2003-04-30 19:25:34 +04:00
2019-02-06 22:46:35 +03:00
/*
* Just set so that we can do the check ourselves above and
* report a helpful error message in place of the error message
* that would be generated from vg_read .
*/
cmd - > handles_missing_pvs = 1 ;
cmd - > handles_unknown_segments = 1 ;
2008-09-19 10:42:00 +04:00
init_pvmove ( 1 ) ;
2003-04-30 19:25:34 +04:00
2016-05-03 12:46:28 +03:00
ret = process_each_vg ( cmd , argc , argv , NULL , NULL , READ_ALLOW_INCONSISTENT , 0 ,
2017-10-18 17:57:46 +03:00
handle , & _vg_backup_single ) ;
2003-04-30 19:25:34 +04:00
2018-06-08 15:40:53 +03:00
free ( last_filename ) ;
2004-06-19 22:55:29 +04:00
2003-04-30 19:25:34 +04:00
init_pvmove ( 0 ) ;
2015-02-13 12:42:21 +03:00
destroy_processing_handle ( cmd , handle ) ;
2003-04-30 19:25:34 +04:00
return ret ;
2001-12-20 19:05:14 +03:00
}