mirror of
https://github.com/libguestfs/libguestfs.git
synced 2026-03-21 22:53:37 +00:00
renamed daemon/tsk.c to daemon/sleuthkit.c
In order to support the new features I am renaming the file with a better name. The file sleuthkit.c will contain the code depending on the sleuthkit package. The original tsk.c file will contain the logic built using libtsk which is the sleuthkit core library. Signed-off-by: Matteo Cafasso <noxdafox@gmail.com>
This commit is contained in:
committed by
Pino Toscano
parent
c67bab9c5d
commit
88d5186eb4
114
daemon/sleuthkit.c
Normal file
114
daemon/sleuthkit.c
Normal file
@@ -0,0 +1,114 @@
|
||||
/* libguestfs - the guestfsd daemon
|
||||
* Copyright (C) 2016 Red Hat Inc.
|
||||
*
|
||||
* This program is free software; you can redistribute it and/or modify
|
||||
* it under the terms of the GNU General Public License as published by
|
||||
* the Free Software Foundation; either version 2 of the License, or
|
||||
* (at your option) any later version.
|
||||
*
|
||||
* This program is distributed in the hope that it will be useful,
|
||||
* but WITHOUT ANY WARRANTY; without even the implied warranty of
|
||||
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
|
||||
* GNU General Public License for more details.
|
||||
*
|
||||
* You should have received a copy of the GNU General Public License
|
||||
* along with this program; if not, write to the Free Software
|
||||
* Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA.
|
||||
*/
|
||||
|
||||
#include <config.h>
|
||||
|
||||
#include <stdio.h>
|
||||
#include <stdlib.h>
|
||||
#include <inttypes.h>
|
||||
#include <string.h>
|
||||
#include <unistd.h>
|
||||
|
||||
#include "guestfs_protocol.h"
|
||||
#include "daemon.h"
|
||||
#include "actions.h"
|
||||
#include "optgroups.h"
|
||||
|
||||
static int file_out (const char *cmd);
|
||||
|
||||
GUESTFSD_EXT_CMD(str_sleuthkit_probe, icat);
|
||||
|
||||
int
|
||||
optgroup_sleuthkit_available (void)
|
||||
{
|
||||
return prog_exists (str_sleuthkit_probe);
|
||||
}
|
||||
|
||||
int
|
||||
do_icat (const mountable_t *mountable, int64_t inode)
|
||||
{
|
||||
CLEANUP_FREE char *cmd = NULL;
|
||||
|
||||
/* Inode must be greater than 0 */
|
||||
if (inode < 0) {
|
||||
reply_with_error ("inode must be >= 0");
|
||||
return -1;
|
||||
}
|
||||
|
||||
/* Construct the command. */
|
||||
if (asprintf (&cmd, "icat -r %s %" PRIi64, mountable->device, inode) == -1) {
|
||||
reply_with_perror ("asprintf");
|
||||
return -1;
|
||||
}
|
||||
|
||||
return file_out (cmd);
|
||||
}
|
||||
|
||||
static int
|
||||
file_out (const char *cmd)
|
||||
{
|
||||
int r;
|
||||
FILE *fp;
|
||||
CLEANUP_FREE char *buffer = NULL;
|
||||
|
||||
if (verbose)
|
||||
fprintf (stderr, "%s\n", cmd);
|
||||
|
||||
buffer = malloc (GUESTFS_MAX_CHUNK_SIZE);
|
||||
if (buffer == NULL) {
|
||||
reply_with_perror ("malloc");
|
||||
return -1;
|
||||
}
|
||||
|
||||
fp = popen (cmd, "r");
|
||||
if (fp == NULL) {
|
||||
reply_with_perror ("%s", cmd);
|
||||
return -1;
|
||||
}
|
||||
|
||||
/* Now we must send the reply message, before the file contents. After
|
||||
* this there is no opportunity in the protocol to send any error
|
||||
* message back. Instead we can only cancel the transfer.
|
||||
*/
|
||||
reply (NULL, NULL);
|
||||
|
||||
while ((r = fread (buffer, 1, sizeof buffer, fp)) > 0) {
|
||||
if (send_file_write (buffer, r) < 0) {
|
||||
pclose (fp);
|
||||
return -1;
|
||||
}
|
||||
}
|
||||
|
||||
if (ferror (fp)) {
|
||||
fprintf (stderr, "fread: %m");
|
||||
send_file_end (1); /* Cancel. */
|
||||
pclose (fp);
|
||||
return -1;
|
||||
}
|
||||
|
||||
if (pclose (fp) != 0) {
|
||||
fprintf (stderr, "pclose: %m");
|
||||
send_file_end (1); /* Cancel. */
|
||||
return -1;
|
||||
}
|
||||
|
||||
if (send_file_end (0)) /* Normal end of file. */
|
||||
return -1;
|
||||
|
||||
return 0;
|
||||
}
|
||||
Reference in New Issue
Block a user