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
104
105
106
107
108
109
110
111
112
113
|
<div style="margin-top: 100px; text-align:center">
<?php echo form_open_multipart('file/do_upload'); ?>
<p>
File: <input type="file" id="file" name="file" size="30" />
<input type="submit" value="Upload" id="upload_button" name="process" /><br />
Optional password (for deletion and search): <input type="password" name="password" size="10" />
</p>
</form>
<script type="text/javascript">
/* <![CDATA[ */
// check file size before uploading if browser support html5
if (window.File && window.FileList) {
function checkFileUpload(evt) {
var f = evt.target.files[0]; // FileList object
if (f.size > <?php echo $max_upload_size; ?>) {
document.getElementById('upload_button').value = "File too big";
document.getElementById('upload_button').disabled = true;
} else {
document.getElementById('upload_button').value = "Upload";
document.getElementById('upload_button').disabled = false;
}
}
document.getElementById('file').addEventListener('change', checkFileUpload, false);
}
function encode64(inp){
var key="ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz0123456789+/=";
var chr1,chr2,chr3,enc3,enc4,i=0,out="";
while(i<inp.length){
chr1=inp.charCodeAt(i++);if(chr1>127) chr1=88;
chr2=inp.charCodeAt(i++);if(chr2>127) chr2=88;
chr3=inp.charCodeAt(i++);if(chr3>127) chr3=88;
if(isNaN(chr3)) {enc4=64;chr3=0;} else enc4=chr3&63
if(isNaN(chr2)) {enc3=64;chr2=0;} else enc3=((chr2<<2)|(chr3>>6))&63
out+=key.charAt((chr1>>2)&63)+key.charAt(((chr1<<4)|(chr2>>4))&63)+key.charAt(enc3)+key.charAt(enc4);
}
return encodeURIComponent(out);
}
function gen_boundary() {
var chars = "0123456789ABCDEFGHIJKLMNOPQRSTUVWXTZabcdefghiklmnopqrstuvwxyz";
var string_length = 40;
var randomstring = '';
for (var i=0; i<string_length; i++) {
var rnum = Math.floor(Math.random() * chars.length);
randomstring += chars.substring(rnum,rnum+1);
}
return randomstring;
}
function do_paste() {
var http = new XMLHttpRequest();
var url = "<?php echo site_url("file/do_upload/dumb"); ?>";
var CRLF = "\r\n";
var boundary = "--" + gen_boundary();
var body = "--" + boundary + CRLF
+ 'Content-Disposition: form-data; name="file"; filename="stdin"' + CRLF
+ "Content-Type: text/plain" + CRLF
+ CRLF
+ document.getElementById("textarea").value + CRLF
+ "--" + boundary + "--" + CRLF + CRLF;
http.open("POST", url, true);
//Send the proper header information along with the request
http.setRequestHeader("Content-type", "multipart/form-data; boundary=" + boundary);
http.setRequestHeader("Authorization", "Basic " + encode64(":" + document.getElementById("textarea_password").value));
http.onreadystatechange = function() {//Call a function when the state changes.
if(http.readyState == 4 && http.status == 200) {
window.location = http.responseText;
}
}
http.send(body);
}
document.write('\
<p><b>OR</b></p>\
<form action="javascript: do_paste()">\
<p>\
<textarea id="textarea" name="content" cols="80" rows="20"></textarea><br />\
<div style="display: none">Email: <input type="text" name="email" size="20" /></div>\
Optional password (for deletion and search): <input id="textarea_password" type="password" name="password" size="10" /><br />\
<input type="submit" value="Paste" name="process" />\
</p>\
</form>\
');
/* ]]> */
</script>
</div>
<br />
<p>Uploads/pastes are deleted after <?php echo $upload_max_age; ?> days<?php if($small_upload_size > 0): ?>
unless they are smaller than <?php echo format_bytes($small_upload_size); ?>
<?php endif; ?>. Maximum upload size is <?php echo format_bytes($max_upload_size); ?></p>
<p><h2>Features</h2></p>
<p>For shell uploading/pasting and download information for the client go to <a href="<?php echo site_url("file/client"); ?>"><?php echo site_url("file/client"); ?></a></p>
<p>You can use the <?php echo anchor("file/upload_history", "history"); ?> to find old uploads using the password supplied when creating the upload.</p>
<p>How to link your pastes:</p>
<ul>
<li><span class="example">/<ID>/</span> automatically highlight the paste</li>
<li><span class="example">/<ID></span> set the detected MIME type and let the browser do the rest</li>
<li><span class="example">/<ID>/plain</span> force the MIME type to be text/plain</li>
<li><span class="example">/<ID>/<file extension></span> override auto detection and use the supplied file extension or language name for highlighting</li>
<li><span class="example">/<ID>/qr</span> display a qr code containing a link to <span class="example">/<ID>/</span></li>
<li><span class="example">/<ID>/rmd</span> convert markdown to HTML</li>
<li><span class="example">/<ID>/ascii</span> convert text with ANSI (shell) escape codes to HTML</li>
</ul>
<p>If your upload is not detected as text, only <span class="example">/<ID>/qr</span> will work as above and all others will simply return the file with the detected MIME type.</p>
<br />
<?php if($contact_me_url) {?><p>If you experience any problems feel free to <a href="<?php echo $contact_me_url; ?>">contact me</a>.</p>
<br /><?php }; ?>
<div class="small">
<p>This service is provided without warranty of any kind and may not be used to distribute copyrighted content.</p>
</div>
|