Added 'scrub-*' commands for securely scrubbing filesystems.
[libguestfs.git] / daemon / scrub.c
1 /* libguestfs - the guestfsd daemon
2  * Copyright (C) 2009 Red Hat Inc. 
3  *
4  * This program is free software; you can redistribute it and/or modify
5  * it under the terms of the GNU General Public License as published by
6  * the Free Software Foundation; either version 2 of the License, or
7  * (at your option) any later version.
8  *
9  * This program is distributed in the hope that it will be useful,
10  * but WITHOUT ANY WARRANTY; without even the implied warranty of
11  * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
12  * GNU General Public License for more details.
13  *
14  * You should have received a copy of the GNU General Public License
15  * along with this program; if not, write to the Free Software
16  * Foundation, Inc., 675 Mass Ave, Cambridge, MA 02139, USA.
17  */
18
19 #include <config.h>
20
21 #include <stdio.h>
22 #include <stdlib.h>
23 #include <string.h>
24 #include <fcntl.h>
25 #include <unistd.h>
26
27 #include "daemon.h"
28 #include "actions.h"
29
30 int
31 do_scrub_device (char *device)
32 {
33   char *err;
34   int r;
35
36   IS_DEVICE (device, -1);
37
38   r = command (NULL, &err, "scrub", device, NULL);
39   if (r == -1) {
40     reply_with_error ("scrub_device: %s: %s", device, err);
41     free (err);
42     return -1;
43   }
44
45   free (err);
46
47   return 0;
48 }
49
50 int
51 do_scrub_file (char *file)
52 {
53   char *buf;
54   int len;
55   char *err;
56   int r;
57
58   NEED_ROOT (-1);
59   ABS_PATH (file, -1);
60
61   /* Make the path relative to /sysroot. */
62   len = strlen (file) + 9;
63   buf = malloc (len);
64   if (!buf) {
65     reply_with_perror ("malloc");
66     return -1;
67   }
68   snprintf (buf, len, "/sysroot%s", file);
69
70   r = command (NULL, &err, "scrub", "-r", buf, NULL);
71   free (buf);
72   if (r == -1) {
73     reply_with_error ("scrub_file: %s: %s", file, err);
74     free (err);
75     return -1;
76   }
77
78   free (err);
79
80   return 0;
81 }
82
83 int
84 do_scrub_freespace (char *dir)
85 {
86   char *buf;
87   int len;
88   char *err;
89   int r;
90
91   NEED_ROOT (-1);
92   ABS_PATH (dir, -1);
93
94   /* Make the path relative to /sysroot. */
95   len = strlen (dir) + 9;
96   buf = malloc (len);
97   if (!buf) {
98     reply_with_perror ("malloc");
99     return -1;
100   }
101   snprintf (buf, len, "/sysroot%s", dir);
102
103   r = command (NULL, &err, "scrub", "-X", buf, NULL);
104   free (buf);
105   if (r == -1) {
106     reply_with_error ("scrub_freespace: %s: %s", dir, err);
107     free (err);
108     return -1;
109   }
110
111   free (err);
112
113   return 0;
114 }