2011-06-14 02:34:18 +00:00
# include "daemon-client.h"
# include "daemon-shared.h"
# include <sys/un.h>
# include <sys/socket.h>
# include <string.h>
# include <stdio.h>
2011-08-31 12:18:40 +00:00
# include <unistd.h>
2011-06-14 02:34:18 +00:00
# include <assert.h>
2011-06-27 13:14:53 +00:00
# include <errno.h> // ENOMEM
2011-06-14 02:34:18 +00:00
daemon_handle daemon_open ( daemon_info i ) {
2011-09-17 14:49:18 +00:00
daemon_handle h = { . protocol = 0 } ;
2011-06-14 02:34:18 +00:00
struct sockaddr_un sockaddr ;
2011-09-17 14:49:18 +00:00
2011-06-27 13:14:53 +00:00
if ( ( h . socket_fd = socket ( PF_UNIX , SOCK_STREAM /* | SOCK_NONBLOCK */ , 0 ) ) < 0 ) {
2011-06-14 02:34:18 +00:00
perror ( " socket " ) ;
goto error ;
}
memset ( & sockaddr , 0 , sizeof ( sockaddr ) ) ;
2011-06-27 13:46:45 +00:00
fprintf ( stderr , " [C] connecting to %s \n " , i . socket ) ;
2011-06-14 02:34:18 +00:00
strcpy ( sockaddr . sun_path , i . socket ) ;
sockaddr . sun_family = AF_UNIX ;
if ( connect ( h . socket_fd , ( struct sockaddr * ) & sockaddr , sizeof ( sockaddr ) ) ) {
perror ( " connect " ) ;
goto error ;
}
return h ;
error :
if ( h . socket_fd > = 0 )
close ( h . socket_fd ) ;
h . socket_fd = - 1 ;
return h ;
}
daemon_reply daemon_send ( daemon_handle h , daemon_request rq )
{
2012-01-25 21:31:59 +00:00
daemon_reply reply = { . cft = NULL } ;
2011-06-14 02:34:18 +00:00
assert ( h . socket_fd > = 0 ) ;
if ( ! rq . buffer ) {
/* TODO: build the buffer from rq.cft */
}
assert ( rq . buffer ) ;
write_buffer ( h . socket_fd , rq . buffer , strlen ( rq . buffer ) ) ;
if ( read_buffer ( h . socket_fd , & reply . buffer ) ) {
2011-08-30 15:42:56 +00:00
reply . cft = dm_config_from_string ( reply . buffer ) ;
2011-06-14 02:34:18 +00:00
} else
reply . error = 1 ;
return reply ;
}
2011-06-27 13:58:11 +00:00
void daemon_reply_destroy ( daemon_reply r ) {
if ( r . cft )
2011-08-31 12:18:40 +00:00
dm_config_destroy ( r . cft ) ;
2011-06-27 13:58:11 +00:00
}
2012-01-15 15:16:50 +00:00
daemon_reply daemon_send_simple ( daemon_handle h , const char * id , . . . )
2011-06-27 13:14:53 +00:00
{
2011-09-17 14:49:18 +00:00
static const daemon_reply err = { . error = ENOMEM , . buffer = NULL , . cft = NULL } ;
2011-10-30 21:58:59 +00:00
daemon_request rq = { . cft = NULL } ;
2011-09-17 14:49:18 +00:00
daemon_reply repl ;
2011-06-27 13:14:53 +00:00
va_list ap ;
2011-09-17 14:49:18 +00:00
2011-06-27 13:14:53 +00:00
va_start ( ap , id ) ;
2011-09-17 14:49:18 +00:00
rq . buffer = format_buffer ( " request " , id , ap ) ;
va_end ( ap ) ;
2011-06-27 13:14:53 +00:00
2011-09-17 14:49:18 +00:00
if ( ! rq . buffer )
2011-06-27 13:14:53 +00:00
return err ;
2011-09-17 14:49:18 +00:00
repl = daemon_send ( h , rq ) ;
2011-06-27 13:14:53 +00:00
dm_free ( rq . buffer ) ;
return repl ;
}
void daemon_close ( daemon_handle h )
{
2011-06-14 02:34:18 +00:00
}