comparison ctd.pl @ 0:72ce01e2dad9 draft default tip

Uploaded tool tarball.
author devteam
date Tue, 20 Aug 2013 09:36:33 -0400
parents
children
comparison
equal deleted inserted replaced
-1:000000000000 0:72ce01e2dad9
1 #!/usr/bin/perl -w
2 use strict;
3 use LWP::UserAgent;
4 require HTTP::Cookies;
5
6 #######################################################
7 # ctd.pl
8 # Submit a batch query to CTD and fetch results into galaxy history
9 # usage: ctd.pl inFile idCol inputType resultType actionType outFile
10 #######################################################
11
12 if (!@ARGV or scalar @ARGV != 6) {
13 print "usage: ctd.pl inFile idCol inputType resultType actionType outFile\n";
14 exit;
15 }
16
17 my $in = shift @ARGV;
18 my $col = shift @ARGV;
19 if ($col < 1) {
20 print "The column number is with a 1 start\n";
21 exit 1;
22 }
23 my $type = shift @ARGV;
24 my $resType = shift @ARGV;
25 my $actType = shift @ARGV;
26 my $out = shift @ARGV;
27
28 my @data;
29 open(FH, $in) or die "Couldn't open $in, $!\n";
30 while (<FH>) {
31 chomp;
32 my @f = split(/\t/);
33 if (scalar @f < $col) {
34 print "ERROR the requested column is not in the file $col\n";
35 exit 1;
36 }
37 push(@data, $f[$col-1]);
38 }
39 close FH or die "Couldn't close $in, $!\n";
40
41 my $url = 'http://ctdbase.org/tools/batchQuery.go';
42 #my $url = 'http://ctd.mdibl.org/tools/batchQuery.go';
43 my $d = join("\n", @data);
44 #list maintains order, where hash doesn't
45 #order matters at ctd
46 #to use input file (gives error can't find file)
47 #my @form = ('inputType', $type, 'inputTerms', '', 'report', $resType,
48 #'queryFile', [$in, ''], 'queryFileColumn', $col, 'format', 'tsv', 'action', 'Submit');
49 my @form = ('inputType', $type, 'inputTerms', $d, 'report', $resType,
50 'queryFile', '', 'format', 'tsv', 'action', 'Submit');
51 if ($resType eq 'cgixns') { #only add if this type
52 push(@form, 'actionTypes', $actType);
53 }
54 if ($resType eq 'go' or $resType eq 'go_enriched') {
55 push(@form, 'ontology', 'go_bp', 'ontology', 'go_mf', 'ontology', 'go_cc');
56 }
57 my $ua = LWP::UserAgent->new;
58 $ua->cookie_jar(HTTP::Cookies->new( () ));
59 $ua->agent('Mozilla/5.0');
60 my $page = $ua->post($url, \@form, 'Content_Type'=>'form-data');
61 if ($page->is_success) {
62 open(FH, ">", $out) or die "Couldn't open $out, $!\n";
63 print FH "#";
64 print FH $page->content, "\n";
65 close FH or die "Couldn't close $out, $!\n";
66 }else {
67 print "ERROR failed to get page from CTD, ", $page->status_line, "\n";
68 print $page->content, "\n";
69 my $req = $page->request();
70 print "Requested \n";
71 foreach my $k(keys %$req) {
72 if ($k eq '_headers') {
73 my $t = $req->{$k};
74 foreach my $k2 (keys %$t) { print "$k2 => $t->{$k2}\n"; }
75 }else { print "$k => $req->{$k}\n"; }
76 }
77 exit 1;
78 }
79 exit;
80