Skip to content
Permalink
Branch: master
Find file Copy path
Find file Copy path
Fetching contributors…
Cannot retrieve contributors at this time
323 lines (292 sloc) 21.8 KB
<?php
if (!is_dir('temp')){mkdir('temp');file_put_contents('temp/index.html', '');}
// handle the post packing of files
if ($_POST&&count($_POST)>1){
set_time_limit (60);
$post=array_map("strip_tags",$_POST);
$filename='temp/'.$post['zipname'].'.zip';unset($post['zipname']);
$tozip=array();
foreach($post as $file){
$temp=file_curl_contents($file);
$basetempfilename='temp/'.basename($file);
$extension=pathinfo($file,PATHINFO_EXTENSION);
if (strtolower($extension)=='php'){str_ireplace('.php','.SECURED_PHP_FILE',$basetempfilename);}
file_put_contents($basetempfilename,$temp);
$tozip[]=$basetempfilename;
}
create_zip($tozip, $filename, true);
//once zip created, delete all temp files (avoid hacking use) except zip !
$temp=glob('temp/*.*');
foreach ($temp as $file){if (basename($file)!='index.html'&&basename($file)!=basename($filename)){unlink($file);}}
header('location: '.$filename);
}else{
// kill all remaining temp files (including zip)
$temp=glob('temp/*.*');
foreach ($temp as $file){if (basename($file)!='index.html'){unlink($file);}}
}
// INIT
$version='v1.5';
$me='http://'.$_SERVER['HTTP_HOST'].$_SERVER['PHP_SELF'];
$bookmarklet="<a class=\"btn\" href=\"javascript:javascript:(function(){var url = location.href;window.open('".$me."?p=' + encodeURIComponent(url)+'&ext=#ext','_blank','menubar=yes,height=600,width=1000,toolbar=yes,scrollbars=yes,status=yes');})();\" >#nom</a>";
$icon='';
$noise='';
$listextensions=array(
'all files'=>'jpg,jpeg,gif,png,svg,mp3,ogg,mp4,flv,swf,css,js,php,html,htm,shtml,pdf,doc,odt,xml,json,txt,ini,zip,gz,rar,7z,tar',
'images only'=>'jpg,jpeg,gif,png,svg',
'music only'=>'mp3,ogg',
'videos only'=>'mp4,flv',
'flash only'=>'swf',
'coding'=>'css,js,php,html,htm,shtml',
'documents'=>'pdf,doc,odt,xml,json,txt,ini',
'zip&co'=>'zip,gz,rar,7z,tar',
);
if (!empty($_GET['p'])){define('URL',strip_tags(urldecode($_GET['p'])));}else{define('URL','None');}
?>
<head>
<title>Tipiaking <?php echo URL;?></title>
<link rel="shortcut icon" href="<?php echo $icon;?>" />
<style>
*{box-sizing: border-box}
html,body{padding:0;margin:0;font-family: Palatino, Georgia, Helvetica, sans-serif;}
body{padding-top:100px;padding-bottom:70px;min-width:320px;min-height:320px;background:url('<?php echo $noise;?>') #eee;}
header{position:fixed;top:0;width:100%;vertical-align:middle;margin:0;padding:10px; font-size:24px;color:#fff; text-shadow:0 1px 2px black;background:url('<?php echo $noise;?>') rgba(0,0,0,0.5);box-shadow:0 1px 2px rgba(0,0,0,0.5);}
header img{vertical-align:middle;}
footer{position:fixed;bottom:0;margin:0;margin-top:10px;padding:10px;width:100%; font-size:20px;color:#fff; text-shadow:0 -1px 2px black;background:url('<?php echo $noise;?>') rgba(0,0,0,0.5);box-shadow:0 1px 2px rgba(0,0,0,0.5);}
footer a,header a{text-decoration:none;color:#bbd;padding-bottom:2px;}
header a:hover{border-bottom:2px dashed #cce;color:#cce;}
header form {display:inline-block;width:100%;}
header form a{font-size:24;font-style:normal;}
header form a:hover{text-decoration:none;}
header form input[type=text]{display:inline-block;width:50%;padding:2px;font-size:20px; border-radius: 3px;margin-left:10px;}
header form input[type=submit]{display:inline-block;width:50px;padding:2px;font-size:20px; border-radius: 3px;margin-left:10px;}
header form select{display:inline-block;padding:2px;font-size:20px; border-radius: 3px;margin-left:10px;}
h1{font-size:20;color:#888;text-shadow:0 1px 1px #fff;margin-left:20px;}
li{list-style:none;padding:5px;margin-left:20px;}
li:hover{background-color:#DDD;}
li label{border-radius:3px;cursor:pointer;padding:4px;}
input[type=checkbox]:checked+label{background-color:rgba(0,0,0,0.2);box-shadow:inset 0 1px 2px black;text-shadow:0 1px 1px white;}
li a {display:inline-block;text-decoration:none;text-shadow:0 1px 1px white;padding:3px;color:black;}
li a.button{width:64px;font-family:courier;text-align:center;border-radius:2px; border:1px solid rgba(0,0,0,0.2);background-color:#EEE;color:#555;box-shadow:0 1px 2px #444;}
li.css a{background-color:#9F0;color:#250;box-shadow:0 1px 2px #250;}
li.htm a,li.html a{background-color:#BF0;color:#450;box-shadow:0 1px 2px #450;}
li.swf a{background-color:violet;color:darkviolet;box-shadow:0 1px 2px darkviolet;}
li.php a{background-color:darkviolet;color:violet;box-shadow:0 1px 2px darkviolet;}
li.svg a{background-color:#aaa;color:#444;box-shadow:0 1px 2px #444;}
li.png a{background-color:#0f0;color:#050;box-shadow:0 1px 2px #050;}
li.gif a{background-color:#beb;color:#454;box-shadow:0 1px 2px #232;}
li.js a{background-color:#0FF;color:#099;text-shadow:0 1px 1px white;box-shadow:0 1px 2px #077;}
li.jpg a, li.jpeg a{background-color:#af0;color:#450;box-shadow:0 1px 2px #450;}
li.pdf a{background-color:darkred;color:red;box-shadow:0 1px 2px darkred;}
li.mp4 a,li.flv a{background-color:blue;color:lightblue;box-shadow:0 1px 2px black;}
li a.youtube {background-color:red;color:white;box-shadow:0 1px 2px maroon;text-shadow:0 0 1px pink;}
li.mp3 a,li.ogg a{background-color:orange;color:maroon;box-shadow:0 1px 2px maroon;}
li.zip a,li.rar a, li.tar a,li.gz a{background-color:#555;color:#eee;box-shadow:0 1px 2px black;}
li.xml a,li.txt a, li.ini a,li.json a{background-color:#aaa;color:#444;text-shadow:0 1px 1px white;box-shadow:0 1px 2px #333;}
.error{text-align:center;color:red;}
footer .btn,form input[type=submit] {
margin:1px;
background: #3498db;
background-image: linear-gradient(to bottom, #3498db, #2980b9);
-webkit-border-radius: 3;
-moz-border-radius: 3;
border-radius: 3px;
font-family: Arial;
color: #ffffff;
font-size: 14px;
padding: 3px 10px 3px 10px;
text-decoration: none;
box-shadow:0 1px 1px blue;
}
.btn:hover {
background: #3cb0fd;
background-image: linear-gradient(to bottom, #3cb0fd, #3498db);
text-decoration: none;
}
form input.tipiakselected{margin:auto;display:block;font-size:20px;}
hr{border: 1px solid #888;}
</style>
</head>
<body><header>
<form action="#" method="get"><img src="<?php echo $icon;?>"/> Tipiaking
<?php
if (URL!='None'){echo '<input value="'.URL.'" type="text" name="p"/>'.makeselect().'<input type="submit" value="GO!"/> <a title="Visit page..." href="'.URL.'"> &#9656;</a></form>'; }
else{echo '<input placeholder="Url to tipiak" type="text" name="p"/>'.makeselect().'<input type="submit" value="GO!"/>';}
?>
</form>
</header>
<?php
// prepare the extension regex ------------------------------------
if (!empty($_GET['ext'])){
$regex=strip_tags($_GET['ext']);
}else{
$regex=$listextensions['all files'];
}
$regex=explode(',',$regex);
$temp='';
foreach($regex as $r){$temp.='\.'.$r.'|';}
$temp=substr($temp,0,strlen($temp)-1);
$reg='#(?<=")([^\'"\?]+('.$temp.'))(?=["\?])|(?<=\')([^\'"\?]+('.$temp.'))(?=[\'\?])|(?<=url\()([^\'"\?]+('.$temp.'))(?=[\)])#i';
// -----------------------------------------------------------------
// functions -------------------------------------------------------
ini_set('allow_url_fopen', '1');
function aff($a,$stop=true,$line='?'){echo 'Arret a la ligne '.$line.' du fichier '.__FILE__.'<pre>';print_r($a);echo '</pre>';if ($stop){exit();}}
function makeselect(){
global $listextensions;
$temp= '<select name="ext">';
foreach ($listextensions as $nom=>$ext){
$temp.= '<option value="'.$ext.'">'.$nom.'</option>';
}
$temp.= '</select>';
return $temp;
}
function makebookmarklets(){
global $listextensions,$bookmarklet;
foreach ($listextensions as $nom=>$ext){
echo str_replace(array('#nom','#ext'),array($nom,$ext),$bookmarklet);
}
}
function remote_file_exists($url){if(@fclose(@fopen($url, 'r'))){return true;}else {return false;}}
function filterchars($string){return preg_replace('#([^a-zA-Z0-9-_\.]+)#','',$string);}
function file_curl_contents($url,$pretend=true){
$ch = curl_init();
curl_setopt($ch, CURLOPT_HTTPHEADER, array('Accept-Charset: UTF-8'));
curl_setopt($ch, CURLOPT_HEADER, 0);
curl_setopt($ch, CURLOPT_SSL_VERIFYPEER, FALSE);
curl_setopt($ch, CURLOPT_RETURNTRANSFER, 1);
curl_setopt($ch, CURLOPT_URL, $url);
if (!ini_get("safe_mode") && !ini_get('open_basedir') ) {curl_setopt($ch, CURLOPT_FOLLOWLOCATION, true);}
curl_setopt($ch, CURLOPT_MAXREDIRS, 10);
if ($pretend){curl_setopt($ch, CURLOPT_USERAGENT, 'Mozilla/5.0 (Windows NT 6.1; WOW64; rv:19.0) Gecko/20100101 Firefox/29.0');}
//curl_setopt($ch, CURLOPT_REFERER, random_referer());// notez le referer "custom"
$data = curl_exec($ch);
$response_headers = curl_getinfo($ch);
// Google seems to be sending ISO encoded page + htmlentities, why??
if($response_headers['content_type'] == 'text/html; charset=ISO-8859-1') $data = html_entity_decode(iconv('ISO-8859-1', 'UTF-8//TRANSLIT', $data));
curl_close($ch);
return $data;
}
function curl_get_file_size( $url ) {
$ch = curl_init($url);
curl_setopt($ch, CURLOPT_RETURNTRANSFER, TRUE);
curl_setopt($ch, CURLOPT_HEADER, TRUE);
curl_setopt($ch, CURLOPT_NOBODY, TRUE);
$data = curl_exec($ch);
$size = curl_getinfo($ch, CURLINFO_CONTENT_LENGTH_DOWNLOAD);
curl_close($ch);
if ($size!=-1){return $size;}else{return false;}
}
function get_video_infos($url=null){
// returns an array with all the youtube video's informations (available qualities/urls/format...)
if (!empty($url)){
if ($contenu=file_curl_contents($url)){
preg_match_all('#"url_encoded_fmt_stream_map": "(.*?)"#', $contenu, $resultats);
preg_match_all('#<title>(.*?)</title>#', $contenu, $title);
$c=0;
$p=array('title'=>$title[1][0]);
$params=explode('\u0026',$resultats[1][0]);
foreach ($params as $param){
$temp=explode('=',$param);
if (isset($p[$c][$temp[0]])){$c++;}
$p[$c][$temp[0]]=urldecode($temp[1]);
}
return $p;
}else{return false;}
}else{return false;}
}
function fuck_slashes($string){return preg_replace('#(?<=[^:])//#','/',stripslashes($string));}
function try_autocomplete_relatives_url($url){
if ($url!=''){
$url=fuck_slashes($url);
$data_url=parse_url($url);
if (!isset($data_url['path'])){return false;}
if (isset($data_url['scheme'])&&$data_url['scheme']!=''){
return $url;
}else{
extract(parse_url(URL));
$scheme=$scheme.'://';
if (substr($data_url['path'],0,1)!='/'){$data_url['path']='/'.$data_url['path'];}
return $scheme.$host.$data_url['path'];
}
}
return false;
}
function create_zip($files = array(),$destination = '',$overwrite = false) {
if(file_exists($destination) && !$overwrite) { return false; }
$valid_files = array();
if(is_array($files)) {
foreach($files as $file) {
if(file_exists($file)) {
$valid_files[] = $file;
}
}
}
if(count($valid_files)) {
$zip = new ZipArchive();
if($zip->open($destination,$overwrite ? ZIPARCHIVE::OVERWRITE : ZIPARCHIVE::CREATE) !== true) {
return false;
}
foreach($valid_files as $file) {
$zip->addFile($file,$file);
}
$zip->close();
return file_exists($destination);
}else{ return false; }
}
// -----------------------------------------------------------------
if (URL!='None'){
echo '<form action="#" method="POST" name="tipiak"><input type="hidden" name="zipname" value="'.filterchars(URL).'"/>';
if ($page=file_curl_contents(URL)){
if (stripos(URL,'www.youtube.com/watch?v=')!==false){
// GRAB YOUTUBE DIRECT VIDEOS LINKS
if ($info=get_video_infos(URL)){
$title=strip_tags($info['title']);
unset($info['title']);
echo'<h1>'.count($info).' versions available for this video. </h1>';
foreach($info as $key=>$video){
if ($length=curl_get_file_size($video['url'])){
$length= '( '.round(($length/1024),2).' ko)';
}else{$length='(no size)';}
if (empty($video['quality'])){$video['quality']='no quality given';}
if (empty($video['type'])){$video['type']='no type given';}
echo '<li><a class="youtube button" href="'.$video['url'].'" title="Download" download="'.$title.'">YTB</a> <a href="'.$video['url'].'" title="Download" download="'.$title.'">'.$title.' <em>'.$length.'</em> ('.strip_tags($video['quality']).' / '.strip_tags($video['type']).')</a></li>
';
}
}else{echo '<p class="error">no tipiakable data in this video link</p>';}
}else if (preg_match_all($reg,$page,$results)){
// GRAB PAGE CONTENT DATA
$results=array_unique($results[0]);
echo'<h1>'.count($results).' files tipiakable.<input type="button" onclick="selunselall(true)" value="&#10004;" title="select all"/><input type="button" onclick="selunselall(false)" value="&#10008;" title="unselect all"/></h1>';
foreach ($results as $key=>$val){
if ($val=try_autocomplete_relatives_url($val)){
//if (remote_file_exists($val)){
$extension=pathinfo($val,PATHINFO_EXTENSION);
if ($length=curl_get_file_size($val)){
$length= '( '.round(($length/1024),2).' ko)';
}else{$length='(no size)';}
if (!empty($extension)){
echo '<li class="'.$extension.'"><a class="button" href="'.$val.'" title="Download" download="'.strip_tags(basename($val)).'">'.$extension.'</a> - <input type="checkbox" name="file'.$key.'" id="file'.$key.'" value="'.$val.'"/><label title="select to make a zip" for="file'.$key.'">'.$val.' <em>'.$length.'</em></label></li>
';
}
//}
}
}
}else{echo '<p class="error">no tipiakable data</p>';}
}else{echo '<p class="error">no file access</p>';}
echo '<hr/><input class="tipiakselected" type="submit" value="Tipiak all selected"/></form>';
}else{echo '<p class="error">no URL to process...</p>';}
?>
<footer>
<span style="float:left">Bookmarklets: <?php makebookmarklets();?> </span>
<span style="float:right"><?php echo $version;?> Cod&#233;e &#224; la <em>va-comme-jte-pousse</em> par <a href="http://www.warriordudimanche.net/article217/tipiak-recuperer-les-ressources-d-une-page-web">Bronco</a></span>
<div style="clear:both"></div>
</footer>
<script>
function selunselall(trufal){
var checkboxes = new Array();
checkboxes = document['tipiak'].getElementsByTagName('input');
for (var i=0; i<checkboxes.length; i++) {
checkboxes[i].checked = trufal;
}
}
</script>
</body>
You can’t perform that action at this time.