]> git.pld-linux.org Git - projects/distfiles.git/blob - request-handler.pl
(Temporarily) support both scp and ftp
[projects/distfiles.git] / request-handler.pl
1 #!/usr/bin/perl -w
2 # read email with request from stdin and process it
3
4 use Sys::Syslog;
5
6 openlog("distfiles-rh", "pid", "user"); 
7
8 $spool_dir = "./spool";
9 $commits_list = "pld-cvs-commit\@lists.pld-linux.org";
10
11 $spec = undef;
12 $branch = "";
13 $from = undef;
14 $flags = "";
15
16 # ---------------------------------------------------------------
17 use File::Basename;
18 use File::Copy;
19 use Cwd;
20
21 sub cleanup()
22 {
23   system("rm -rf tmp/$id");
24 }
25
26 sub report_fatal($)
27 {
28   my $msg = shift;
29
30   syslog("err","FATAL: $msg");
31   cleanup();
32   open(M, "| /usr/sbin/sendmail -t") or die("/usr/sbin/sendmail not found");
33   #open(M, "| cat") or die;
34   my $version = '$Id$';
35   print M <<EOF
36 From: $from <$from\@pld-linux.org>
37 To: $commits_list
38 Cc: $from\@pld-linux.org
39 Message-ID: <$id\@distfiles.pld-linux.org>
40 Subject: DISTFILES: ERROR fetching sources for $spec ($branch)
41 X-distfiles-program: request-handler.pl
42 X-distfiles-version: $version
43
44 $msg
45
46 -- 
47 Virtually Yours: distfiles.
48 EOF
49 ;
50   close(M) or die("problem while sending email");
51   exit 0;
52 }
53 # ---------------------------------------------------------------
54
55 $id = `uuidgen`;
56 chomp $id;
57 $id = rand if (!defined $id or $id eq "");
58
59 my $ref_pattern='[0-9a-zA-Z][0-9#a-zA-Z._\@/+ :,-]*';
60 while (<STDIN>) {
61   chomp;
62   /^X-Package: ([a-z0-9_.+-]+)/i and $spec = $1;
63   /^X-Branch: ($ref_pattern)/i and $branch = $1;
64   /^X-Login: ([a-z0-9_.]+)/i and $from = $1;
65   /^X-Flags: ([a-z0-9_ -]+)/i and $flags = $1;
66 }
67
68 if (!defined $from) {
69    syslog("err","FATAL: ill-formed request");
70    die "ill-formed request";
71 }
72
73 syslog("info","got request from $from for $spec at $branch ($flags)");
74
75 report_fatal("bad spec name") if (!defined $spec);
76
77 $oldcwd = Cwd::getcwd();
78
79 mkdir("tmp/$id") or die("cannot create: tmp/$id");
80 chdir("tmp/$id");
81
82 my $cvs_get = `~/distfiles/show_spec.sh $spec $branch 2>&1`;
83 if ( $? ) {
84   chdir($oldcwd);
85   my $at_branch = "";
86   $at_branch = " from branch $branch" if $branch;
87   my $code = $? >> 8;
88   report_fatal("cannot git fetch $spec$at_branch;\n$cvs_get\nexited with code $code");
89 }
90
91 chdir($oldcwd);
92
93 syslog("info","spooling to tmp/$id/to-spool");
94 open(S, "> tmp/$id/to-spool");
95 print S "$from\@pld-linux.org\n";
96 print S "$spec\n";
97 print S "$flags\n";
98 close(S);
99
100 if (system("perl ./specparser.pl \"tmp/$id/$spec\" tmp/$id/sources >> tmp/$id/to-spool") != 0) {
101   report_fatal("cannot parse $spec ($branch)")
102 }
103
104 if (!File::Copy::move("tmp/$id/to-spool", "$spool_dir/$id")) {
105   syslog("err","FATAL: move failed: $!");
106   die("move failed: $!");
107 }
108
109 cleanup();
110
111 exit(0);
112
113 # vim: ts=2:sw=2:et
This page took 0.039558 seconds and 3 git commands to generate.