daemon: Use gnulib futimens module.
[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 #include "optgroups.h"
30
31 int
32 optgroup_scrub_available (void)
33 {
34   int r = access ("/usr/bin/scrub", X_OK);
35   return r == 0;
36 }
37
38 int
39 do_scrub_device (const char *device)
40 {
41   char *err;
42   int r;
43
44   r = command (NULL, &err, "scrub", device, NULL);
45   if (r == -1) {
46     reply_with_error ("scrub_device: %s: %s", device, err);
47     free (err);
48     return -1;
49   }
50
51   free (err);
52
53   return 0;
54 }
55
56 int
57 do_scrub_file (const char *file)
58 {
59   char *buf;
60   char *err;
61   int r;
62
63   /* Make the path relative to /sysroot. */
64   buf = sysroot_path (file);
65   if (!buf) {
66     reply_with_perror ("malloc");
67     return -1;
68   }
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 (const char *dir)
85 {
86   char *buf;
87   char *err;
88   int r;
89
90   /* Make the path relative to /sysroot. */
91   buf = sysroot_path (dir);
92   if (!buf) {
93     reply_with_perror ("malloc");
94     return -1;
95   }
96
97   r = command (NULL, &err, "scrub", "-X", buf, NULL);
98   free (buf);
99   if (r == -1) {
100     reply_with_error ("scrub_freespace: %s: %s", dir, err);
101     free (err);
102     return -1;
103   }
104
105   free (err);
106
107   return 0;
108 }