Réindentation du code pour une meilleur lecture.
This commit is contained in:
parent
9a3ea6f195
commit
653d007602
1 changed files with 94 additions and 85 deletions
123
xsaf2.php
123
xsaf2.php
|
@ -1,5 +1,5 @@
|
|||
<?php
|
||||
/* modtime 2013-01-28 */
|
||||
/* modtime 2013-01-30 */
|
||||
|
||||
define('DEBUG', true);
|
||||
|
||||
|
@ -8,53 +8,51 @@ header('X-Robots-Tag: noindex'); /* more civilized method, but bots may not a
|
|||
header('Content-type: text/plain');
|
||||
$expire = time() -7200 ; $lockfile = ".xsaflock"; /* defaut delay: 7200 (2 hours) */
|
||||
|
||||
if (file_exists($lockfile))
|
||||
{
|
||||
if (filemtime($lockfile) > $expire)
|
||||
{ echo "too early"; die; }
|
||||
else
|
||||
{ unlink($lockfile); file_put_contents($lockfile, ''); }
|
||||
if (file_exists($lockfile)) {
|
||||
if (filemtime($lockfile) > $expire) {
|
||||
echo "too early";
|
||||
die;
|
||||
}else{
|
||||
unlink($lockfile);
|
||||
file_put_contents($lockfile, '');
|
||||
}
|
||||
}else{
|
||||
file_put_contents($lockfile, '');
|
||||
}
|
||||
else file_put_contents($lockfile, '');
|
||||
|
||||
define('ROOT_DIR', __DIR__);
|
||||
function escape($str)
|
||||
{
|
||||
function escape($str) {
|
||||
return htmlspecialchars($str, ENT_COMPAT, 'UTF-8', false);
|
||||
}
|
||||
function serverUrl()
|
||||
{
|
||||
|
||||
function serverUrl() {
|
||||
$https = (!empty($_SERVER['HTTPS']) && (strtolower($_SERVER['HTTPS'])=='on')) || $_SERVER["SERVER_PORT"]=='443'; // HTTPS detection.
|
||||
$serverport = ($_SERVER["SERVER_PORT"]=='80' || ($https && $_SERVER["SERVER_PORT"]=='443') ? '' : ':'.$_SERVER["SERVER_PORT"]);
|
||||
return 'http'.($https?'s':'').'://'.$_SERVER["SERVER_NAME"].$serverport;
|
||||
}
|
||||
function NoProtocolSiteURL($url)
|
||||
{
|
||||
|
||||
function NoProtocolSiteURL($url) {
|
||||
$siteurlnoprototypes = array("http://", "https://");
|
||||
$siteurlnoproto = str_replace($siteurlnoprototypes, "", $url);
|
||||
return $siteurlnoproto;
|
||||
}
|
||||
function xsafimport($xsafremote, $iter)
|
||||
{
|
||||
echo "\n*Traitement $xsafremote avec $iter créations max";
|
||||
|
||||
function xsafimport($xsafremote, $iter) {
|
||||
echo "\n*Traitement $xsafremote avec $iter créations max";
|
||||
$json_import = file_get_contents($xsafremote);
|
||||
if(!empty($json_import)){
|
||||
if(!empty($json_import)) {
|
||||
$to_update=array();
|
||||
foreach (json_decode($json_import) as $value) {
|
||||
$infos="";
|
||||
if(count($value)==3 && !empty($value[0]) && !empty($value[1]) && !empty($value[2])){
|
||||
|
||||
if(count($value)==3 && !empty($value[0]) && !empty($value[1]) && !empty($value[2])) {
|
||||
$sitename = $value[0];
|
||||
$siteurl = escape($value[1]);
|
||||
$rssurl = escape($value[2]);
|
||||
if(strpos($siteurl, 'twitter.com') !== FALSE or strpos($siteurl, 'identi.ca') !== FALSE or strpos($sitename, 'statusnet-') !== FALSE) {$social=TRUE;} else {$social=FALSE;}
|
||||
if($social==FALSE)
|
||||
{
|
||||
if($social==FALSE) {
|
||||
$foldername = sha1(NoProtocolSiteURL($siteurl));
|
||||
if(substr($siteurl, -1) == '/'){ $foldername2 = sha1(NoProtocolSiteURL(substr($siteurl, 0, -1))); }else{ $foldername2 = sha1(NoProtocolSiteURL($siteurl).'/');}
|
||||
}
|
||||
else
|
||||
{
|
||||
} else{
|
||||
$foldername = $sitename;$foldername2 = $sitename;
|
||||
}
|
||||
|
||||
|
@ -67,26 +65,26 @@ echo "\n*Traitement $xsafremote avec $iter créations max";
|
|||
if ( mkdir('./'. $foldername, 0755, false) ) {
|
||||
$fp = fopen('./'. $foldername .'/index.php', 'w+');
|
||||
|
||||
$response = get_headers($rssurl, 1); // check for redirections
|
||||
if(!empty($response['Location']))
|
||||
{ $result="false"; }
|
||||
else
|
||||
{
|
||||
$xml = simplexml_load_file($rssurl); // quick feed check
|
||||
if (isset($xml->entry)) // ATOM feed.
|
||||
{$result="true";}
|
||||
elseif (isset($xml->item)) // RSS 1.0 /RDF
|
||||
{$result="true";}
|
||||
elseif (isset($xml->channel->item)) // RSS 2.0
|
||||
{$result="true";}
|
||||
else
|
||||
{$result="false";}
|
||||
}
|
||||
$response = get_headers($rssurl, 1); // check for redirections
|
||||
if(!empty($response['Location'])) {
|
||||
$result="false";
|
||||
}else{
|
||||
$xml = simplexml_load_file($rssurl); // quick feed check
|
||||
if (isset($xml->entry)) { // ATOM feed.
|
||||
$result="true";
|
||||
}elseif (isset($xml->item)) { // RSS 1.0 /RDF
|
||||
$result="true";
|
||||
}elseif (isset($xml->channel->item)) { // RSS 2.0
|
||||
$result="true";
|
||||
}else{
|
||||
$result="false";
|
||||
}
|
||||
}
|
||||
|
||||
/* autoblog */
|
||||
if($social==FALSE and $result!=="false")
|
||||
{ $iter--;
|
||||
if( !fwrite($fp, "<?php require_once dirname(__DIR__) . '/autoblog.php'; ?>") ){
|
||||
/* autoblog */
|
||||
if($social==FALSE and $result!=="false") {
|
||||
$iter--;
|
||||
if( !fwrite($fp, "<?php require_once dirname(__DIR__) . '/autoblog.php'; ?>") ) {
|
||||
$infos = "\nImpossible d'écrire le fichier index.php dans ".$foldername;
|
||||
fclose($fp);
|
||||
}else{
|
||||
|
@ -106,10 +104,10 @@ DOWNLOAD_MEDIA_FROM='.$sitedomain) ){
|
|||
$to_update[]=serverUrl().preg_replace("/(.*)\/(.*)$/i","$1/".$foldername , $_SERVER['SCRIPT_NAME']); // url of the new autoblog
|
||||
}
|
||||
}
|
||||
}
|
||||
/* automicroblog */
|
||||
else if($social!==FALSE and $result!=="false")
|
||||
{ $iter--;
|
||||
}
|
||||
/* automicroblog */
|
||||
else if($social!==FALSE and $result!=="false"){
|
||||
$iter--;
|
||||
if( !fwrite($fp, "<?php require_once dirname(__DIR__) . '/automicroblog.php'; ?>") ){
|
||||
$infos = "\nImpossible d'écrire le fichier index.php dans ".$foldername;
|
||||
fclose($fp);
|
||||
|
@ -129,26 +127,35 @@ FEED_URL="'. $rssurl .'"') ){
|
|||
$to_update[]=serverUrl().preg_replace("/(.*)\/(.*)$/i","$1/".$foldername , $_SERVER['SCRIPT_NAME']); // url of the new autoblog
|
||||
}
|
||||
}
|
||||
|
||||
} else { $infos = "\n$rssurl -> flux invalide"; }
|
||||
/* end of file writing */
|
||||
} else {
|
||||
$infos = "\n$rssurl -> flux invalide";
|
||||
}
|
||||
/* end of file writing */
|
||||
}else {
|
||||
$infos = "\nImpossible de créer le répertoire ".$foldername;
|
||||
}
|
||||
} else { /*$infos = "\nFin d'itération ou Le répertoire ".$foldername." existe déjà ($sitename;$siteurl;$rssurl)";*/ }
|
||||
if(DEBUG){ echo $infos; }
|
||||
} else {
|
||||
/*$infos = "\nFin d'itération ou Le répertoire ".$foldername." existe déjà ($sitename;$siteurl;$rssurl)";*/
|
||||
}
|
||||
if(DEBUG){
|
||||
echo $infos;
|
||||
}
|
||||
}
|
||||
}
|
||||
/*if(!empty($to_update)){
|
||||
if(DEBUG){ echo "\nupdate of autoblogs ..."; }
|
||||
if(DEBUG){
|
||||
echo "\nupdate of autoblogs ...";
|
||||
}
|
||||
// because it's could be very long, we finish by updating new autoblogs
|
||||
foreach ($to_update as $url) {
|
||||
get_headers($url);
|
||||
}
|
||||
if(DEBUG){ echo "done\n\n"; }
|
||||
if(DEBUG){
|
||||
echo "done\n\n";
|
||||
}
|
||||
}*/
|
||||
}
|
||||
$iter=''; return;
|
||||
$iter=''; return;
|
||||
}
|
||||
|
||||
/* And now, the XSAF links to be imported, with maximal import per run ! */
|
||||
|
@ -156,6 +163,8 @@ xsafimport('https://raw.github.com/mitsukarenai/xsaf-bootstrap/master/2.json', 2
|
|||
//xsafimport('https://www.ecirtam.net/autoblogs/?export', 2);
|
||||
//xsafimport('https://autoblog.suumitsu.eu/?export', 1);
|
||||
|
||||
if(DEBUG){ echo "\n\nXSAF import finished\n\n"; }
|
||||
if(DEBUG) {
|
||||
echo "\n\nXSAF import finished\n\n";
|
||||
}
|
||||
die;
|
||||
?>
|
||||
|
|
Loading…
Reference in a new issue