-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathindex.php
103 lines (82 loc) · 2.58 KB
/
index.php
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.1//EN" "http://www.w3.org/TR/xhtml11/DTD/xhtml11.dtd">
<html xmlns="http://www.w3.org/1999/xhtml" xml:lang="en">
<head>
<title>Librebin</title>
<meta content="text/html; charset=utf-8" http-equiv="content-type" />
<meta name="viewport" content="width=device-width, initial-scale=1.0" />
<meta name="referrer" content="no-referrer" />
<link rel="stylesheet" type="text/css" href="static/styles.css" />
</head>
<body>
<h1>Librebin</h1>
<a href="https://github.com/hnhx/librebin">Source & Instances</a>
<a href="./index.php">Upload</a>
<?php
require("config.php");
$content = NULL;
if (isset($_REQUEST["p"]))
$content = file_get_contents("p/" . $_REQUEST["p"]);
?>
<form method="POST" action="index.php">
<textarea name="content" cols="80" rows="20" minlength="15" <?php echo (!empty($content) ? "readonly=\"on\"" : ""); ?> maxlength="1048576" placeholder="Paste in your stuff here! (max 1048576 chars)"><?php echo (!empty($content) ? $content : ""); ?></textarea>
<?php
if (empty($content))
{
echo "<br/>";
echo "<br/>";
echo "<img src=\"captcha.php\" alt=\"captcha\" />";
echo "<input name=\"captcha\" type=\"text\" maxlength=\"5\" placeholder=\"Captcha...\" />";
echo "<br/>";
echo "<button type=\"submit\">Upload</button>";
}
else
{
echo "<br />";
echo "<br />";
echo "<a href=\"p/" . $_REQUEST["p"] . "\">Raw text</a>";
}
?>
</form>
<?php
function random_string()
{
$chars = array_merge(range("A", "Z"), range("a", "z"), range(1, 9));
$random_str = "";
for($i=0; random_int(6,9)>$i; $i++)
$random_str .= $chars[random_int(0, count($chars)-1)];
return $random_str;
}
if (!isset($_REQUEST["content"]))
die();
session_start();
$valid_upload = true;
$content = htmlspecialchars(trim($_REQUEST["content"]));
if (empty($_SESSION["captcha"]) || $_SESSION["captcha"] != strtoupper($_REQUEST["captcha"]))
{
if (!in_array($_REQUEST["api_key"], $api_keys))
{
$valid_upload = false;
echo "<p>Invalid captcha!</p>";
}
}
$content_len = strlen($content);
if ($content_len > 1048576 || 15 > $content_len)
{
$valid_upload = false;
echo "<p>Content must be between 15 and 1048576 chars!</p>";
}
if ($valid_upload)
{
if (!file_exists("p"))
mkdir("p");
$file_name = NULL;
do
{
$file_name = random_string();
} while (file_exists("p/" . $file_name));
file_put_contents("p/" . $file_name, $content);
header("Location: index.php?p=" . $file_name);
}
?>
</body>
</html>