2019-08-21 20:42:45 -05:00
/*
* This library is free software ; you can redistribute it and / or
* modify it under the terms of the GNU Lesser General Public
* License as published by the Free Software Foundation ; either
* version 2.1 of the License , or ( at your option ) any later version .
*
* This library 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
* Lesser General Public License for more details .
*
* You should have received a copy of the GNU Lesser General Public
* License along with this library . If not , see
* < http : //www.gnu.org/licenses/>.
*/
# include <config.h>
# include "virsh-backup.h"
# include "virsh-util.h"
# include "internal.h"
# include "virfile.h"
/*
* " backup-begin " command
*/
static const vshCmdInfo info_backup_begin [ ] = {
{ . name = " help " ,
. data = N_ ( " Start a disk backup of a live domain " )
} ,
{ . name = " desc " ,
. data = N_ ( " Use XML to start a full or incremental disk backup of a live "
" domain, optionally creating a checkpoint " )
} ,
{ . name = NULL }
} ;
static const vshCmdOptDef opts_backup_begin [ ] = {
2020-09-11 15:13:17 +08:00
VIRSH_COMMON_OPT_DOMAIN_FULL ( VIR_CONNECT_LIST_DOMAINS_ACTIVE ) ,
2019-08-21 20:42:45 -05:00
{ . name = " backupxml " ,
. type = VSH_OT_STRING ,
2021-09-15 17:26:35 +02:00
. completer = virshCompletePathLocalExisting ,
2019-08-21 20:42:45 -05:00
. help = N_ ( " domain backup XML " ) ,
} ,
{ . name = " checkpointxml " ,
. type = VSH_OT_STRING ,
2021-09-15 17:26:35 +02:00
. completer = virshCompletePathLocalExisting ,
2019-08-21 20:42:45 -05:00
. help = N_ ( " domain checkpoint XML " ) ,
} ,
{ . name = " reuse-external " ,
. type = VSH_OT_BOOL ,
. help = N_ ( " reuse files provided by caller " ) ,
} ,
{ . name = NULL }
} ;
static bool
cmdBackupBegin ( vshControl * ctl ,
const vshCmd * cmd )
{
g_autoptr ( virshDomain ) dom = NULL ;
const char * backup_from = NULL ;
g_autofree char * backup_buffer = NULL ;
const char * check_from = NULL ;
g_autofree char * check_buffer = NULL ;
unsigned int flags = 0 ;
if ( vshCommandOptBool ( cmd , " reuse-external " ) )
flags | = VIR_DOMAIN_BACKUP_BEGIN_REUSE_EXTERNAL ;
if ( ! ( dom = virshCommandOptDomain ( ctl , cmd , NULL ) ) )
return false ;
if ( vshCommandOptStringReq ( ctl , cmd , " backupxml " , & backup_from ) < 0 )
return false ;
if ( ! backup_from ) {
backup_buffer = g_strdup ( " <domainbackup/> " ) ;
} else {
if ( virFileReadAll ( backup_from , VSH_MAX_XML_FILE , & backup_buffer ) < 0 ) {
vshSaveLibvirtError ( ) ;
return false ;
}
}
if ( vshCommandOptStringReq ( ctl , cmd , " checkpointxml " , & check_from ) < 0 )
return false ;
if ( check_from ) {
if ( virFileReadAll ( check_from , VSH_MAX_XML_FILE , & check_buffer ) < 0 ) {
vshSaveLibvirtError ( ) ;
return false ;
}
}
if ( virDomainBackupBegin ( dom , backup_buffer , check_buffer , flags ) < 0 )
return false ;
vshPrint ( ctl , _ ( " Backup started \n " ) ) ;
return true ;
}
/*
* " backup-dumpxml " command
*/
static const vshCmdInfo info_backup_dumpxml [ ] = {
{ . name = " help " ,
. data = N_ ( " Dump XML for an ongoing domain block backup job " )
} ,
{ . name = " desc " ,
. data = N_ ( " Backup Dump XML " )
} ,
{ . name = NULL }
} ;
static const vshCmdOptDef opts_backup_dumpxml [ ] = {
2020-09-11 15:13:17 +08:00
VIRSH_COMMON_OPT_DOMAIN_FULL ( VIR_CONNECT_LIST_DOMAINS_ACTIVE ) ,
2022-06-16 16:29:54 +01:00
{ . name = " xpath " ,
. type = VSH_OT_STRING ,
virsh: Require --xpath for *dumpxml
Historically, the dumpxml command reject any unknown arguments,
for instance:
virsh dumpxml fedora xxx
However, after v8.5.0-rc1~31 the second argument ('xxx') is
treated as an XPath, but it's not that clearly visible.
Therefore, require the --xpath switch, like this:
virsh dumpxml fedora --xpath xxx
Yes, this breaks already released virsh, but I think we can argue
that the pool of users of this particular function is very small.
We also document the argument being mandatory:
dumpxml [--inactive] [--security-info] [--update-cpu] [--migratable]
[--xpath EXPRESSION] [--wrap] domain
The sooner we do this change, the better.
The same applies for other *dumpxml functions (net-dumpxml,
pool-dumpxml, vol-dumpxl to name a few).
Resolves: https://bugzilla.redhat.com/show_bug.cgi?id=2103524
Signed-off-by: Michal Privoznik <mprivozn@redhat.com>
Reviewed-by: Peter Krempa <pkrempa@redhat.com>
2022-07-08 12:45:42 +02:00
. flags = VSH_OFLAG_REQ_OPT ,
2022-06-16 16:29:54 +01:00
. completer = virshCompleteEmpty ,
. help = N_ ( " xpath expression to filter the XML document " )
} ,
{ . name = " wrap " ,
. type = VSH_OT_BOOL ,
. help = N_ ( " wrap xpath results in an common root element " ) ,
} ,
2019-08-21 20:42:45 -05:00
{ . name = NULL }
} ;
static bool
cmdBackupDumpXML ( vshControl * ctl ,
const vshCmd * cmd )
{
g_autoptr ( virshDomain ) dom = NULL ;
g_autofree char * xml = NULL ;
2022-06-16 16:29:54 +01:00
bool wrap = vshCommandOptBool ( cmd , " wrap " ) ;
const char * xpath = NULL ;
2019-08-21 20:42:45 -05:00
if ( ! ( dom = virshCommandOptDomain ( ctl , cmd , NULL ) ) )
return false ;
2022-06-16 16:29:54 +01:00
if ( vshCommandOptStringQuiet ( ctl , cmd , " xpath " , & xpath ) < 0 )
return false ;
2019-08-21 20:42:45 -05:00
if ( ! ( xml = virDomainBackupGetXMLDesc ( dom , 0 ) ) )
return false ;
2022-06-16 16:29:54 +01:00
return virshDumpXML ( ctl , xml , " domain-backup " , xpath , wrap ) ;
2019-08-21 20:42:45 -05:00
}
const vshCmdDef backupCmds [ ] = {
{ . name = " backup-begin " ,
. handler = cmdBackupBegin ,
. opts = opts_backup_begin ,
. info = info_backup_begin ,
. flags = 0
} ,
{ . name = " backup-dumpxml " ,
. handler = cmdBackupDumpXML ,
. opts = opts_backup_dumpxml ,
. info = info_backup_dumpxml ,
. flags = 0
} ,
{ . name = NULL }
} ;