diff --git a/.gitignore b/.gitignore
index b60d9a3..f0bf8f0 100644
--- a/.gitignore
+++ b/.gitignore
@@ -3,3 +3,4 @@
obj/
.clangd
.depend
+http/f/*
diff --git a/http/index.css b/http/public/index.css
similarity index 100%
rename from http/index.css
rename to http/public/index.css
diff --git a/http/saki.png b/http/public/saki.png
similarity index 100%
rename from http/saki.png
rename to http/public/saki.png
diff --git a/http/upload.cgi b/http/upload.cgi
index 83e13bc..ce2ca9e 100755
--- a/http/upload.cgi
+++ b/http/upload.cgi
@@ -1,108 +1,78 @@
#!/usr/bin/perl
# This file is part of sakisafe.
-# sakisafe is free software: you can redistribute it and/or modify
-# it under the terms of the GNU General Public License as published by
-# the Free Software Foundation, either version 3 of the License, or
-# (at your option) any later version.
+use Mojolicious::Lite -signatures;
+use Mojolicious::Routes::Pattern;
+plugin 'RenderFile';
+my $MAX_SIZE = 1024 * 1024 * 100;
-# sakisafe is distributed in the hope that it will be useful,
-# but WITHOUT ANY WARRANTY; without even the implied warranty of
-# MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
-# GNU General Public License for more details.
+get '/' => 'index';
-# You should have received a copy of the GNU General Public License
-# along with sakisafe. If not, see .
+get '/f/:dir/:name' => sub ($c) {
+ my $captures = $c->req->url;
+ $captures =~ s/^.//;
+ my $filerender = Mojolicious::Plugin::RenderFile->new;
+ $c->render_file( filepath => $captures );
+};
-use CGI;
-use CGI::Carp qw(fatalsToBrowser);
+app->max_request_size( 1024 * 1024 * 100 );
+my $dirname;
+post '/upload' => sub ($c) {
+ my $filedata = $c->param("file");
+ if ( $filedata->size > $MAX_SIZE ) {
+ return $c->render(
+ text => "Max upload size: $MAX_SIZE",
+ status => 400
+ );
+ }
+
+ # Generate random string for the directory
+ my @chars = ( '0' .. '9', 'a' .. 'Z' );
+ $dirname .= $chars[ rand @chars ] for 1 .. 5;
-my $q = CGI->new;
+ mkdir( "f/" . $dirname );
+ $filedata->move_to( "f/" . $dirname . "/" . $filedata->filename );
+ my $host = $c->req->url->to_abs->host;
+ $c->res->headers->header(
+ 'Location' => "http://$host/$dirname/" . $filedata->filename );
+ $c->render(
+ text => "Uploaded to http://$host/f/$dirname/" . $filedata->filename,
+ status => 201,
+ );
+ $dirname = "";
-my $filename = $q->param('file');
-my $url = $q->param('url');
+};
-my $upload_dir = "files/";
+app->start;
-$size = $ENV{CONTENT_LENGTH};
+__DATA__
-# Configuration
+@@ index.html.ep
-our $MAX_SIZE = 1024*1024*100; # Change for your size
-our $MAX_SIZE_MB = $MAX_SIZE / 1024 / 1024; # Don't change this
-
-our @not_allowed_extensions = qw(sh out exe);
-
-print $q->header();
-
-# do something better
-if ($url ne "") {
- goto url_shorter;
-}
-
-if ($filename eq "" || $ENV{REQUEST_METHOD} eq "GET") {
- print("What are you looking for?");
- exit;
-}
-
-if ($filename) {
- if ($size > $MAX_SIZE) {
- print("Max size for a file is $MAX_SIZE_MB MBs");
- exit;
- }
-
-
- my @chars = ("A"..."z","a"..."z");
- my $dirname;
- my $extension = $filename;
-
- $dirname .= $chars[rand @chars] for 1..8;
- $extension =~ s/.*\.//;
- $filename .= ".notcgi" if $extension eq "cgi";
-
- mkdir("$upload_dir/$dirname");
- my $upload_filehandle = $q->upload("file");
-
- # onion urls will be http
- my $prot = length $ENV{HTTPS} ? "https" : "http";
-
- my $allowed_extension = 1;
-
- foreach (@not_allowed_extensions) {
- if ($filename =~ /\.$_$/i) {
- $allowed_extension = 0;
- last;
- }
-
- }
- if ($filename eq "-") {
- $filename .= ".txt"; # for pastes
- }
- if ($allowed_extension) {
-
- open(FILE,">$upload_dir/$dirname/$filename");
- binmode(FILE);
- while (<$upload_filehandle>) {
- print FILE;
- }
- close FILE;
- $filename =~ s/ /%20/g;
-
- print $prot. "://" . $ENV{HTTP_HOST} . "/$upload_dir$dirname/$filename" . "\n";
- } else {
- print "The file extension .$extension is not allowed in this instance.";
- }
- exit;
-} elsif ($url != "" && !$filename) {
- url_shorter:
- my $template = "";
- my @chars = ("A"..."z","a"..."z",1..9);
- my $dirname;
- $dirname .= $chars[rand @chars] for 1..4;
- mkdir($dirname);
- open(my $fh, ">$dirname/index.html");
- print $fh $template;
- my $prot = length $ENV{HTTPS} ? "https" : "http";
- print $prot. "://" . $ENV{HTTP_HOST} . "/$dirname" . "\n";
- exit;
-}
+
+
+
+ sakisafe
+
+
+
+
+ sakisafe
+ shitless file upload, pastebin and url shorter
+
+ USAGE
+ POST a file:
+ curl -F 'file=@yourfile.png' $SITE_URL
+ Shorten URL:
+ curl -F 'url=https://example.org' $SITE_URL
+ Post your text directly
+ curl -F 'file=@-' $SITE_URL
+
+
Or just upload a file here
+
+
+
+