=================================================================== RCS file: /cvs/openbsd/OpenBSDTorrents/MakeTorrents.pl,v retrieving revision 1.4 retrieving revision 1.10 diff -u -r1.4 -r1.10 --- openbsd/OpenBSDTorrents/MakeTorrents.pl 2005/03/22 23:45:10 1.4 +++ openbsd/OpenBSDTorrents/MakeTorrents.pl 2005/04/06 23:56:50 1.10 @@ -1,9 +1,11 @@ #!/usr/bin/perl -T -#$Id: MakeTorrents.pl,v 1.4 2005/03/22 23:45:10 andrew Exp $ +#$Id: MakeTorrents.pl,v 1.10 2005/04/06 22:56:50 andrew Exp $ use strict; use warnings; use diagnostics; +use BT::MetaInfo; + use lib 'lib'; use OpenBSDTorrents; @@ -11,13 +13,10 @@ use YAML; -my $BTMake = '/usr/local/bin/btmake'; -my $MinFiles = 5; - -my $StartDir = shift || $BaseName; +my $StartDir = shift || $OBT->{BASENAME}; $StartDir =~ s#/$##; -chdir($BaseDir) || die "Couldn't change dir to $BaseDir"; +chdir($OBT->{DIR_FTP}) || die "Couldn't change dir to " . $OBT->{DIR_FTP} . ": $!"; Process_Dir($StartDir); @@ -31,7 +30,7 @@ } # don't recurse if we were called on a specific directory - return 1 if $StartDir ne $BaseName; + return 1 if $StartDir ne $OBT->{BASENAME}; foreach my $subdir (@$dirs) { next if $subdir eq '.'; @@ -45,7 +44,7 @@ my $basedir = shift; my $files = shift; - if ($#{ $files } < $MinFiles) { + if ($#{ $files } < $OBT->{MIN_FILES}) { print "Too few files in $basedir, skipping . . .\n"; return undef; } @@ -72,15 +71,62 @@ "Created by andrew fresh (andrew\@mad-techies.org)\n" . "http://OpenBSD.somedomain.net/"; - system($BTMake, - '-C', - '-c', $comment, - '-n', $BaseName, - '-o', "$TorrentDir/$torrent", - '-a', $Tracker, - @$files - );# || die "Couldn't system $BTMake $torrent: $!"; + eval { btmake($torrent, $comment, $files); }; + if ($@) { + print "Error creating $torrent\n"; + } +# system($BTMake, +# '-C', +# '-c', $comment, +# '-n', $OBT->{BASENAME}, +# '-o', $OBT->{DIR_TORRENT} . "/$torrent", +# '-a', $Tracker, +# @$files +# );# || die "Couldn't system $BTMake $torrent: $!"; + return $torrent; +} + + +# Stole and modified from btmake to work for this. +sub btmake { + no locale; + + my $torrent = shift; + my $comment = shift; + my $files = shift; + + my $name = $OBT->{BASENAME}; + my $announce = $OBT->{URL_TRACKER}; + my $piece_len = 2 << ($OBT->{PIECE_LENGTH} - 1); + + $torrent = $OBT->{DIR_TORRENT} . "/$torrent"; + + my $t = BT::MetaInfo->new(); + $t->name($name); + $t->announce($announce); + unless ($announce =~ m!^http://[^/]+/!i) { + warn " [ WARNING: announce URL does not look like: http://hostname/ ]\n"; + } + $t->comment($comment); + #foreach my $pair (split(/;/, $::opt_f)) { + # if (my($key, $val) = split(/,/, $pair, 2)) { + # $t->set($key, $val); + # } + #} + $t->piece_length($piece_len); + $t->creation_date(time); + print "Checksumming files. This may take a little while...\n"; + $t->set_files(@$files); + + if ($t->total_size < $OBT->{MIN_SIZE}) { + print "Skipping smaller than minimum size\n"; + return 0; + } + + $t->save("$torrent"); + print "Created: $torrent\n"; + #system("btinfo $torrent") if ($::opt_I); }