mirror of
https://github.com/e107inc/e107.git
synced 2025-01-17 20:58:30 +01:00
Issue #3291 gSitemap table changes. Generic handling of link updates via e_gsitemap.php
This commit is contained in:
parent
c43da4d7aa
commit
450e392741
@ -4829,12 +4829,31 @@ class e_admin_controller_ui extends e_admin_controller
|
|||||||
$pid = $this->getPrimaryName();
|
$pid = $this->getPrimaryName();
|
||||||
$_posted[$pid] = $id; // add in the primary ID field.
|
$_posted[$pid] = $id; // add in the primary ID field.
|
||||||
|
|
||||||
|
$table = $this->getTableName();
|
||||||
|
$pname = $this->getPluginName();
|
||||||
|
|
||||||
|
if($pname === 'core') // Handler 'core' plugin value.
|
||||||
|
{
|
||||||
|
$convert = array(
|
||||||
|
'news_category' => 'news',
|
||||||
|
'news' => 'news',
|
||||||
|
'page' => 'page',
|
||||||
|
'page_chapters' => 'page',
|
||||||
|
'user' => 'user'
|
||||||
|
);
|
||||||
|
|
||||||
|
if(!empty($convert[$table]))
|
||||||
|
{
|
||||||
|
$pname = $convert[$table];
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
$eventData = array( // use $_posted as it may include unsaved data.
|
$eventData = array( // use $_posted as it may include unsaved data.
|
||||||
'newData' => $_posted,
|
'newData' => $_posted,
|
||||||
'oldData' => $old_data,
|
'oldData' => $old_data,
|
||||||
'id' => $id,
|
'id' => $id,
|
||||||
'table' => $this->getTableName(),
|
'table' => $table,
|
||||||
'plugin' => $this->getPluginName(),
|
'plugin' => $pname,
|
||||||
);
|
);
|
||||||
|
|
||||||
$this->_log('Triggering Event: ' . $triggerName);
|
$this->_log('Triggering Event: ' . $triggerName);
|
||||||
|
@ -133,6 +133,10 @@ class gsitemap_ui extends e_admin_ui
|
|||||||
$this->fields['gsitemap_freq']['writeParms']['optArray'] = $this->freqList;
|
$this->fields['gsitemap_freq']['writeParms']['optArray'] = $this->freqList;
|
||||||
|
|
||||||
|
|
||||||
|
if(!empty($_POST['import_links']))
|
||||||
|
{
|
||||||
|
$this->importLink();
|
||||||
|
}
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -187,6 +191,9 @@ class gsitemap_ui extends e_admin_ui
|
|||||||
|
|
||||||
public function importPage()
|
public function importPage()
|
||||||
{
|
{
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
global $PLUGINS_DIRECTORY;
|
global $PLUGINS_DIRECTORY;
|
||||||
|
|
||||||
$ns = e107::getRender();
|
$ns = e107::getRender();
|
||||||
@ -257,6 +264,7 @@ class gsitemap_ui extends e_admin_ui
|
|||||||
{
|
{
|
||||||
if(!in_array($row['name'], $existing))
|
if(!in_array($row['name'], $existing))
|
||||||
{
|
{
|
||||||
|
$row['plugin'] = $plug;
|
||||||
$importArray[] = $row;
|
$importArray[] = $row;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
@ -290,7 +298,8 @@ class gsitemap_ui extends e_admin_ui
|
|||||||
$id = 'gs-'.$k;
|
$id = 'gs-'.$k;
|
||||||
$text .= "
|
$text .= "
|
||||||
<tr>
|
<tr>
|
||||||
<td class='center'><input id='".$id."' type='checkbox' name='importid[]' value='".$ia['name']."^".$ia['url']."^".$ia['type']."^".$ia['table']."^".$ia['id']."' /></td>
|
<td class='center'><input id='".$id."' type='checkbox' name='importid[]'
|
||||||
|
value='".$ia['name']."^".$ia['url']."^".$ia['type']."^".$ia['plugin']."^".$ia['table']."^".$ia['id']."' /></td>
|
||||||
<td><label for='".$id."'>".$ia['type']."</label></td>
|
<td><label for='".$id."'>".$ia['type']."</label></td>
|
||||||
<td>".$ia['name']."</td>
|
<td>".$ia['name']."</td>
|
||||||
<td><span class='smalltext'>".str_replace(SITEURL,"",$ia['url'])."</span></td>
|
<td><span class='smalltext'>".str_replace(SITEURL,"",$ia['url'])."</span></td>
|
||||||
@ -501,6 +510,50 @@ $text = "
|
|||||||
|
|
||||||
|
|
||||||
*/
|
*/
|
||||||
|
function importLink()
|
||||||
|
{
|
||||||
|
|
||||||
|
$sql = e107::getDb();
|
||||||
|
$tp = e107::getParser();
|
||||||
|
$log = e107::getLog();
|
||||||
|
|
||||||
|
|
||||||
|
foreach ($_POST['importid'] as $import)
|
||||||
|
{
|
||||||
|
list($name, $url, $type, $plugin, $table, $id) = explode("^", $import);
|
||||||
|
|
||||||
|
$insert = array(
|
||||||
|
'gsitemap_id' => 0,
|
||||||
|
'gsitemap_name' => $tp->toDB($name),
|
||||||
|
'gsitemap_url' => $tp->toDB($url),
|
||||||
|
'gsitemap_plugin' => $tp->toDB($plugin),
|
||||||
|
'gsitemap_table' => $tp->toDB($table),
|
||||||
|
'gsitemap_table_id' => (int) $id,
|
||||||
|
'gsitemap_lastmod' => time(),
|
||||||
|
'gsitemap_freq' => $_POST['import_freq'],
|
||||||
|
'gsitemap_priority' => $_POST['import_priority'],
|
||||||
|
'gsitemap_cat' => $type,
|
||||||
|
'gsitemap_order' => '0',
|
||||||
|
'gsitemap_img' => '',
|
||||||
|
'gsitemap_active' => '0',
|
||||||
|
);
|
||||||
|
|
||||||
|
if ($sql->insert("gsitemap", $insert))
|
||||||
|
{
|
||||||
|
e107::getMessage()->addSuccess(LAN_CREATED);
|
||||||
|
$log->add('GSMAP_01', $gsitemap->message);
|
||||||
|
}
|
||||||
|
else
|
||||||
|
{
|
||||||
|
e107::getMessage()->addError(LAN_CREATED_FAILED);
|
||||||
|
}
|
||||||
|
|
||||||
|
// $sql->insert("gsitemap", "0, '$name', '$url', '".time()."', '".$_POST['import_freq']."', '".$_POST['import_priority']."', '$type', '0', '', '0' ");
|
||||||
|
}
|
||||||
|
|
||||||
|
// $this->message = count($_POST['importid'])." link(s) imported.";
|
||||||
|
$log->add('GSMAP_01', $gsitemap->message);
|
||||||
|
}
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -619,6 +672,7 @@ class gsitemap
|
|||||||
"never" => LAN_NEVER
|
"never" => LAN_NEVER
|
||||||
);
|
);
|
||||||
|
|
||||||
|
|
||||||
if(isset($_POST['edit']))
|
if(isset($_POST['edit']))
|
||||||
{
|
{
|
||||||
$this->editSme();
|
$this->editSme();
|
||||||
@ -634,10 +688,7 @@ class gsitemap
|
|||||||
$this->addLink();
|
$this->addLink();
|
||||||
}
|
}
|
||||||
|
|
||||||
if(isset($_POST['import_links']))
|
|
||||||
{
|
|
||||||
$this->importLink();
|
|
||||||
}
|
|
||||||
|
|
||||||
|
|
||||||
if($this->message)
|
if($this->message)
|
||||||
@ -659,7 +710,7 @@ class gsitemap
|
|||||||
}
|
}
|
||||||
else if(e_QUERY == "import")
|
else if(e_QUERY == "import")
|
||||||
{
|
{
|
||||||
$this->importSme();
|
// $this->importSme();
|
||||||
}
|
}
|
||||||
else if(e_QUERY == "instructions")
|
else if(e_QUERY == "instructions")
|
||||||
{
|
{
|
||||||
@ -939,198 +990,6 @@ class gsitemap
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
// Import site links
|
|
||||||
function importSme()
|
|
||||||
{
|
|
||||||
global $PLUGINS_DIRECTORY;
|
|
||||||
|
|
||||||
$ns = e107::getRender();
|
|
||||||
$sql = e107::getDb();
|
|
||||||
//$sql2 = e107::getDb('sql2'); not used?
|
|
||||||
$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(
|
|
||||||
'table' => 'links',
|
|
||||||
'id' => $row['link_id'],
|
|
||||||
'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(
|
|
||||||
'table' => 'page',
|
|
||||||
'id' => $row['page_id'],
|
|
||||||
'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']."^".$ia['table']."^".$ia['id']."' /></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)."
|
|
||||||
</div>
|
|
||||||
</form>
|
|
||||||
";
|
|
||||||
|
|
||||||
$ns->tablerender(GSLAN_7, $mes->render(). $text);
|
|
||||||
|
|
||||||
unset($PLUGINS_DIRECTORY);
|
|
||||||
}
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
function importLink()
|
|
||||||
{
|
|
||||||
$sql = e107::getDb();
|
|
||||||
$tp = e107::getParser();
|
|
||||||
$log = e107::getLog();
|
|
||||||
|
|
||||||
|
|
||||||
foreach($_POST['importid'] as $import)
|
|
||||||
{
|
|
||||||
list($name, $url, $type, $table, $id) = explode("^", $import);
|
|
||||||
|
|
||||||
$insert = array(
|
|
||||||
'gsitemap_id' => 0,
|
|
||||||
'gsitemap_name' => $tp->toDB($name),
|
|
||||||
'gsitemap_url' => $tp->toDB($url),
|
|
||||||
'gsitemap_table' => $tp->toDB($table),
|
|
||||||
'gsitemap_table_id' => (int) $id,
|
|
||||||
'gsitemap_lastmod' => time(),
|
|
||||||
'gsitemap_freq' => $_POST['import_freq'],
|
|
||||||
'gsitemap_priority' => $_POST['import_priority'],
|
|
||||||
'gsitemap_cat' => $type,
|
|
||||||
'gsitemap_order' => '0',
|
|
||||||
'gsitemap_img' => '',
|
|
||||||
'gsitemap_active' => '0',
|
|
||||||
);
|
|
||||||
|
|
||||||
$sql->insert("gsitemap", $insert);
|
|
||||||
|
|
||||||
// $sql->insert("gsitemap", "0, '$name', '$url', '".time()."', '".$_POST['import_freq']."', '".$_POST['import_priority']."', '$type', '0', '', '0' ");
|
|
||||||
}
|
|
||||||
|
|
||||||
$this->message = count($_POST['importid'])." link(s) imported.";
|
|
||||||
$log->add('GSMAP_01',$this->message);
|
|
||||||
}
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
function instructions()
|
function instructions()
|
||||||
{
|
{
|
||||||
|
@ -40,37 +40,51 @@ class gsitemap_event // plugin-folder + '_event'
|
|||||||
|
|
||||||
function update($data) // the method to run.
|
function update($data) // the method to run.
|
||||||
{
|
{
|
||||||
e107::getMessage()->addDebug("GSITEMAP TRIGGERRED!!") ;
|
// e107::getMessage()->addDebug("GSITEMAP TRIGGERRED!!") ;
|
||||||
|
|
||||||
|
if(empty($data['plugin']) || empty($data['table']) || empty($data['newData']))
|
||||||
if(empty($data['table']) || empty($data['newData']))
|
|
||||||
{
|
{
|
||||||
return null;
|
return null;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
/** @var news_gsitemap $gsmap - could be another plugin too */
|
||||||
switch ($data['table'])
|
if(!$gsmap = e107::getAddon($data['plugin'], 'e_gsitemap'))
|
||||||
{
|
{
|
||||||
case "news":
|
return null;
|
||||||
$update = array(
|
|
||||||
'gsitemap_url' => e107::getUrl()->create('news/view/item', $data['newData'], array('full' => 1)),
|
|
||||||
'WHERE' => "gsitemap_table = 'news' AND gsitemap_table_id = ".(int) $data['id']
|
|
||||||
);
|
|
||||||
break;
|
|
||||||
|
|
||||||
case "page":
|
|
||||||
// code
|
|
||||||
break;
|
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|
||||||
if(!empty($update))
|
if(!method_exists($gsmap, 'url'))
|
||||||
{
|
{
|
||||||
|
return null;
|
||||||
|
}
|
||||||
|
|
||||||
|
if(!$url = $gsmap->url($data['newData']))
|
||||||
|
{
|
||||||
|
return null;
|
||||||
|
}
|
||||||
|
|
||||||
|
$tp = e107::getParser();
|
||||||
|
$id = (int) $data['id'];
|
||||||
|
|
||||||
|
$update = array(
|
||||||
|
'gsitemap_url' => $url,
|
||||||
|
'WHERE' => "gsitemap_plugin = '".$tp->filter($data['plugin'])."'
|
||||||
|
AND gsitemap_table = '".$tp->filter($data['table'])."'
|
||||||
|
AND gsitemap_table_id = ".$id
|
||||||
|
);
|
||||||
|
|
||||||
|
// todo LAN
|
||||||
|
$message = e107::getParser()->lanVars("Updating sitemap link for #[x] to [y]. ", array($id,$url), true);
|
||||||
|
|
||||||
if(e107::getDb()->update('gsitemap', $update)!==false)
|
if(e107::getDb()->update('gsitemap', $update)!==false)
|
||||||
{
|
{
|
||||||
e107::getMessage()->addDebug("Gsitemap updated: ".print_a($update,true));
|
e107::getMessage()->addSuccess($message);
|
||||||
}
|
}
|
||||||
|
else
|
||||||
|
{
|
||||||
|
e107::getMessage()->addError($message);
|
||||||
}
|
}
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
|
@ -1,10 +1,11 @@
|
|||||||
CREATE TABLE gsitemap (
|
CREATE TABLE gsitemap (
|
||||||
gsitemap_id int(11) unsigned NOT NULL auto_increment,
|
gsitemap_id int(11) unsigned NOT NULL auto_increment,
|
||||||
gsitemap_name varchar(200) NOT NULL default '',
|
gsitemap_name varchar(200) NOT NULL,
|
||||||
gsitemap_url varchar(200) NOT NULL default '',
|
gsitemap_url varchar(200) NOT NULL,
|
||||||
|
gsitemap_plugin varchar(50) NOT NULL default '',
|
||||||
gsitemap_table varchar(50) NOT NULL default '',
|
gsitemap_table varchar(50) NOT NULL default '',
|
||||||
gsitemap_table_id int(7) NOT NULL default '0',
|
gsitemap_table_id int(7) NOT NULL default '0',
|
||||||
gsitemap_lastmod varchar(15) NOT NULL default '',
|
gsitemap_lastmod varchar(15) NOT NULL,
|
||||||
gsitemap_freq varchar(10) NOT NULL default '',
|
gsitemap_freq varchar(10) NOT NULL default '',
|
||||||
gsitemap_priority char(3) NOT NULL default '',
|
gsitemap_priority char(3) NOT NULL default '',
|
||||||
gsitemap_cat varchar(100) NOT NULL default '',
|
gsitemap_cat varchar(100) NOT NULL default '',
|
||||||
|
@ -56,11 +56,24 @@ class news_gsitemap
|
|||||||
'id' => $row['news_id'],
|
'id' => $row['news_id'],
|
||||||
'table' => 'news',
|
'table' => 'news',
|
||||||
'name' => $row['news_title'],
|
'name' => $row['news_title'],
|
||||||
'url' => e107::getUrl()->create('news/view/item', $row, array('full' => 1)),
|
'url' => $this->url($row),
|
||||||
'type' => ADLAN_0
|
'type' => ADLAN_0
|
||||||
);
|
);
|
||||||
}
|
}
|
||||||
|
|
||||||
return $import;
|
return $import;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Used above and by gsitemap/e_event.php to update the URL when changed in news, pages etc.
|
||||||
|
* @param $row
|
||||||
|
* @return string
|
||||||
|
*/
|
||||||
|
function url($row)
|
||||||
|
{
|
||||||
|
return e107::getUrl()->create('news/view/item', $row, array('full' => 1));
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
}
|
}
|
Loading…
x
Reference in New Issue
Block a user