2002-12-12 20:55:49 +00:00
/*
2004-03-30 19:35:44 +00:00
* Copyright ( C ) 2002 - 2004 Sistina Software , Inc . All rights reserved .
2009-02-09 09:45:49 +00:00
* Copyright ( C ) 2004 - 2009 Red Hat , Inc . All rights reserved .
2002-12-12 20:55:49 +00:00
*
2004-03-30 19:35:44 +00:00
* This file is part of LVM2 .
2002-12-12 20:55:49 +00:00
*
2004-03-30 19:35:44 +00:00
* 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 .
2002-12-12 20:55:49 +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
2002-12-12 20:55:49 +00:00
*/
# ifndef _LVM_REPORT_H
# define _LVM_REPORT_H
2018-05-14 10:30:20 +01:00
# include "lib/metadata/metadata-exported.h"
# include "lib/label/label.h"
# include "lib/activate/activate.h"
2002-12-12 20:55:49 +00:00
2024-05-27 15:10:58 +02:00
enum {
2016-05-10 15:15:48 +02:00
CMDLOG = 1 ,
2016-05-03 11:18:16 +02:00
FULL = 2 ,
LVS = 4 ,
LVSINFO = 8 ,
LVSSTATUS = 16 ,
LVSINFOSTATUS = 32 ,
PVS = 64 ,
VGS = 128 ,
SEGS = 256 ,
PVSEGS = 512 ,
LABEL = 1024 ,
DEVTYPES = 2048
2024-05-27 15:10:58 +02:00
} ;
2002-12-12 20:55:49 +00:00
2023-08-22 10:54:35 +02:00
typedef enum {
REPORT_HEADINGS_UNKNOWN = - 1 ,
REPORT_HEADINGS_NONE = 0 ,
REPORT_HEADINGS_ABBREV = 1 ,
REPORT_HEADINGS_FULL = 2
} report_headings_t ;
2014-11-27 15:02:13 +01:00
/*
* The " struct selection_handle " is used only for selection
* of items that should be processed further ( not for display ! ) .
*
* It consists of selection reporting handle " selection_rh "
* used for the selection itself ( not for display on output ! ) .
* The items are reported directly in memory to a buffer and
* then compared against selection criteria . Once we know the
* result of the selection , the buffer is dropped !
*
* The " orig_report_type " is the original requested report type .
* The " report_type " is the reporting type actually used which
* also counts with report types of the fields used in selection
* criteria .
*
* The " selected " variable is used for propagating the result
* of the selection .
*/
struct selection_handle {
struct dm_report * selection_rh ;
2024-05-27 15:10:58 +02:00
unsigned orig_report_type ;
unsigned report_type ;
2014-11-27 15:02:13 +01:00
int selected ;
} ;
2016-05-10 15:15:48 +02:00
struct cmd_log_item {
uint32_t seq_num ;
const char * type ;
const char * context ;
const char * object_type_name ;
const char * object_name ;
const char * object_id ;
const char * object_group ;
const char * object_group_id ;
const char * msg ;
int current_errno ;
int ret_code ;
} ;
2002-12-12 20:55:49 +00:00
struct field ;
struct report_handle ;
2016-05-30 16:28:47 +02:00
struct processing_handle ;
2002-12-12 20:55:49 +00:00
typedef int ( * field_report_fn ) ( struct report_handle * dh , struct field * field ,
const void * data ) ;
2023-08-22 10:54:35 +02:00
report_headings_t report_headings_str_to_type ( const char * str ) ;
2016-08-03 15:37:14 +02:00
int report_format_init ( struct cmd_context * cmd ) ;
2016-05-02 14:22:02 +02:00
2002-12-12 20:55:49 +00:00
void * report_init ( struct cmd_context * cmd , const char * format , const char * keys ,
2024-05-27 15:10:58 +02:00
unsigned * report_type , const char * separator ,
2023-08-22 10:54:35 +02:00
int aligned , int buffered , report_headings_t headings ,
int field_prefixes , int quoted , int columns_as_rows ,
const char * selection , int multiple_output ) ;
2024-05-27 15:10:58 +02:00
int report_get_single_selection ( struct cmd_context * cmd , unsigned report_type , const char * * selection ) ;
void * report_init_for_selection ( struct cmd_context * cmd , unsigned * report_type ,
2014-12-02 13:14:12 +01:00
const char * selection ) ;
2024-05-27 15:10:58 +02:00
int report_get_prefix_and_desc ( unsigned report_type_id ,
2016-06-14 16:44:52 +02:00
const char * * report_prefix ,
const char * * report_desc ) ;
2015-02-13 10:36:06 +01:00
int report_for_selection ( struct cmd_context * cmd ,
2016-05-30 16:28:47 +02:00
struct processing_handle * parent_handle ,
2014-12-01 14:19:30 +01:00
struct physical_volume * pv ,
struct volume_group * vg ,
struct logical_volume * lv ) ;
2002-12-12 20:55:49 +00:00
void report_free ( void * handle ) ;
2014-12-02 13:14:12 +01:00
int report_object ( void * handle , int selection_only , const struct volume_group * vg ,
2015-01-14 10:31:24 +01:00
const struct logical_volume * lv , const struct physical_volume * pv ,
const struct lv_segment * seg , const struct pv_segment * pvseg ,
2015-01-20 13:16:41 +01:00
const struct lv_with_info_and_seg_status * lvdm ,
2015-01-14 10:31:24 +01:00
const struct label * label ) ;
2013-09-18 01:09:15 +01:00
int report_devtypes ( void * handle ) ;
2016-05-10 15:15:48 +02:00
int report_cmdlog ( void * handle , const char * type , const char * context ,
const char * object_type_name , const char * object_name ,
2024-10-18 19:38:25 +02:00
const struct id * object_id , const char * object_group ,
const struct id * object_group_id , const char * msg ,
2016-05-10 15:15:48 +02:00
int current_errno , int ret_code ) ;
2016-08-08 15:45:46 +02:00
void report_reset_cmdlog_seqnum ( void ) ;
2016-05-23 15:27:09 +02:00
# define REPORT_OBJECT_CMDLOG_NAME "status"
# define REPORT_OBJECT_CMDLOG_SUCCESS "success"
# define REPORT_OBJECT_CMDLOG_FAILURE "failure"
2016-05-23 15:09:05 +02:00
int report_current_object_cmdlog ( const char * type , const char * msg , int32_t ret_code ) ;
2002-12-12 20:55:49 +00:00
int report_output ( void * handle ) ;
# endif