Compare commits

...

4 Commits

Author SHA1 Message Date
Pin
ac70e240c8 format 2024-03-02 23:50:20 -05:00
Pin
991ffb5224 Merge branch 'dev' of https://git.robbyzambito.me/robby/guestfs-inspect into dev 2024-03-02 23:35:01 -05:00
15322a601b Add command union and name of the disk to be associated with. 2024-03-02 23:29:39 -05:00
6ca7727ee8 Add initial header file
This will be used in the client and the daemon
2024-03-02 23:29:39 -05:00
2 changed files with 102 additions and 66 deletions

View File

@@ -5,9 +5,11 @@
#include <zactor.h> #include <zactor.h>
#include <guestfs.h> #include <guestfs.h>
#include "libguestfs-inspect.h"
#define STREQ(a, b) (strcmp((a), (b)) == 0) #define STREQ(a, b) (strcmp((a), (b)) == 0)
static void *worker_task(char*); static void *worker_task(zsock_t*, char*);
char *endpoint(void); char *endpoint(void);
@@ -34,7 +36,7 @@ static int count_mountpoints(char *const *argv) {
return c; return c;
} }
static void *worker_task(char *disk_path) { static void *worker_task(zsock_t *pipe, char *disk_path) {
guestfs_h *g; guestfs_h *g;
char **roots, **mountpoints; char **roots, **mountpoints;
char *root; char *root;
@@ -50,9 +52,7 @@ static void *worker_task(char *disk_path) {
} }
// Adding disk_path to connection handle // Adding disk_path to connection handle
if (guestfs_add_drive_opts(g, disk_path, if (guestfs_add_drive_opts(g, disk_path, GUESTFS_ADD_DRIVE_OPTS_READONLY, 1, -1) == -1) {
GUESTFS_ADD_DRIVE_OPTS_READONLY, 1,
-1) == -1) {
exit(EXIT_FAILURE); exit(EXIT_FAILURE);
} }
@@ -86,8 +86,21 @@ static void *worker_task(char *disk_path) {
} }
// ZeroMQ Opens here // ZeroMQ Opens here
for (;;) { zsock_signal(pipe, 0);
while (true) {
zmsg_t *message = zmsg_recv(pipe);
if (message == NULL) {
break;
}
// Process message
// do something here
// Sending reply
zmsg_t *reply = zmsg_new();
zmsg_addstr(reply, "Reply from worker");
zmsg_send(&reply, pipe);
zmsg_destroy(&message);
} }
/*if (guestfs_is_file_opts(g, file_path, GUESTFS_IS_FILE_OPTS_FOLLOWSYMLINKS, 1, -1) > 0) { /*if (guestfs_is_file_opts(g, file_path, GUESTFS_IS_FILE_OPTS_FOLLOWSYMLINKS, 1, -1) > 0) {
printf("--- %s ---\n", file_path); printf("--- %s ---\n", file_path);

View File

@@ -0,0 +1,23 @@
enum guestfs_inspect_command {
GUESTFS_COMMAND_LS,
/* GUESTFS_COMMAND_TOUCH, */
/* GUESTFS_COMMAND_MKDIR, */
GUESTFS_COMMAND_CAT
};
struct guestfs_ls_args {
size_t path_length;
char path[];
};
struct guestfs_cat_args {};
struct guestfs_inpsect_command {
enum guestfs_inspect_command command;
union {
struct guestfs_ls_args ls;
struct guestfs_cat_args cat;
} args;
size_t name_length;
char name[];
};