~azzar1/unity/add-show-desktop-key

« back to all changes in this revision

Viewing changes to bin/timount/timount.c

  • Committer: Matt Giuca
  • Date: 2010-07-22 02:12:36 UTC
  • mfrom: (1812.1.13 late-submit)
  • Revision ID: matt.giuca@gmail.com-20100722021236-k8kt4cqdtywzpk24
Merge from trunk late-submit.
Students may now submit projects after the deadline, but they are warned that the submission is late.
Lecturers are now given data on which submissions were made late, and how many days.
(LP: #598346)

Show diffs side-by-side

added added

removed removed

Lines of Context:
 
1
/* IVLE - Informatics Virtual Learning Environment
 
2
 * Copyright (C) 2008 The University of Melbourne
 
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., 51 Franklin St, Fifth Floor, Boston, MA  02110-1301  USA
 
17
 *
 
18
 * Program: Timount
 
19
 * Author:  William Grant
 
20
 * Date:    05/07/2008
 
21
 *
 
22
 * Timount ('timeout mounts') cleans up mounts after a period of inactivity.
 
23
 * It looks in the given directory of mountpoints, and attempts to unmount each
 
24
 * with the MNT_EXPIRE flag. This flag is reset whenever a process accesses
 
25
 * the mountpoint, meaning that a mountpoint will be unmounted only if it is
 
26
 * inactive for the interval between two timount invocations.
 
27
 *
 
28
 * It is unclear how frequently timount should optimally be run. Empirical data
 
29
 * specific to the installation will likely be required.
 
30
 *
 
31
 * Usage: timount <path>
 
32
 * Must run as root, and probably from cron.
 
33
 */
 
34
 
 
35
#include <stdio.h>
 
36
#include <stdlib.h>
 
37
#include <string.h>
 
38
#include <errno.h>
 
39
#include <dirent.h>
 
40
#include <syslog.h>
 
41
#include <sys/mount.h>
 
42
 
 
43
#ifndef MNT_EXPIRE
 
44
/* For some reason this isn't defined in libc at the moment. */
 
45
#define MNT_EXPIRE 4
 
46
#endif
 
47
 
 
48
void usage(const char *prog)
 
49
{
 
50
    fprintf(stderr, "usage: %s <path>\n", prog);
 
51
    exit(1);
 
52
}
 
53
 
 
54
int main(int argc, const char *argv[])
 
55
{
 
56
    DIR *rootdir;
 
57
    struct dirent *mp;
 
58
    char *dirname;
 
59
 
 
60
    if (argc != 2)
 
61
        usage(argv[0]);
 
62
 
 
63
    openlog("timount", LOG_CONS | LOG_PID, LOG_USER);
 
64
 
 
65
    if (!(rootdir = opendir(argv[1])))
 
66
    {
 
67
        perror("could not open specified path");
 
68
        exit(1);
 
69
    }
 
70
 
 
71
    while ((mp = readdir(rootdir)))
 
72
    {
 
73
        dirname = malloc(strlen(argv[1]) + strlen(mp->d_name) + 2);
 
74
        sprintf(dirname, "%s/%s", argv[1], mp->d_name);
 
75
        if (mp->d_name[0] != '.' && mp->d_name[0] != '_')
 
76
        {
 
77
            if (umount2(dirname, MNT_EXPIRE))
 
78
            {
 
79
                /* We failed to unmount, but did it set the expire flag? */
 
80
                if (errno == EAGAIN)
 
81
                    syslog(LOG_INFO, "marked %s for expiry\n", mp->d_name);
 
82
            }
 
83
            else
 
84
            {
 
85
                syslog(LOG_INFO, "unmounted %s\n", mp->d_name);
 
86
            }
 
87
        }
 
88
        free(dirname);
 
89
    }
 
90
 
 
91
    closedir(rootdir);
 
92
    closelog();
 
93
    return 0;
 
94
}