nscheck.in 1.72 KB
Newer Older
1
#!/usr/bin/perl -wT
Leigh B. Stoller's avatar
Leigh B. Stoller committed
2 3 4

#
# EMULAB-COPYRIGHT
5
# Copyright (c) 2000-2003 University of Utah and the Flux Group.
Leigh B. Stoller's avatar
Leigh B. Stoller committed
6 7 8
# All rights reserved.
#

9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27
use English;
use Getopt::Std;

#
# Syntax check an NS file.
#
# usage: nscheck <nsfile>
#
sub usage()
{
    print STDOUT "Usage: nscheck <nsfile>\n";
    exit(-1);
}
my  $optlist = "";

#
# Configure variables
#
my $TB       = "@prefix@";
28
my $parser   = "$TB/libexec/parse-ns";
29 30 31 32 33 34 35 36 37

#
# Turn off line buffering on output
#
$| = 1;

#
# Untaint the path
# 
38
$ENV{'PATH'} = "/bin:/usr/bin:/sbin:/usr/sbin";
39 40 41 42 43 44 45 46 47 48 49 50 51
delete @ENV{'IFS', 'CDPATH', 'ENV', 'BASH_ENV'};

#
# Parse command arguments. Once we return from getopts, all that should
# left are the required arguments.
#
%options = ();
if (! getopts($optlist, \%options)) {
    usage();
}
if (@ARGV != 1) {
    usage();
}
Leigh B. Stoller's avatar
Leigh B. Stoller committed
52
my ($tempfile) = @ARGV;
53 54 55 56 57 58 59 60

#
# Untaint the arguments.
#
# Note different taint check (allow /).
if ($tempfile =~ /^([-\@\w.\/]+)$/) {
    $tempfile = $1;
}
Leigh B. Stoller's avatar
Leigh B. Stoller committed
61

62 63 64 65 66 67 68 69 70 71 72 73 74 75 76
else {
    fatal("Tainted argument $tempfile");
}

$nsfile    = "foo.ns";

#
# Make a temp dir and copy the NS file into it. We run the scripts
# from that directory cause it writes temp files.
# 
$dirname = "/tmp/parse-$$";

mkdir($dirname, 0775) or
    fatal("Could not mkdir $dirname");

77
if (system("/bin/cp", "$tempfile", "$dirname/$nsfile")) {
78 79 80
    fatal("Could not copy $tempfile to $dirname");
}

81 82 83
chdir($dirname) or
    fatal("Could not chdir to $dirname");

Leigh B. Stoller's avatar
Leigh B. Stoller committed
84 85 86
# Run parse in impotent mode on the NS file.  This has no effect but
# will display any errors.

87
if (system("$parser -n -a $nsfile") != 0) {
88 89 90 91 92 93 94 95 96 97 98 99 100 101 102
    fatal("NS Parse failed!");
}

system("/bin/rm", "-rf", "$dirname");
exit 0;

sub fatal($)
{
    my($mesg) = $_[0];

    print STDOUT "$mesg\n";

    system("/bin/rm", "-rf", "$dirname");
    exit(-1);
}