Add Makefile.PL and allow banned IP's to be derived from a file (#21)
* added perl makefile * fixup gitignore and eval
This commit is contained in:
parent
9af44501cc
commit
deb4318cd9
3 changed files with 34 additions and 6 deletions
11
.gitignore
vendored
11
.gitignore
vendored
|
@ -4,3 +4,14 @@ obj/
|
||||||
.clangd
|
.clangd
|
||||||
.depend
|
.depend
|
||||||
http/f/*
|
http/f/*
|
||||||
|
blib/
|
||||||
|
pm_to_blib
|
||||||
|
Makefile
|
||||||
|
Makefile.old
|
||||||
|
MANIFEST*
|
||||||
|
!MANIFEST.SKIP
|
||||||
|
META.*/
|
||||||
|
MYMETA.*
|
||||||
|
pm_to_blib
|
||||||
|
sakisafe.log
|
||||||
|
f/
|
||||||
|
|
17
http/Makefile.PL
Normal file
17
http/Makefile.PL
Normal file
|
@ -0,0 +1,17 @@
|
||||||
|
use v5.36;
|
||||||
|
|
||||||
|
use ExtUtils::MakeMaker;
|
||||||
|
|
||||||
|
WriteMakefile(
|
||||||
|
NAME => 'sakisafe',
|
||||||
|
PREREQ_PM => {
|
||||||
|
"Mojolicious" => 0,
|
||||||
|
"List::MoreUtils" => 0,
|
||||||
|
"Term::ANSIColor" => 0,
|
||||||
|
"MIME::Types" => 0,
|
||||||
|
"Path::Tiny" => 0,
|
||||||
|
"Mojolicious::Plugin::RenderFile" => 0,
|
||||||
|
"Mojolicious::Routes::Pattern" => 0
|
||||||
|
},
|
||||||
|
EXE_FILES => ['sakisafe.pl']
|
||||||
|
);
|
|
@ -9,21 +9,20 @@ use Carp;
|
||||||
use Term::ANSIColor;
|
use Term::ANSIColor;
|
||||||
use English;
|
use English;
|
||||||
use MIME::Types;
|
use MIME::Types;
|
||||||
|
use Path::Tiny;
|
||||||
use warnings;
|
use warnings;
|
||||||
use experimental 'signatures';
|
use experimental 'signatures';
|
||||||
use feature 'say';
|
use feature 'say';
|
||||||
plugin 'RenderFile';
|
plugin 'RenderFile';
|
||||||
|
|
||||||
# OpenBSD promises.
|
# OpenBSD promises.
|
||||||
my $openbsd = 0;
|
pledge("stdio cpath rpath wpath inet flock fattr") if $^O eq "openbsd";
|
||||||
$openbsd = 1 if $^O eq "openbsd";
|
|
||||||
pledge("stdio cpath rpath wpath inet flock fattr") if $openbsd;
|
|
||||||
|
|
||||||
# 100 MBs
|
# 100 MBs
|
||||||
|
|
||||||
my $MAX_SIZE = 1024 * 1024 * 100;
|
my $MAX_SIZE = 1024 * 1024 * 100;
|
||||||
|
|
||||||
my @BANNED = qw(); # Add banned IP addresses here
|
my @BANNED = eval { path('banned.txt')->slurp_utf8 } or qw(); # Add banned IP addresses here
|
||||||
my $dirname;
|
my $dirname;
|
||||||
my $link;
|
my $link;
|
||||||
|
|
||||||
|
@ -46,6 +45,7 @@ sub handle_file {
|
||||||
status => 400
|
status => 400
|
||||||
);
|
);
|
||||||
}
|
}
|
||||||
|
|
||||||
if ( List::MoreUtils::any { /$c->tx->remote_address/ } uniq @BANNED ) {
|
if ( List::MoreUtils::any { /$c->tx->remote_address/ } uniq @BANNED ) {
|
||||||
$c->render(
|
$c->render(
|
||||||
text =>
|
text =>
|
||||||
|
@ -119,8 +119,8 @@ get '/f/:dir/#name' => sub ($c) {
|
||||||
content_disposition => 'inline'
|
content_disposition => 'inline'
|
||||||
);
|
);
|
||||||
|
|
||||||
}
|
};
|
||||||
;
|
|
||||||
app->max_request_size( 1024 * 1024 * 100 );
|
app->max_request_size( 1024 * 1024 * 100 );
|
||||||
|
|
||||||
post '/upload' => sub ($c) { handle_file($c) };
|
post '/upload' => sub ($c) { handle_file($c) };
|
||||||
|
|
Loading…
Add table
Reference in a new issue