chiark / gitweb /
Seems to do correct POST ...
authorIan Jackson <ian@liberator.(none)>
Wed, 10 Jun 2009 17:39:06 +0000 (18:39 +0100)
committerIan Jackson <ian@liberator.(none)>
Wed, 10 Jun 2009 17:39:06 +0000 (18:39 +0100)
pctb/yppsc-commod-processor

index 0f25452..01db528 100755 (executable)
@@ -219,7 +219,7 @@ sub main__tsv () {
 
 our (%commodmap);
 our ($pctb) = 'http://pctb.ilk.org/';
-our ($ua);
+our ($ua)= LWP::UserAgent->new;
 
 sub load_commodmap() {
     undef %commodmap;
@@ -234,7 +234,6 @@ sub load_commodmap() {
 }
 
 sub refresh_commodmap() {
-    my $ua= LWP::UserAgent->new;
     my $resp= $ua->get("$pctb/commodmap.php?version=2");
     die $resp->status_line unless $resp->is_success;
 
@@ -331,7 +330,7 @@ sub bs_gen_md ($$) {
 
 sub writeint { return pack 'v*', @_; }
 
-sub main__genmarketdata () {
+sub genmarketdata () {
     our $version= '005b';
 
     load_commodmap();
@@ -348,22 +347,37 @@ sub main__genmarketdata () {
            if $missing;
     }    
 
-    my $o='';
-    $o .= bs_gen_md(Buy, -1);
-    $o .= bs_gen_md(Sell,+1);
-
-    printf("$version\n".
-          "%d\n",
-          scalar(@stallmap))
-       or die $!;
-    foreach $stall (@stallmap) { print "$stall\n" or die $!; }
+    my $ob='';
+    $ob .= bs_gen_md(Buy, -1);
+    $ob .= bs_gen_md(Sell,+1);
 
-    print $o or die$!;
+    my $ot= sprintf("$version\n".
+                   "%d\n",
+                   scalar(@stallmap));
+    foreach $stall (@stallmap) { $ot .= "$stall\n"; }
+    return $ot.$ob;
 }
 
+sub main__genmarketdata () {
+    my $o= genmarketdata();
+    print $o or die $!;
+}
 
 sub main__upload () {
-    die "\nUploading not yet implemented, sorry.\n";
+    my $o= genmarketdata();
+    my $url= "$pctb/upload.php";
+    $url= "http://www.chiark.greenend.org.uk/ucgi/~ijackson/check/upload.php";
+    my $content= {
+       'marketdata' => [ undef, "marketdata.gz",
+                         Content_Type => 'application/gzip',
+                         Content => $o
+                         ]
+                     };
+    my $resp= $ua->post("$url", Content => $content,
+                       Content_Type => 'form-data');
+    die $resp->status_line unless $resp->is_success;
+
+    print "[[ ",$resp->content," ]]\n";
 }