2004-03-26 12:25:15 +00:00
/*
2004-03-30 19:35:44 +00:00
* Copyright ( C ) 2001 - 2004 Sistina Software , Inc . All rights reserved .
2007-07-18 15:38:58 +00:00
* Copyright ( C ) 2004 - 2007 Red Hat , Inc . All rights reserved .
2004-03-26 12:25:15 +00:00
*
2004-03-30 19:35:44 +00: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-20 20:55:30 +00:00
* of the GNU Lesser General Public License v .2 .1 .
2004-03-30 19:35:44 +00:00
*
2007-08-20 20:55:30 +00:00
* You should have received a copy of the GNU Lesser General Public License
2004-03-30 19:35:44 +00:00
* along with this program ; if not , write to the Free Software Foundation ,
2016-01-21 11:49:46 +01:00
* Inc . , 51 Franklin Street , Fifth Floor , Boston , MA 02110 - 1301 USA
2004-03-26 12:25:15 +00:00
*/
# ifndef _LVM_TOOL_ARCHIVE_H
# define _LVM_TOOL_ARCHIVE_H
2007-07-18 15:38:58 +00:00
# include "metadata-exported.h"
2004-03-26 12:25:15 +00:00
/*
* There are two operations that come under the general area of
* backups . ' Archiving ' occurs just before a volume group
* configuration is changed . The user may configure when
* archived files are expired . Typically archives will be stored
* in / etc / lvm / archive .
*
* A ' backup ' is a redundant copy of the * current * volume group
* configuration . As such it should be taken just after the
* volume group is changed . Only 1 backup file will exist .
* Typically backups will be stored in / etc / lvm / backups .
*/
2005-05-17 13:46:38 +00:00
int archive_init ( struct cmd_context * cmd , const char * dir ,
2008-12-11 03:32:56 +00:00
unsigned int keep_days , unsigned int keep_min ,
int enabled ) ;
2005-05-17 13:46:38 +00:00
void archive_exit ( struct cmd_context * cmd ) ;
2004-03-26 12:25:15 +00:00
2005-05-17 13:46:38 +00:00
void archive_enable ( struct cmd_context * cmd , int flag ) ;
2004-03-26 12:25:15 +00:00
int archive ( struct volume_group * vg ) ;
int archive_display ( struct cmd_context * cmd , const char * vg_name ) ;
2007-06-08 22:38:48 +00:00
int archive_display_file ( struct cmd_context * cmd , const char * file ) ;
2004-03-26 12:25:15 +00:00
2008-12-11 03:33:35 +00:00
int backup_init ( struct cmd_context * cmd , const char * dir , int enabled ) ;
2005-05-17 13:46:38 +00:00
void backup_exit ( struct cmd_context * cmd ) ;
2004-03-26 12:25:15 +00:00
2005-05-17 13:46:38 +00:00
void backup_enable ( struct cmd_context * cmd , int flag ) ;
2004-03-26 12:25:15 +00:00
int backup ( struct volume_group * vg ) ;
2009-04-22 09:39:45 +00:00
int backup_locally ( struct volume_group * vg ) ;
2005-05-17 13:46:38 +00:00
int backup_remove ( struct cmd_context * cmd , const char * vg_name ) ;
2004-03-26 12:25:15 +00:00
struct volume_group * backup_read_vg ( struct cmd_context * cmd ,
const char * vg_name , const char * file ) ;
2013-09-18 12:53:11 +02:00
int backup_restore_vg ( struct cmd_context * cmd , struct volume_group * vg , int drop_lvmetad ) ;
2004-03-26 12:25:15 +00:00
int backup_restore_from_file ( struct cmd_context * cmd , const char * vg_name ,
2012-11-26 23:45:35 +01:00
const char * file , int force ) ;
int backup_restore ( struct cmd_context * cmd , const char * vg_name , int force ) ;
2004-03-26 12:25:15 +00:00
int backup_to_file ( const char * file , const char * desc , struct volume_group * vg ) ;
2005-05-17 13:44:02 +00:00
void check_current_backup ( struct volume_group * vg ) ;
2004-03-26 12:25:15 +00:00
# endif