<?php
if (isset($_GET['public'])){$public=true;}else{$public=false;include 'auto_restrict.php';}

/* (webpage retriever by Timo Van Neerden; http://lehollandaisvolant.net/contact December 2012)
 * last updated : December, 10th, 2012
 *
 * This piece of software is under the WTF Public Licence. 
 * Everyone is permitted to copy and distribute verbatim or modified 
 * copies of this program, under the following terms of the WFTPL :
 *
 *            DO WHAT THE FUCK YOU WANT TO PUBLIC LICENSE 
 *   TERMS AND CONDITIONS FOR COPYING, DISTRIBUTION AND MODIFICATION 
 *
 *  0. You just DO WHAT THE FUCK YOU WANT TO.
 *
 */

/* all the enhancements (logo, css, session lock, bookmarklet) are from Bronco (www.warriordudimanche.net) 
* and are based on the same licence ;)
* thanks a lot to Timo for his great job on this app ;) */

// PHP 5.1.2 minimum required

error_reporting(-1);
date_default_timezone_set('UTC');
// CONFIGURABLE OPTIONS
// change those directories'names for more security
$GLOBALS['data_folder'] = 'mypersonaldata'; 
$GLOBALS['private_data_folder'] = $GLOBALS['data_folder'].'/private';
$GLOBALS['public_data_folder'] =  $GLOBALS['data_folder'].'/public';
$GLOBALS['default_data_folder'] =  $GLOBALS['public_data_folder'];
$GLOBAL['version']='1.0';
$GLOBALS['message'] = 'Votre webliothèque perso';
$GLOBALS['public_title'] = 'Voici la webliothèque publique de Bronco';
$bookmarklet='<a title="Drag this link to your shortcut bar" href=\'javascript:javascript:(function(){var url = location.href;window.open("http://'.$_SERVER['SERVER_NAME'].$_SERVER['PHP_SELF'].'?q="+ encodeURIComponent(url),"_blank","menubar=yes,height=600,width=1000,toolbar=yes,scrollbars=yes,status=yes");})();\' >Bookmarklet</a>';
$column_width='width:47%';
if ($public){$bookmarklet='';$column_width='width:97%';}
if (!creer_dossier($GLOBALS['data_folder'], TRUE)) { die('Cant create '.$GLOBALS['data_folder'].' folder.'); }
if (!creer_dossier($GLOBALS['data_folder'].'/zipversions', TRUE)) { die('Cant create '.$GLOBALS['data_folder'].'/zipversions'.' folder.'); }
if (!creer_dossier($GLOBALS['private_data_folder'], TRUE)) { die('Cant create '.$GLOBALS['private_data_folder'].' folder.'); }
if (!creer_dossier($GLOBALS['public_data_folder'], TRUE)) { die('Cant create '.$GLOBALS['public_data_folder'].' folder.'); }

//
// BEGIN SCRIPT
//

#TODO
/*
- remplacer les liens relatifs par les liens absolus (ne chercher que les liens relatifs, uri)
- gestion des pages DL (classement ?)
- gestion de la taille max des fichiers à télélcharger 


*/

// init
// url not yet retrieved
$GLOBALS['done']['d'] = FALSE;

if (!$public){
	// Get URL to save.
	if (!empty($_GET['q'])) {


		$url = htmlspecialchars($_GET['q']);
		if (strpos($url, '://') === false) {
			$url = 'http://'.$url;
		}
		$GLOBALS['url'] = $url;
		$url_p = url_parts();

		// retrieve the file main HTML file

		$GLOBALS['main_page_data'] = get_external_file($GLOBALS['url'], 6);


		if ($GLOBALS['main_page_data'] === FALSE) {
			die('error retrieving external main page');
		}

		else {
			// crée le nouveau dossier basé sur le TS.
			$new_folder = date('Y-m-d-H-i-s');
			if (!creer_dossier($GLOBALS['default_data_folder'].'/'.$new_folder) === TRUE ) {
				die('error creating data folder');
			}
			else {
				$GLOBALS['target_folder'] = $GLOBALS['default_data_folder'].'/'.$new_folder;
			}
			$liste_css = array();
			// parse le fichier principal à la recherche de données à télécharger
			$files = list_retrievable_data($GLOBALS['url'], $GLOBALS['main_page_data']);
			// les récupère et les enregistre.
			//echo '<pre>';print_r($files);die();
			foreach ($files as $i => $file) {
				if ($data = get_external_file($file['url_fichier'], 3) and ($data !== FALSE) ) {
					// CSS files need to be parsed aswell
					if ($file['type'] == 'css') {
						$liste_css[] = $file;
					}
					else {
						file_put_contents($GLOBALS['target_folder'].'/'.$file['nom_destination'], $data);
					}
				}
			}
			// remplace juste les liens <a href=""> relatifs vers des liens absolus
			absolutes_links($GLOBALS['main_page_data']);

			// enregistre le fichier HTML principal
			file_put_contents($GLOBALS['target_folder'].'/'.'index.html', $GLOBALS['main_page_data']);

			// récupère le titre de la page
			// cherche le charset spécifié dans le code HTML.
			// récupère la balise méta tout entière, dans $meta
			preg_match('#<meta .*charset=.*>#Usi', $GLOBALS['main_page_data'], $meta);

			// si la balise a été trouvée, on tente d’isoler l’encodage.
			if (!empty($meta[0])) {
				// récupère juste l’encodage utilisé, dans $enc
				preg_match('#charset="?(.*)"#si', $meta[0], $enc);
				// regarde si le charset a été trouvé, sinon le fixe à UTF-8
				$html_charset = (!empty($enc[1])) ? strtolower($enc[1]) : 'utf-8';
			} else { $html_charset = 'utf-8'; }
			// récupère le titre, dans le tableau $titles, rempli par preg_match()
			preg_match('#<title>(.*)</title>#Usi', $GLOBALS['main_page_data'], $titles);
			if (!empty($titles[1])) {
				$html_title = trim($titles[1]);
				// ré-encode le titre en UTF-8 en fonction de son encodage.
				$title = ($html_charset == 'iso-8859-1') ? utf8_encode($html_title) : $html_title;
			// si pas de titre : on utilise l’URL.
			} else {
				$title = $url;
			}


			// récupère, parse, modifie & enregistre les fichier CSS (et les fichiés liés)
			$n = 0;
			$count = count($liste_css);
			while ( $n < $count and $n <300) { // no more than 300 ext files.
				$i = $n;
				$file = $liste_css[$i];
				if ($data = get_external_file($file['url_fichier'], 3) and ($data !== FALSE) ) {
					if (preg_match('#(css|php|txt|html|xml|js)#', $file['url_fichier']) ) {
						$matches_url = array();
						preg_match_all('#url\s{0,}\(("|\')?([^\'")]{1,})(\'|")?\)#i', $data, $matches_url, PREG_SET_ORDER);
						$matches_url2 = array();
						preg_match_all("#@import\s*(?:\"([^\">]*)\"?|'([^'>]*)'?)([^;]*)(;|$)#i", $data, $matches_url2, PREG_SET_ORDER);


						$matches_url = array_merge($matches_url2, $matches_url);
				

						// pour chaque URL/URI
						foreach ($matches_url as $j => $valuej) {

							if (preg_match('#^data:#', $matches_url[$j][2])) break; // if BASE64 data, dont download.

							// get the filenam (basename)
							$nom_fichier = (preg_match('#^(ht|f)tps?://#', $matches_url[$j][2])) ? pathinfo(parse_url($matches_url[$j][2], PHP_URL_PATH), PATHINFO_BASENAME) : pathinfo($matches_url[$j][2], PATHINFO_BASENAME);

							// get the URL. For URIs, uses the GLOBALS[url] tu make the URL
							// the files in CSS are relative to the CSS !
							if (preg_match('#^https?://#', $matches_url[$j][2])) {
								$url_fichier = $matches_url[$j][2];
							}
							// abs url w/o protocole
							elseif (preg_match('#^//#', $matches_url[$j][2])) {
								$url_fichier = $url_p['s'].':'.$matches_url[$j][2];
							}
							// rel url
							elseif (preg_match('#^/#', $matches_url[$j][2])) {
								$url_fichier = $url_p['s'].'://'.$url_p['h'].$matches_url[$j][2];
							}

							else {
								$endstr = ($w = strpos($file['url_fichier'], '?')) ? $w : strlen($file['url_fichier']);
								$url_fichier = substr(substr($file['url_fichier'], 0, $endstr), 0, -strlen($file['nom_fich_origine'])).$matches_url[$j][2];
							}
							// new rand name, for local storage.
							$nouveau_nom = rand_new_name($nom_fichier);
							//echo '<pre>'.$nouveau_nom."\n";
							$add = TRUE;

							// avoids downloading the same file twice. (yes, we re-use the same $retrievable ($files), why not ?)
							foreach ($files as $key => $item) {
								if ($item['url_fichier'] == $url_fichier) {
									$nouveau_nom = $item['nom_destination'];
									$add = FALSE;
									break;
								}
							}

							// if we do download, add it to the array.
							if ($add === TRUE) {
								$files_n = array(
									'url_origine' => $matches_url[$j][2],
									'url_fichier' => $url_fichier,
									'nom_fich_origine' => $nom_fichier,
									'nom_destination' => $nouveau_nom
									);
								$files[] = $files_n;
								$liste_css[] = $files_n;
							}

							// replace url in CSS $data
							$data = str_replace($matches_url[$j][2], $nouveau_nom, $data);
							// echo $nouveau_nom."<br>\n";

							if (!preg_match('#(css|php|txt|html)#', $file['url_fichier']) ) {
								if (FALSE !== ($f = get_external_file($url_fichier, 3)) ) {
									file_put_contents($GLOBALS['target_folder'].'/'.$nouveau_nom, $f);
								}
							}
						}
					}

					// don't forget to save data
					file_put_contents($GLOBALS['target_folder'].'/'.$file['nom_destination'], $data);
				}
				$n++;
				$count = count($liste_css);
			}
			// enregistre un fichier d’informations concernant la page (date, url, titre)
			$info  = '';
			$info .= 'URL="'.$GLOBALS['url'].'"'."\n";
			$info .= 'TITLE="'.$title.'"'."\n";
			$info .= 'DATE="'.time().'"'."\n";
			file_put_contents($GLOBALS['target_folder'].'/'.'index.ini', $info);
			$GLOBALS['done']['d'] = 'ajout';			
			$GLOBALS['done']['lien'] = $GLOBALS['target_folder'].'/';			
		}

	}//die;


	// in case of delete an entry
	if (isset($_GET['suppr']) and $torem = $_GET['suppr'] and $torem != '') {
		$torem = htmlspecialchars($_GET['suppr']);
		if (is_dir($_GET['suppr'])){
			$sousliste = scandir($_GET['suppr']); // listage des dossiers de data.
			$nb_sousfichier = count($sousliste);
			for ($j = 0 ; $j < $nb_sousfichier ; $j++) {
				if (!($sousliste[$j] == '..' or $sousliste[$j] == '.')) {
					unlink($_GET['suppr'].'/'.$sousliste[$j]);
				}
			}
			// then the folder itself.
	        if (TRUE === rmdir($_GET['suppr'])) {
					$GLOBALS['done']['d'] = 'remove';			

			}
	    }
	    
	    header("location: index.php");
	}

	// to private
	if (isset($_GET['toprivate']) and $torem = $_GET['toprivate'] and $torem != '') {
		$torem = htmlspecialchars($_GET['toprivate']);
		if (is_dir($GLOBALS['public_data_folder'].'/'.$_GET['toprivate'])){
			rename ($GLOBALS['public_data_folder'].'/'.$_GET['toprivate'],$GLOBALS['private_data_folder'].'/'.$_GET['toprivate']);
			header("location: index.php");
		}
	}
	// to public
	if (isset($_GET['topublic']) and $torem = $_GET['topublic'] and $torem != '') {
		$torem = htmlspecialchars($_GET['topublic']);
		if (is_dir($GLOBALS['private_data_folder'].'/'.$_GET['topublic'])){
			rename ($GLOBALS['private_data_folder'].'/'.$_GET['topublic'],$GLOBALS['public_data_folder'].'/'.$_GET['topublic']);
			header("location: index.php");
		}
	}

	if (isset($_GET['zipprivate'])) {

		$zip_filename=$GLOBALS['data_folder'].'/zipversions/'.$_GET['zipprivate'].'.zip';
		
		if (is_file($zip_filename)){header("location: $zip_filename");exit();}
		if (is_dir($GLOBALS['private_data_folder'].'/'.$_GET['zipprivate'])){
			include 'zip.php';
			zip($_GET['zipprivate'].'.zip',$GLOBALS['private_data_folder'].'/'.$_GET['zipprivate'],$GLOBALS['data_folder'].'/zipversions/');
			header("location: $zip_filename");
		}
	}
}
	// public get 
	//download public zip version
	if (isset($_GET['zippublic'])) {

		$zip_filename=$GLOBALS['data_folder'].'/zipversions/'.$_GET['zippublic'].'.zip';	
		if (is_file($zip_filename)){header("location: $zip_filename");exit();}
		if (is_dir($GLOBALS['public_data_folder'].'/'.$_GET['zippublic'])){
			include 'zip.php';

			rename ($GLOBALS['public_data_folder'].'/'.$_GET['zippublic'],$_GET['zippublic']); // on le déplace pour éviter de voir la structure de dossiers apparaître dans le zip
			zip($_GET['zippublic'].'.zip',$_GET['zippublic'],$GLOBALS['data_folder'].'/zipversions/');
			rename ($_GET['zippublic'],$GLOBALS['public_data_folder'].'/'.$_GET['zippublic']); // on le remet à sa place
			header("location: $zip_filename");
		}
	}



function url_parts() {
	$url_p['s']    = parse_url($GLOBALS['url'], PHP_URL_SCHEME); $url_p['s']   = (is_null($url_p['s'])) ? '' : $url_p['s'];
	$url_p['h']    = parse_url($GLOBALS['url'], PHP_URL_HOST);   $url_p['h']   = (is_null($url_p['h'])) ? '' : $url_p['h'];
	$url_p['p']    = parse_url($GLOBALS['url'], PHP_URL_PORT);   $url_p['p']   = (is_null($url_p['p'])) ? '' : ':'.$url_p['p'];
	$url_p['pat']  = parse_url($GLOBALS['url'], PHP_URL_PATH);   $url_p['pat'] = (is_null($url_p['pat'])) ? '' : $url_p['pat'];
	$url_p['file'] = pathinfo($url_p['pat'], PATHINFO_BASENAME);
	return $url_p;
}

//
// Gets external file by URL. 
// Make a stream context (better).
//

function get_external_file($url, $timeout) {
	$context = stream_context_create(array('http'=>array('timeout' => $timeout))); // Timeout : time until we stop waiting for the response.
	$data = @file_get_contents($url, false, $context, -1, 4000000); // We download at most 4 Mb from source.
	if (isset($data) and isset($http_response_header) and isset($http_response_header[0]) and (strpos($http_response_header[0], '200 OK') !== FALSE) ) {
		return $data;
	}
	else {
		return FALSE;
	}
}

//
// CREATE FOLDER
//

function creer_dossier($dossier, $indexfile = FALSE) {
	if ( !is_dir($dossier) ) {
		if (mkdir($dossier, 0777, TRUE) === TRUE) {
			chmod($dossier, 0777);
			if ($indexfile == TRUE) touch($dossier.'/index.html'); // make a index.html file : avoid the possibility of listing folder's content
			return TRUE;
		} else {
			return FALSE;
		}
	}
	return TRUE; // if folder already exists
}


//
// PARSE TAGS AND LISTE DOWNLOADABLE CONTENT IN ARRAY
// Also modify html source code to replace absolutes URLs with local URIs.
//

function list_retrievable_data($url, &$data) {
	$url_p = url_parts();

	$retrievable = array();

	// cherche les balises 'link' qui contiennent  un rel="(icon|favicon|stylesheet)" et un href=""
	// (on ne cherche pas uniquement le "href" sinon on se retrouve avec les flux RSS aussi)
	$matches = array();
	preg_match_all('#<\s*link[^>]+rel=["\'][^"\']*(icon|favicon|stylesheet)[^"\']*["\'][^>]*>#Si', $data, $matches, PREG_SET_ORDER);
	// dans les link avec une icone, stylesheet, etc récupère l’url.
	foreach($matches as $i => $key) {
		$type =  (strpos($key[1], 'stylesheet') !== FALSE) ? 'css' : 'other';
		if ( (preg_match_all('#(href|src)=["\']([^"\']*)["\']#i', $matches[$i][0], $matches_attr, PREG_SET_ORDER) === 1) ) {
			$retrievable = add_table_and_replace($data, $retrievable, $matches[$i][0], $matches_attr[0][2], $url_p, $type);
		}
	}

	// recherche les images, scripts, audio & videos HTML5.
	// dans les balises, récupère l’url/uri contenue dans les src="".
	// le fichier sera téléchargé.
	// Le nom du fichier sera modifié pour être unique, et sera aussi modifié dans le code source.
	$matches = array();
	preg_match_all('#<\s*(source|audio|img|script|video)[^>]+src="([^"]*)"[^>]*>#Si', $data, $matches, PREG_SET_ORDER);

	foreach($matches as $i => $key) {
		if (preg_match('#^data:#', $matches[$i][2])) break;
		$retrievable = add_table_and_replace($data, $retrievable, $matches[$i][0], $matches[$i][2], $url_p, 'other');
	}

	// Dans les balises <style>, remplace les url() et src()
	$matches = array();
	preg_match_all('#<\s*style[^>]*>(.*?)<\s*/\s*style[^>]*>#is', $data, $matches, PREG_SET_ORDER);

	// pour chaque élement <style>
	foreach($matches as $i => $value) {
		$matches_url = array();
		preg_match_all('#url\s*\(("|\')?([^\'")]*)(\'|")?\)#i', $matches[$i][1], $matches_url, PREG_SET_ORDER);
		$matches_url2 = array();
		preg_match_all("#@import\s*(\"([^\">]*)\"?|'([^'>]*)'?)([^;]*)(;|$)#i", $matches[$i][1], $matches_url2, PREG_SET_ORDER);
		$matches_url = array_merge($matches_url2, $matches_url);
		//echo '<pre>';print_r($matches_url);die;

		// pour chaque URL/URI
		foreach ($matches_url as $j => $valuej) {
			if (preg_match('#^data:#', $matches_url[$j][2])) break;
			$retrievable = add_table_and_replace($data, $retrievable, $matches[$i][1], $matches_url[$j][2], $url_p, 'other');
		}
	}

	// recherche les url dans les CSS inlines.
	$matches = array();
	// pour chaque élement contenant un style=""
	preg_match_all('#<\s*[^>]+style="([^"]*url\s*\(([^)]*)\)[^"]*)"[^>]*>+#is', $data, $matches, PREG_SET_ORDER);
	foreach($matches as $i => $value) {
		$matches_url = array();

		// pour chaque URL/URI trouvé
		preg_match_all('#url\s*\(("|\')?([^\'")]*)(\'|")?\)#i', $matches[$i][1], $matches_url, PREG_SET_ORDER);

		foreach ($matches_url as $j => $valuej) {
			if (preg_match('#^data:#', $matches_url[$j][2])) break; // if BASE64 data, dont download.
			$retrievable = add_table_and_replace($data, $retrievable, $matches[$i][1], $matches_url[$j][2], $url_p, 'other');
		}
	}
	return $retrievable;
}

function absolutes_links(&$data) {
	$url_p = url_parts();
	// cherche les balises 'a' qui contiennent un href
	$matches = array();
	preg_match_all('#<\s*a[^>]+href=["\'](([^"\']*))["\'][^>]*>#Si', $data, $matches, PREG_SET_ORDER);

	// ne conserve que les liens ne commençant pas par un protocole « protocole:// » ni par une ancre « # »
	foreach($matches as $i => $link) {
		$link[1] = trim($link[1]);
		if (!preg_match('#^(([a-z]+://)|(\#))#', $link[1]) ) {
			$matches[$i][1] = complete_url($link[1]);
			$new_match = str_replace($matches[$i][2], $matches[$i][1], $matches[$i][0]);
			$data = str_replace($matches[$i][0], $new_match, $data);
		}
	}
}

function complete_url($url) {
	$home_p = url_parts();

	$url = trim($url);
	if ($url === '') {
		return '';
	}
//	echo $url."\n\n\n";

	$hash_pos = strrpos($url, '#');
	$fragment = $hash_pos !== false ? '#' . substr($url, $hash_pos) : '';
	$sep_pos  = strpos($url, '://');

	if ($sep_pos === false || $sep_pos > 5) {
		switch ($url{0}) {
			// absolute path w/o HTTP and relatives paths
			case '/':
				$url = substr($url, 0, 2) === '//' ? $home_p['s'] . ':' . $url : $home_p['s'] . '://' . $home_p['h'] . $url;
				break;
			// php query string
			case '?':
				$url = $home_p['h'] . '/' . $home_p['file'] . $url;
				break;
			// html # particule
			case '#':
			// magnet & mailto
			case 'm':
			// javascript
			case 'j':
				break;
			default:
				$url = $home_p['h'] . '/' . $url;
				break;
		}
	}
//	echo $url."\n\n\n";
	return $url;
}

function add_table_and_replace(&$data, $retrievable, &$match1, $match, $url_p, $type) {
	// get the filenam (basename)
	$nom_fichier = (preg_match('#^https?://#', $match)) ? pathinfo(parse_url($match, PHP_URL_PATH), PATHINFO_BASENAME) : pathinfo($match, PATHINFO_BASENAME);
	// get the URL. For relatives URL, uses the GLOBALS[url] tu make the complete URL
	// the files in CSS are relative to the CSS !
	if (preg_match('#^https?://#', $match)) { // url
		$url_fichier = $match;
	}
	elseif (preg_match('#^//#', $match)) { // absolute path w/o HTTP
		$url_fichier = $url_p['s'].':'.$match;
	}
	elseif (preg_match('#^/#', $match)) { // absolute local path
		$url_fichier = $url_p['s'].'://'.$url_p['h'].$match;
	}
	else { // relative local path
		$uuu = (strlen($url_p['file']) == 0 or preg_match('#/$#', $url_p['pat'])) ? $GLOBALS['url'] : substr($GLOBALS['url'], 0, -strlen($url_p['file'])) ;
		$url_fichier = $uuu . substr($match, 0, -strlen($nom_fichier)).$nom_fichier;
	}

	$url_fichier = html_entity_decode(urldecode($url_fichier));
	// new rand name, for local storage.
	$nouveau_nom = rand_new_name($nom_fichier);
	if ($type == 'css') {
		$nouveau_nom = $nouveau_nom.'.css';
	}
	$add = TRUE;

	// avoids downloading the same file twice.
	foreach ($retrievable as $key => $item) {
		if ($item['url_fichier'] == $url_fichier) {
			$nouveau_nom = $item['nom_destination'];
			$add = FALSE;
			break;
		}
	}

	// if we do want to download it, we add to the array.
	if ($add === TRUE) {
		$retrievable[] = array(
			'url_origine' => $match,
			'url_fichier' => $url_fichier,
			'nom_fich_origine' => $nom_fichier,
			'nom_destination' => $nouveau_nom,
			'type' => $type
			);
	}
	// replace the URL with the new filename in the &data.
	$new_match = str_replace($match, $nouveau_nom, $match1);
	$data = str_replace($match1, $new_match, $data);
	$match1 = $new_match;

	return $retrievable;
}
function rand_new_name($name) {
	$name = substr($name, 0, (($w = strpos($name, '?')) ? $w : strlen($name)));
	return 'f_'.str_shuffle('abcd').mt_rand(100, 999).'--'.preg_replace('#[^\w.]#', '_', substr($name, 15)).'.'.pathinfo($name, PATHINFO_EXTENSION);
}


if ($GLOBALS['done']['d'] !== FALSE) {
	switch($GLOBALS['done']['d']) {
		case 'ajout' :
			header('Location: index.php?done='.$GLOBALS['done']['d'].'&lien='.urlencode($GLOBALS['url']).'&loclink='.urlencode($GLOBALS['done']['lien']));
			break;
		case 'remove' :
			header('Location: index.php?done='.$GLOBALS['done']['d']);
			break;
	}
	echo '</div>'."\n";
}

/*
 * Displays main form (page to retrieve)
 *
 */
?>
<!DOCTYPE html>
<html>
	<head>
		<meta charset="utf-8" /></head>
		<title>Respawn – a PHP WebPage Saver</title>	
		<link rel="stylesheet" type="text/css" href="design/style.css"/>
		<link rel="shortcut icon" type="/image/png" href="design/favicon2.png">
		<!--[if IE]><script> document.createElement("article");document.createElement("aside");document.createElement("section");document.createElement("footer");</script> <![endif]-->
		
	</head>
<body>
	<header><a href="<?php echo $_SERVER['PHP_SELF'];?>"><img src="design/logo2.png"/></a>
		<nav id="orpx_nav-bar">
		<?php 
			if (!$public){
				echo "\t".'<form method="get" action="'.$_SERVER['PHP_SELF'].'" style="text-align:center">'."\n";
				echo "\t\t".'<input id="____q" type="text" size="70" name="q" value="" placeholder="URL from the page to download" />'."\n";
				echo "\t\t".'<input type="submit" value="Retrieve"/>'."\n";
				echo "\t".'</form>'."\n";
			} else{echo '<p>'.$GLOBALS['message'].'</p>';}
		?>
		</nav>
	</header>
	<aside>
	<?php
	if (!$public){
		if (isset($_GET['done']) and $_GET['done'] !== FALSE) {
			echo '<div id="new-link">'."\n";
			switch($_GET['done']) {
				case 'ajout' :
					echo "\t".'<a target="_blanc" href="'.urldecode($_GET['loclink']).'">Retrieved page</a> - (<a href="'.htmlspecialchars(urldecode($_GET['lien'])).'">orig. page</a>)' ."\n";
					break;

				case 'remove' :
					echo "\t".'Page removed'."\n";
					break;
			}
			echo '</div>'."\n";

		}
	}
	// public pages
	echo '<div class="public" style="'.$column_width.'">'."\n";
	$liste_pages = scandir($GLOBALS['public_data_folder']);
	if ( ($nb = count($liste_pages)) != 0 ) {
		echo '<ul id="liste-pages-sauvees">'."\n";

		for ($i = 0 ; $i < $nb ; $i++) {
			// dont list '.' and '..' folders.
			if (is_dir($GLOBALS['public_data_folder'].'/'.$liste_pages[$i]) and ($liste_pages[$i] != '.') and ($liste_pages[$i] != '..')) {
				// each folder should contain such a file "index.ini".
				$ini_file = $GLOBALS['public_data_folder'].'/'.$liste_pages[$i].'/index.ini';
				$favicon = glob($GLOBALS['public_data_folder'].'/'.$liste_pages[$i].'/*favicon.*');

				$favicon = (isset($favicon[0])) ? $favicon[0] : '';
				if ( is_file($ini_file) and is_readable($ini_file) ) {
					$infos = parse_ini_file($ini_file);
				} else {
					$infos = FALSE;
				}
				if (FALSE !== $infos) {
					$titre = $infos['TITLE']; $url = $infos['URL']; $date = date('d/m/Y, H:i:s', $infos['DATE']);
				} else {
					$titre = 'titre'; $url = '#'; $date = 'date inconnue';
				}
				echo "\t".'<li><a class="suppr" onclick="return window.confirm(\'Sure to remove?\')" href="?suppr='.$GLOBALS['public_data_folder'].'/'.$liste_pages[$i].'" title="suppr"> </a><a class="zip" href="?zippublic='.$liste_pages[$i].'"  title="Download zip version"> </a><a class="origine" href="'.$url.'" title="origin"> </a> - <a href="'.$GLOBALS['public_data_folder'].'/'.$liste_pages[$i].'"><img src="'.$favicon.'"/>'.$titre.'</a> <em> ['.$date.']</em>';
				if (!$public){echo '<a href="?toprivate='.$liste_pages[$i].'" class="toprivate" title="Change to private">&#9654;</a></li>'."\n";}else{echo "</li>\n";}
			}
		}
		echo '</ul>'."\n";
	}
	echo '</div>'."\n";

	if (!$public){ // don't list private pages
	
		echo '<div class="private" style="'.$column_width.'">'."\n";
		$liste_pages = scandir($GLOBALS['private_data_folder']);
		if ( ($nb = count($liste_pages)) != 0 ) {
			echo '<ul id="liste-pages-sauvees">'."\n";

			for ($i = 0 ; $i < $nb ; $i++) {
				// dont list '.' and '..' folders.
				if (is_dir($GLOBALS['private_data_folder'].'/'.$liste_pages[$i]) and ($liste_pages[$i] != '.') and ($liste_pages[$i] != '..')) {
					// each folder should contain such a file "index.ini".
					$ini_file = $GLOBALS['private_data_folder'].'/'.$liste_pages[$i].'/index.ini';
					$favicon=glob($GLOBALS['private_data_folder'].'/'.$liste_pages[$i].'/*favicon.*');
					$favicon = (isset($favicon[0])) ? $favicon[0] : '';
					if ( is_file($ini_file) and is_readable($ini_file) ) {
						$infos = parse_ini_file($ini_file);
					} else {
						$infos = FALSE;
					}
					if (FALSE !== $infos) {
						$titre = $infos['TITLE']; $url = $infos['URL']; $date = date('d/m/Y, H:i:s', $infos['DATE']);
					} else {
						$titre = 'titre'; $url = '#'; $date = 'date inconnue';
					}
					echo "\t".'<li><a class="suppr" onclick="return window.confirm(\'Sure to remove?\')" href="?suppr='.$GLOBALS['private_data_folder'].'/'.$liste_pages[$i].'" title="suppr"> </a><a class="zip" href="?zipprivate='.$liste_pages[$i].'"  title="Download zip version"> </a><a class="origine" href="'.$url.'" title="origin"> </a> - <a href="'.$GLOBALS['private_data_folder'].'/'.$liste_pages[$i].'"><img src="'.$favicon.'"/>'.$titre.'</a> <em> ['.$date.']</em><a href="?topublic='.$liste_pages[$i].'" class="topublic" title="Change to public">&#9664;</a></li>'."\n";
				}
			}
			echo '</ul>'."\n";
		}
		echo '</div>'."\n";
	}
?>
	</aside>
<footer>
	<p style='float:left'><?php echo $bookmarklet; ?></p><p><a title='from TiMo' href='http://lehollandaisvolant.net/index.php?mode=links&id=20121211195941'>Respawn</a> (bronco edition v<?php echo $GLOBAL['version'];?>) - <?php $GLOBALS['message'];?> - <a href='?public'>Public page link</a></p>
</footer>
</body>
</html>