mirror of
https://github.com/e107inc/e107.git
synced 2025-01-18 05:09:05 +01:00
555 lines
14 KiB
PHP
555 lines
14 KiB
PHP
<?php
|
|
/*
|
|
* e107 website system
|
|
*
|
|
* Copyright (C) 2008-2013 e107 Inc (e107.org)
|
|
* Released under the terms and conditions of the
|
|
* GNU General Public License (http://www.gnu.org/licenses/gpl.txt)
|
|
*
|
|
* Plugin Administration - gsitemap
|
|
*
|
|
*/
|
|
require_once("../../class2.php");
|
|
if(!getperms("P") || !e107::isInstalled('gsitemap'))
|
|
{
|
|
e107::redirect('admin');
|
|
exit();
|
|
}
|
|
require_once(e_ADMIN."auth.php");
|
|
require_once(e_HANDLER."userclass_class.php");
|
|
|
|
e107::lan('gsitemap',true);
|
|
|
|
$gsm = new gsitemap;
|
|
|
|
|
|
class gsitemap
|
|
{
|
|
|
|
var $message;
|
|
var $freq_list = array();
|
|
|
|
function gsitemap()
|
|
{
|
|
/* constructor */
|
|
|
|
$mes = e107::getMessage();
|
|
|
|
|
|
$this->freq_list = array
|
|
(
|
|
"always" => GSLAN_11,
|
|
"hourly" => GSLAN_12,
|
|
"daily" => GSLAN_13,
|
|
"weekly" => GSLAN_14,
|
|
"monthly" => GSLAN_15,
|
|
"yearly" => GSLAN_16,
|
|
"never" => LAN_NEVER
|
|
);
|
|
|
|
if(isset($_POST['edit']))
|
|
{
|
|
$this -> editSme();
|
|
}
|
|
|
|
if(isset($_POST['delete']))
|
|
{
|
|
$this -> deleteSme();
|
|
}
|
|
|
|
if(isset($_POST['add_link']))
|
|
{
|
|
$this -> addLink();
|
|
}
|
|
|
|
if(isset($_POST['import_links']))
|
|
{
|
|
$this -> importLink();
|
|
}
|
|
|
|
|
|
if($this -> message)
|
|
{
|
|
$mes->addSuccess($this -> message);
|
|
// echo "<br /><div style='text-align:center'><b>".$this -> message."</b></div><br />";
|
|
}
|
|
|
|
|
|
if(e_QUERY == "new")
|
|
{
|
|
$this -> doForm();
|
|
}
|
|
else if(e_QUERY == "import")
|
|
{
|
|
$this -> importSme();
|
|
}
|
|
else if(e_QUERY == "instructions")
|
|
{
|
|
$this -> instructions();
|
|
}
|
|
else if(!vartrue($_POST['edit']))
|
|
{
|
|
$this -> showList();
|
|
}
|
|
}
|
|
|
|
|
|
function showList()
|
|
{
|
|
|
|
$mes = e107::getMessage();
|
|
$sql = e107::getDb();
|
|
$ns = e107::getRender();
|
|
$tp = e107::getParser();
|
|
$frm = e107::getForm();
|
|
|
|
$gen = new convert;
|
|
|
|
$count = $sql -> select("gsitemap", "*", "gsitemap_id !=0 ORDER BY gsitemap_order ASC");
|
|
|
|
if (!$count)
|
|
{
|
|
$text = "
|
|
<form action='".e_SELF."?import' id='import' method='post'>
|
|
".GSLAN_39."<br /><br />"
|
|
.$frm->admin_button('import',LAN_YES,'submit')."
|
|
</form>";
|
|
|
|
$mes->addInfo($text);
|
|
|
|
$ns -> tablerender(GSLAN_24, $mes->render());
|
|
return;
|
|
}
|
|
else
|
|
{
|
|
$text = "
|
|
<form action='".e_SELF."' id='display' method='post'>
|
|
<table class='table adminlist'>
|
|
<colgroup span='2'>
|
|
<col style='width:5%' />
|
|
<col style='width:10%' />
|
|
<col style='width:35%' />
|
|
<col style='width:20%' />
|
|
<col style='width:10%' />
|
|
<col style='width:10%' />
|
|
<col style='width:10%' />
|
|
</colgroup>
|
|
<thead>
|
|
<tr class='first last' >
|
|
<th style='text-align: center;'>Id</th>
|
|
<th>".LAN_NAME."</th>
|
|
<th>".LAN_URL."</th>
|
|
<th style='text-align: center'>".GSLAN_27."</th>
|
|
<th style='text-align: center' >".GSLAN_28."</th>
|
|
<th style='text-align: center' >".GSLAN_9."</th>
|
|
<th style='text-align: center'>".LAN_OPTIONS."</th>
|
|
</tr>
|
|
</thead>
|
|
<tbody>
|
|
";
|
|
|
|
$glArray = $sql -> db_getList();
|
|
foreach($glArray as $row2)
|
|
{
|
|
$datestamp = $gen->convert_date($row2['gsitemap_lastmod'], "short");
|
|
$rowStyle = (vartrue($rowStyle) == "odd") ? "even" : "odd";
|
|
|
|
$text .= "<tr class='{$rowStyle}'>
|
|
<td style='; text-align: center;'>".$row2['gsitemap_id'] ."</td>
|
|
<td>".$tp->toHTML($row2['gsitemap_name'],"","defs")."</td>
|
|
<td>".$row2['gsitemap_url']."</td>
|
|
<td style='; text-align: center;'>".$datestamp."</td>
|
|
<td style='; text-align: center;'>".$this->freq_list[($row2['gsitemap_freq'])]."</td>
|
|
<td style='; text-align: center;'>".$row2['gsitemap_priority'] ."</td>
|
|
|
|
<td class='center' style='white-space:nowrap'>
|
|
<div>
|
|
<button class='btn btn-default' type='submit' name='edit[{$row2['gsitemap_id']}]' value='edit' alt='".LAN_EDIT."' title='".LAN_EDIT."' style='border:0px' >".ADMIN_EDIT_ICON."</button>
|
|
<button class='btn btn-default btn-secondary action delete' type='submit' name='delete[{$row2['gsitemap_id']}]' value='del' data-confirm='".$tp->toJS(LAN_CONFIRMDEL." [".$row2['gsitemap_name']."]")."' title='".LAN_DELETE."' >".ADMIN_DELETE_ICON."</button>
|
|
</div>
|
|
</td>
|
|
</tr>
|
|
";
|
|
}
|
|
}
|
|
|
|
$text .= "</tbody></table>\n</form>";
|
|
|
|
$ns -> tablerender(GSLAN_24, $mes->render(). $text);
|
|
}
|
|
|
|
|
|
function editSme()
|
|
{
|
|
$sql = e107::getDb();
|
|
$tp = e107::getParser();
|
|
|
|
$e_idt = array_keys($_POST['edit']);
|
|
|
|
if($sql -> select("gsitemap", "*", "gsitemap_id='".$e_idt[0]."' "))
|
|
{
|
|
$foo = $sql -> db_Fetch();
|
|
$foo['gsitemap_name'] = $tp -> toFORM($foo['gsitemap_name']);
|
|
$foo['gsitemap_url'] = $tp -> toFORM($foo['gsitemap_url']);
|
|
|
|
$this -> doForm($foo);
|
|
}
|
|
}
|
|
|
|
|
|
|
|
function doForm($editArray=FALSE)
|
|
{
|
|
$frm = e107::getForm();
|
|
$sql = e107::getDb();
|
|
$ns = e107::getRender();
|
|
$mes = e107::getMessage();
|
|
|
|
|
|
$count = $sql -> select("gsitemap", "*", "gsitemap_id !=0 ORDER BY gsitemap_id ASC");
|
|
|
|
$text = "
|
|
<form action='".e_SELF."' id='form' method='post'>
|
|
<table class='table adminform'>
|
|
<colgroup span='2'>
|
|
<col class='col-label' />
|
|
<col class='col-control' />
|
|
</colgroup>
|
|
<tr>
|
|
<td>".LAN_NAME."</td>
|
|
<td>".$frm->text('gsitemap_name', $editArray['gsitemap_name'], '100', array('class' => 'tbox input-text span3'))."</td>
|
|
</tr>
|
|
|
|
<tr>
|
|
<td>".LAN_URL."</td>
|
|
<td>".$frm->text('gsitemap_url', $editArray['gsitemap_url'], '100', array('class' => 'tbox input-text span3'))."
|
|
<input class='tbox' type='hidden' name='gsitemap_lastmod' size='40' value='".time()."' maxlength='100' /></td>
|
|
</tr>
|
|
<tr>
|
|
<td>".GSLAN_10."</td>
|
|
<td>
|
|
<select class='tbox' name='gsitemap_freq'>\n";
|
|
foreach($this->freq_list as $k=>$fq)
|
|
{
|
|
$sel = ($editArray['gsitemap_freq'] == $k)? "selected='selected'" : "";
|
|
$text .= "<option value='$k' $sel>".$fq."</option>\n";
|
|
}
|
|
|
|
$text.="</select>
|
|
</td>
|
|
</tr>
|
|
<tr>
|
|
<td>".GSLAN_9."</td>
|
|
<td>
|
|
<select class='tbox' name='gsitemap_priority' >\n";
|
|
|
|
for ($i=0.1; $i<1.0; $i=$i+0.1)
|
|
{
|
|
$sel = ($editArray['gsitemap_priority'] == number_format($i,1))? "selected='selected'" : "";
|
|
$text .= "<option value='".number_format($i,1)."' $sel>".number_format($i,1)."</option>\n";
|
|
};
|
|
|
|
$text.="</select></td>
|
|
</tr>
|
|
<tr>
|
|
<td>".LAN_ORDER."</td>
|
|
<td><select name='gsitemap_order' class='tbox'>";
|
|
|
|
for($i=0;$i<$count;$i++){
|
|
$text .= $editArray['gsitemap_order'] == $i ? "<option value='".$i."' selected='selected'>".$i."</option>" : "<option value='".$i."'>".$i."</option>";
|
|
}
|
|
$text .= "</select>
|
|
</td>
|
|
</tr>
|
|
<tr>
|
|
<td>".LAN_VISIBILITY."</td>
|
|
<td>".r_userclass("gsitemap_active", $editArray['gsitemap_active'], 'off', "nobody,public,guest,member,admin,classes,language")." </td>
|
|
</tr>
|
|
</table>
|
|
<div class='buttons-bar center'>";
|
|
if(is_array($editArray))
|
|
{
|
|
$text .= $frm->admin_button('add_link',LAN_UPDATE,'update')."
|
|
<input type='hidden' name='gsitemap_id' value='".$editArray['gsitemap_id']."' />";
|
|
}
|
|
else
|
|
{
|
|
$text .= $frm->admin_button('add_link',LAN_CREATE,'create');
|
|
}
|
|
|
|
$text .= "</div>
|
|
</form>
|
|
";
|
|
|
|
$ns -> tablerender(GSLAN_29, $mes->render(). $text);
|
|
}
|
|
|
|
|
|
|
|
function addLink()
|
|
{
|
|
$log = e107::getAdminLog();
|
|
$sql = e107::getDb();
|
|
$tp = e107::getParser();
|
|
|
|
$gmap = array(
|
|
'gsitemap_name' => $tp->toDB($_POST['gsitemap_name']),
|
|
'gsitemap_url' => $tp->toDB($_POST['gsitemap_url']),
|
|
'gsitemap_priority' => $_POST['gsitemap_priority'],
|
|
'gsitemap_lastmod' => $_POST['gsitemap_lastmod'],
|
|
'gsitemap_freq' => $_POST['gsitemap_freq'],
|
|
'gsitemap_order' => $_POST['gsitemap_order'],
|
|
'gsitemap_active' => $_POST['gsitemap_active'],
|
|
'WHERE' => ' gsitemap_id= '.intval($_POST['gsitemap_id'])
|
|
);
|
|
|
|
if(!empty($_POST['gsitemap_id']))
|
|
{
|
|
$this -> message = $sql->update("gsitemap", $gmap) ? LAN_UPDATED : LAN_UPDATED_FAILED;
|
|
$log->logArrayAll('GSMAP_04',$gmap);
|
|
}
|
|
else
|
|
{
|
|
$gmap['gsitemap_img'] = $_POST['gsitemap_img'];
|
|
$gmap['gsitemap_cat'] = $_POST['gsitemap_cat'];
|
|
$this -> message = ($sql->insert('gsitemap',$gmap)) ? LAN_CREATED : LAN_CREATED_FAILED;
|
|
$log->logArrayAll('GSMAP_03',$gmap);
|
|
}
|
|
}
|
|
|
|
|
|
function deleteSme()
|
|
{
|
|
$log = e107::getAdminLog();
|
|
$sql = e107::getDb();
|
|
|
|
$d_idt = array_keys($_POST['delete']);
|
|
$this -> message = ($sql -> db_Delete("gsitemap", "gsitemap_id='".$d_idt[0]."'")) ? LAN_DELETED : LAN_DELETED_FAILED;
|
|
$log->log_event('GSMAP_02', $this->message.': '.$d_idt[0], E_LOG_INFORMATIVE,'');
|
|
}
|
|
|
|
|
|
|
|
// Import site links
|
|
function importSme()
|
|
{
|
|
global $PLUGINS_DIRECTORY;
|
|
|
|
$ns = e107::getRender();
|
|
$sql = e107::getDb();
|
|
$sql2 = e107::getDb('sql2');
|
|
$frm = e107::getForm();
|
|
$mes = e107::getMessage();
|
|
|
|
$existing = array();
|
|
$sql -> select("gsitemap", "*");
|
|
while($row = $sql->fetch())
|
|
{
|
|
$existing[] = $row['gsitemap_name'];
|
|
}
|
|
|
|
|
|
$importArray = array();
|
|
|
|
/* sitelinks ... */
|
|
$sql -> select("links", "*", "ORDER BY link_order ASC", "no-where");
|
|
$nfArray = $sql -> db_getList();
|
|
foreach($nfArray as $row)
|
|
{
|
|
if(!in_array($row['link_name'], $existing))
|
|
{
|
|
$importArray[] = array('name' => $row['link_name'], 'url' => $row['link_url'], 'type' => GSLAN_1);
|
|
}
|
|
}
|
|
|
|
/* custom pages ... */
|
|
$query = "SELECT p.page_id, p.page_title, p.page_sef, p.page_chapter, ch.chapter_sef as chapter_sef, b.chapter_sef as book_sef FROM #page as p
|
|
LEFT JOIN #page_chapters as ch ON p.page_chapter = ch.chapter_id
|
|
LEFT JOIN #page_chapters as b ON ch.chapter_parent = b.chapter_id
|
|
WHERE page_title !='' ORDER BY page_datestamp ASC";
|
|
|
|
$data = $sql->retrieve($query,true);
|
|
|
|
foreach($data as $row)
|
|
{
|
|
if(!in_array($row['page_title'], $existing))
|
|
{
|
|
$route = ($row['page_chapter'] == 0) ? "page/view/other" : "page/view/index";
|
|
|
|
$importArray[] = array('name' => $row['page_title'], 'url' => e107::getUrl()->create($route, $row, array('full'=>1, 'allow' => 'page_sef,page_title,page_id, chapter_sef, book_sef')), 'type' => "Page");
|
|
}
|
|
}
|
|
|
|
|
|
|
|
/* Plugins.. - currently: forums ... */
|
|
$addons = e107::getAddonConfig('e_gsitemap', null, 'import');
|
|
|
|
foreach($addons as $plug => $config)
|
|
{
|
|
|
|
foreach($config as $row)
|
|
{
|
|
if(!in_array($row['name'], $existing))
|
|
{
|
|
$importArray[] = $row;
|
|
}
|
|
}
|
|
|
|
}
|
|
|
|
$editArray = $_POST;
|
|
|
|
$text = "
|
|
<form action='".e_SELF."' id='form' method='post'>
|
|
<table class='table adminlist table-striped table-condensed'>
|
|
<colgroup>
|
|
<col class='center' style='width:5%;' />
|
|
<col style='width:15%' />
|
|
<col style='width:40%' />
|
|
<col style='width:40%' />
|
|
</colgroup>
|
|
<thead>
|
|
<tr>
|
|
<th class='center'>".GSLAN_2."</th>
|
|
<th>".LAN_TYPE."</th>
|
|
<th>".LAN_NAME."</th>
|
|
<th>".LAN_URL."</th>
|
|
</tr>
|
|
</thead>
|
|
<tbody>
|
|
";
|
|
|
|
foreach($importArray as $k=>$ia)
|
|
{
|
|
$id = 'gs-'.$k;
|
|
$text .= "
|
|
<tr>
|
|
<td class='center'><input id='".$id."' type='checkbox' name='importid[]' value='".$ia['name']."^".$ia['url']."^".$ia['type']."' /></td>
|
|
<td><label for='".$id."'>".$ia['type']."</label></td>
|
|
<td>".$ia['name']."</td>
|
|
<td><span class='smalltext'>".str_replace(SITEURL,"",$ia['url'])."</span></td>
|
|
</tr>
|
|
";
|
|
}
|
|
|
|
$text .= "
|
|
<tr>
|
|
<td colspan='4' class='center'>
|
|
<div class='buttons-bar'> ".GSLAN_8." ".GSLAN_9." : <select class='tbox' name='import_priority' >\n";
|
|
|
|
for ($i=0.1; $i<1.0; $i=$i+0.1)
|
|
{
|
|
$sel = (vartrue($editArray['gsitemap_priority']) == number_format($i,1))? "selected='selected'" : "";
|
|
$text .= "<option value='".number_format($i,1)."' $sel>".number_format($i,1)."</option>\n";
|
|
}
|
|
|
|
$text.="</select> ".GSLAN_10."
|
|
|
|
<select class='tbox' name='import_freq' >\n";
|
|
foreach($this->freq_list as $k=>$fq)
|
|
{
|
|
$sel = (vartrue($editArray['gsitemap_freq']) == $k)? "selected='selected'" : "";
|
|
$text .= "<option value='{$k}' {$sel}>{$fq}</option>\n";
|
|
}
|
|
|
|
$text .= "</select> <br /><br />
|
|
|
|
</div>
|
|
|
|
</td>
|
|
</tr>
|
|
</tbody>
|
|
</table>
|
|
<div class='buttons-bar center'>
|
|
".
|
|
$frm->admin_button('import_links',GSLAN_18,'submit')."
|
|
</div>
|
|
</form>
|
|
";
|
|
|
|
$ns -> tablerender(GSLAN_7, $mes->render(). $text);
|
|
}
|
|
|
|
|
|
|
|
function importLink()
|
|
{
|
|
$sql = e107::getDb();
|
|
$tp = e107::getParser();
|
|
$log = e107::getAdminLog();
|
|
|
|
foreach($_POST['importid'] as $import)
|
|
{
|
|
list($name, $url, $type) = explode("^", $import);
|
|
$name = $tp -> toDB($name);
|
|
$url = $tp -> toDB($url);
|
|
$sql -> db_Insert("gsitemap", "0, '$name', '$url', '".time()."', '".$_POST['import_freq']."', '".$_POST['import_priority']."', '$type', '0', '', '0' ");
|
|
}
|
|
$this -> message = count($_POST['importid'])." link(s) imported.";
|
|
$log->log_event('GSMAP_01',$this->message, E_LOG_INFORMATIVE,'');
|
|
}
|
|
|
|
|
|
|
|
function instructions()
|
|
{
|
|
$mes = e107::getMessage();
|
|
$ns = e107::getRender();
|
|
|
|
|
|
$LINK_1 = "https://www.google.com/accounts/ServiceLogin?service=sitemaps";
|
|
$LINK_2 = "http://www.google.com/support/webmasters/?hl=en";
|
|
|
|
$srch[0] = "[URL]";
|
|
$repl[0] = "<a href='".$LINK_1."'>".$LINK_1."</a>";
|
|
|
|
$srch[1] = "[URL2]";
|
|
$repl[1] = "<blockquote><b>".SITEURL."gsitemap.php</b></blockquote>";
|
|
|
|
$srch[2] = "[";
|
|
$repl[2] = "<a href='".e_ADMIN."prefs.php'>";
|
|
|
|
$srch[3] = "]";
|
|
$repl[3] = "</a>";
|
|
|
|
$text = "<b>".GSLAN_33."</b><br /><br />
|
|
<ul>
|
|
<li>".GSLAN_34."</li>
|
|
<li>".GSLAN_35."</li>
|
|
<li>".GSLAN_36."</li>
|
|
<li>".str_replace($srch,$repl,GSLAN_37)."</li>
|
|
<li>".str_replace("[URL]","<a href='".$LINK_2."'>".$LINK_2."</a>",GSLAN_38)."</li>
|
|
<ul>
|
|
";
|
|
|
|
$ns -> tablerender(GSLAN_32, $mes->render(). $text);
|
|
}
|
|
|
|
}
|
|
|
|
|
|
require_once(e_ADMIN."footer.php");
|
|
|
|
|
|
function admin_config_adminmenu()
|
|
{
|
|
$action = (e_QUERY) ? e_QUERY : "list";
|
|
$var['list']['text'] = GSLAN_20;
|
|
$var['list']['link'] = e_SELF;
|
|
$var['list']['perm'] = "7";
|
|
$var['instructions']['text'] = GSLAN_21 ;
|
|
$var['instructions']['link'] = e_SELF."?instructions";
|
|
$var['instructions']['perm'] = "7";
|
|
$var['new']['text'] = GSLAN_22 ;
|
|
$var['new']['link'] = e_SELF."?new";
|
|
$var['new']['perm'] = "7";
|
|
$var['import']['text'] = GSLAN_23;
|
|
$var['import']['link'] = e_SELF."?import";
|
|
$var['import']['perm'] = "0";
|
|
|
|
show_admin_menu(LAN_PLUGIN_GSITEMAP_NAME, $action, $var);
|
|
}
|
|
|
|
?>
|