2011-05-13 08:07:28 +00:00
/*
2012-02-28 18:35:04 +00:00
* Copyright ( C ) 2011 - 2012 Red Hat , Inc .
2011-05-13 08:07:28 +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
* of the GNU Lesser General Public License v .2 .1 .
*
* You should have received a copy of the GNU Lesser General Public License
* along with this program ; if not , write to the Free Software Foundation ,
* Inc . , 59 Temple Place , Suite 330 , Boston , MA 02111 - 1307 USA
*/
2014-04-17 10:40:35 +02:00
# ifndef _LVM_DAEMON_CLIENT_H
# define _LVM_DAEMON_CLIENT_H
2011-05-13 08:07:28 +00:00
2012-10-11 14:17:17 +02:00
# include "config-util.h"
2012-02-28 18:35:04 +00:00
2011-05-13 08:07:28 +00:00
typedef struct {
int socket_fd ; /* the fd we use to talk to the daemon */
2012-02-23 23:52:11 +00:00
const char * protocol ;
int protocol_version ; /* version of the protocol the daemon uses */
2012-02-26 08:46:28 +00:00
int error ;
2011-05-13 08:07:28 +00:00
} daemon_handle ;
typedef struct {
const char * path ; /* the binary of the daemon */
const char * socket ; /* path to the comms socket */
unsigned autostart : 1 ; /* start the daemon if not running? */
2012-02-23 23:52:11 +00:00
/*
* If the following are not NULL / 0 , an attempt to talk to a daemon which
* uses a different protocol or version will fail .
*/
const char * protocol ;
int protocol_version ;
2011-05-13 08:07:28 +00:00
} daemon_info ;
typedef struct {
2012-10-11 14:17:17 +02:00
struct buffer buffer ;
2011-06-27 12:26:54 +00:00
/*
* The request looks like this :
* request = " id "
* arg_foo = " something "
* arg_bar = 3
* arg_wibble {
* something_special = " here "
* amount = 75
* knobs = [ " twiddle " , " tweak " ]
* }
*/
2011-08-30 15:42:56 +00:00
struct dm_config_tree * cft ;
2011-05-13 08:07:28 +00:00
} daemon_request ;
typedef struct {
2011-05-15 11:02:29 +00:00
int error ; /* 0 for success */
2012-10-11 14:17:17 +02:00
struct buffer buffer ;
2011-08-30 15:42:56 +00:00
struct dm_config_tree * cft ; /* parsed reply, if available */
2011-05-13 08:07:28 +00:00
} daemon_reply ;
/*
* Open the communication channel to the daemon . If the daemon is not running ,
* it may be autostarted based on the binary path provided in the info ( this
* will only happen if autostart is set to true ) . If the call fails for any
* reason , daemon_handle_valid ( h ) for the response will return false . Otherwise ,
* the connection is good to start serving requests .
*/
daemon_handle daemon_open ( daemon_info i ) ;
/*
* Send a request to the daemon , waiting for the reply . All communication with
* the daemon is synchronous . The function handles the IO details and parses the
* response , handling common error conditions . See " daemon_reply " for details .
2011-06-27 12:26:54 +00:00
*
* In case the request contains a non - NULL buffer pointer , this buffer is sent
* * verbatim * to the server . In this case , the cft pointer may be NULL ( but will
* be ignored even if non - NULL ) . If the buffer is NULL , the cft is required to
* be a valid pointer , and is used to build up the request .
2011-05-13 08:07:28 +00:00
*/
2011-05-15 11:02:29 +00:00
daemon_reply daemon_send ( daemon_handle h , daemon_request r ) ;
2011-05-13 08:07:28 +00:00
2011-06-27 12:26:54 +00:00
/*
* A simple interface to daemon_send . This function just takes the command id
* and possibly a list of parameters ( of the form " name = %? " , " value " ) . The
* type ( string , integer ) of the value is indicated by a character substituted
* for ? in % ? : d for integer , s for string .
*/
2012-01-15 15:16:50 +00:00
daemon_reply daemon_send_simple ( daemon_handle h , const char * id , . . . ) ;
2012-08-11 10:33:53 +02:00
daemon_reply daemon_send_simple_v ( daemon_handle h , const char * id , va_list ap ) ;
daemon_request daemon_request_make ( const char * id ) ;
int daemon_request_extend ( daemon_request r , . . . ) ;
int daemon_request_extend_v ( daemon_request r , va_list ap ) ;
void daemon_request_destroy ( daemon_request r ) ;
2011-06-27 12:26:54 +00:00
2011-06-27 13:58:11 +00:00
void daemon_reply_destroy ( daemon_reply r ) ;
2014-11-28 21:31:51 +00:00
static inline int64_t daemon_reply_int ( daemon_reply r , const char * path , int64_t def )
{
2012-03-01 19:54:53 +00:00
return dm_config_find_int64 ( r . cft - > root , path , def ) ;
2011-06-27 14:03:58 +00:00
}
2014-11-28 21:31:51 +00:00
static inline const char * daemon_reply_str ( daemon_reply r , const char * path , const char * def )
{
2014-03-24 16:47:08 +01:00
return dm_config_find_str_allow_empty ( r . cft - > root , path , def ) ;
2011-06-27 14:03:58 +00:00
}
2011-05-13 08:07:28 +00:00
/* Shut down the communication to the daemon. Compulsory. */
void daemon_close ( daemon_handle h ) ;
# endif