plugin custom permalink refresh

This commit is contained in:
Ian 2016-03-18 13:56:03 +01:00
parent dcfb48e103
commit 34383f19ca
2 changed files with 96 additions and 39 deletions

View file

@ -1 +1,20 @@
1.14: Added stricter array check 1.15:
-----
* Load lang with lang api
* Add Serendpity 2.0+ backend markup
* Fix inconistencies
* Added entries_header hook to assign $is_single_entry,
which else would not be available with custom permalink entries.
1.14.1:
-------
* Use serendipity_specialchars
1.14:
-----
* Added stricter array check

View file

@ -1,22 +1,18 @@
<?php <?php
if (IN_serendipity !== true) { if (IN_serendipity !== true) {
die ("Don't hack!"); die ("Don't hack!");
} }
// Probe for a language include with constants. Still include defines later on, if some constants were missing // Load possible language files.
$probelang = dirname(__FILE__) . '/' . $serendipity['charset'] . 'lang_' . $serendipity['lang'] . '.inc.php'; @serendipity_plugin_api::load_language(dirname(__FILE__));
if (file_exists($probelang)) {
include $probelang;
}
include dirname(__FILE__) . '/lang_en.inc.php'; class serendipity_event_custom_permalinks extends serendipity_event
{
class serendipity_event_custom_permalinks extends serendipity_event {
var $ids = array(); var $ids = array();
function introspect(&$propbag) { function introspect(&$propbag)
{
global $serendipity; global $serendipity;
$propbag->add('name', PLUGIN_EVENT_CUSTOM_PERMALINKS); $propbag->add('name', PLUGIN_EVENT_CUSTOM_PERMALINKS);
@ -24,23 +20,26 @@ class serendipity_event_custom_permalinks extends serendipity_event {
$propbag->add('event_hooks', array( $propbag->add('event_hooks', array(
'genpage' => true, 'genpage' => true,
'backend_publish' => true, 'backend_publish' => true,
'css_backend' => true,
'entry_display' => true, 'entry_display' => true,
'backend_save' => true, 'backend_save' => true,
'entries_header' => true,
'frontend_display:html:per_entry' => true, 'frontend_display:html:per_entry' => true,
'backend_display' => true)); 'backend_display' => true));
$propbag->add('author', 'Garvin Hicking'); $propbag->add('author', 'Garvin Hicking');
$propbag->add('version', '1.14.1'); $propbag->add('version', '1.15');
$propbag->add('requirements', array( $propbag->add('requirements', array(
'serendipity' => '0.8', 'serendipity' => '1.6',
'smarty' => '2.6.7', 'smarty' => '2.6.7',
'php' => '4.1.0' 'php' => '5.1.0'
)); ));
$propbag->add('stackable', false); $propbag->add('stackable', false);
$propbag->add('groups', array('BACKEND_EDITOR')); $propbag->add('groups', array('BACKEND_EDITOR'));
} }
function show($id) { function show($id)
{
global $serendipity; global $serendipity;
$id = (int)$id; $id = (int)$id;
@ -63,18 +62,23 @@ class serendipity_event_custom_permalinks extends serendipity_event {
$serendipity['head_subtitle'] = $serendipity['blogTitle']; $serendipity['head_subtitle'] = $serendipity['blogTitle'];
} }
function generate_content(&$title) { function generate_content(&$title)
{
$title = PLUGIN_EVENT_CUSTOM_PERMALINKS; $title = PLUGIN_EVENT_CUSTOM_PERMALINKS;
} }
function event_hook($event, &$bag, &$eventData, $addData = null) { function event_hook($event, &$bag, &$eventData, $addData = null)
{
global $serendipity; global $serendipity;
$hooks = &$bag->get('event_hooks'); $hooks = &$bag->get('event_hooks');
if (isset($hooks[$event])) { if (isset($hooks[$event])) {
switch($event) { switch($event) {
case 'genpage': case 'genpage':
$args = implode('/', serendipity_getUriArguments($eventData, true)); $args = implode('/', serendipity_getUriArguments($eventData, true));
if ($serendipity['rewrite'] != 'none') { if ($serendipity['rewrite'] != 'none') {
$nice_url = $serendipity['serendipityHTTPPath'] . $args; $nice_url = $serendipity['serendipityHTTPPath'] . $args;
@ -82,16 +86,6 @@ class serendipity_event_custom_permalinks extends serendipity_event {
$nice_url = $serendipity['serendipityHTTPPath'] . $serendipity['indexFile'] . '?/' . $args; $nice_url = $serendipity['serendipityHTTPPath'] . $serendipity['indexFile'] . '?/' . $args;
} }
$myi = strpos($nice_url, '?');
if ($myi != 0 && $serendipity['rewrite'] != 'none') {
$nice_url2 = substr($nice_url, $myi+1);
}
$myi = strpos($nice_url, '?');
if ($myi != 0 && $serendipity['rewrite'] != 'none') {
$nice_url = substr($nice_url, 0, $myi);
}
$myi = strpos($nice_url, '&'); $myi = strpos($nice_url, '&');
if ($myi != 0 && $serendipity['rewrite'] != 'none') { if ($myi != 0 && $serendipity['rewrite'] != 'none') {
$nice_url = substr($nice_url, 0, $myi); $nice_url = substr($nice_url, 0, $myi);
@ -110,13 +104,12 @@ class serendipity_event_custom_permalinks extends serendipity_event {
if (is_array($retid) && !empty($retid[0]['entryid'])) { if (is_array($retid) && !empty($retid[0]['entryid'])) {
$this->show($retid[0]['entryid']); $this->show($retid[0]['entryid']);
} }
break; break;
case 'entry_display': case 'entry_display':
$ids = array(); $ids = array();
if (!is_array($eventData)) { if (!is_array($eventData)) {
return true; break;
} }
foreach ($eventData AS $entry) { foreach ($eventData AS $entry) {
@ -126,11 +119,15 @@ class serendipity_event_custom_permalinks extends serendipity_event {
$query = "SELECT entryid,value FROM {$serendipity['dbPrefix']}entryproperties WHERE entryid IN (" . implode(', ', $ids) . ") AND property = 'permalink'"; $query = "SELECT entryid,value FROM {$serendipity['dbPrefix']}entryproperties WHERE entryid IN (" . implode(', ', $ids) . ") AND property = 'permalink'";
$retval = serendipity_db_query($query); $retval = serendipity_db_query($query);
if (is_array($retval)) { if (is_array($retval)) {
foreach((array)$retval AS $pl) { foreach((array)$retval AS $pl) {
$this->ids[$pl['entryid']] = $pl['value']; $this->ids[$pl['entryid']] = $pl['value'];
} }
} }
break;
case 'entries_header':
// for custom permalinks this has to be set, since it else is not available - only with /archives/ path
$serendipity['smarty']->assign('is_single_entry', true);
break; break;
case 'frontend_display:html:per_entry': case 'frontend_display:html:per_entry':
@ -141,6 +138,26 @@ class serendipity_event_custom_permalinks extends serendipity_event {
} }
break; break;
case 'css_backend':
// append css
$eventData .= '
/* serendipity_event_custom_permalink backend start */
#properties_permalink,
meta_properties_permalink {
width: 100%;
}
#meta_properties_permalink .msg_notice {
margin-top: 0;
margin-bottom: 0;
}
/* serendipity_event_custom_permalink backend end */
';
break;
case 'backend_display': case 'backend_display':
$permalink = !empty($serendipity['POST']['permalink']) ? $serendipity['POST']['permalink'] : ''; $permalink = !empty($serendipity['POST']['permalink']) ? $serendipity['POST']['permalink'] : '';
@ -162,14 +179,34 @@ class serendipity_event_custom_permalinks extends serendipity_event {
? $serendipity['serendipityHTTPPath'] . 'permalink/' . serendipity_makeFilename($title) . '.html' ? $serendipity['serendipityHTTPPath'] . 'permalink/' . serendipity_makeFilename($title) . '.html'
: $serendipity['serendipityHTTPPath'] . $serendipity['indexFile'] . '?/permalink/' . serendipity_makeFilename($title) . '.html'; : $serendipity['serendipityHTTPPath'] . $serendipity['indexFile'] . '?/permalink/' . serendipity_makeFilename($title) . '.html';
} }
if ($serendipity['version'][0] > 1) {
?>
<fieldset id="edit_entry_custompermalinks" class="entryproperties_custompermalinks" style="margin: 1em 0">
<span class="wrap_legend">
<legend>
<?php echo PLUGIN_EVENT_CUSTOM_PERMALINKS_PL; ?>
<button class="toggle_info button_link active" type="button" data-href="#meta_properties_permalink">
<span class="icon-info-circled"></span><b>i</b><span class="visuallyhidden"> <?php echo MORE; ?></span>
</button>
</legend>
</span>
<div class="form_field">
<input id="properties_permalink" class="input_textbox" type="text" name="serendipity[permalink]" value="<?php echo (function_exists('serendipity_specialchars') ? serendipity_specialchars($permalink) : htmlspecialchars($permalink, ENT_COMPAT, LANG_CHARSET)); ?>" />
</div>
<div id="meta_properties_permalink" class="clearfix xfield_info additional_info">
<span class="msg_notice"><span class="icon-info-circled"></span> <?php echo PLUGIN_EVENT_CUSTOM_PERMALINKS_PL_DESC; ?></span>
</div>
</fieldset>
<?php
} else {
?> ?>
<fieldset style="margin: 5px"> <fieldset style="margin: 5px">
<legend><?php echo PLUGIN_EVENT_CUSTOM_PERMALINKS_PL; ?></legend> <legend><?php echo PLUGIN_EVENT_CUSTOM_PERMALINKS_PL; ?></legend>
<div><?php echo PLUGIN_EVENT_CUSTOM_PERMALINKS_PL_DESC; ?><br /><br /></div> <div><?php echo PLUGIN_EVENT_CUSTOM_PERMALINKS_PL_DESC; ?><br /><br /></div>
<label for="permalink" title="<?php echo htmlentities(PLUGIN_EVENT_CUSTOM_PERMALINKS_PL, ENT_COMPAT, LANG_CHARSET); ?>"><?php echo PLUGIN_EVENT_CUSTOM_PERMALINKS_PL; ?>:</label> <input class="input_textbox" type="text" style="width: 60%" name="serendipity[permalink]" id="permalink" value="<?php echo (function_exists('serendipity_specialchars') ? serendipity_specialchars($permalink) : htmlspecialchars($permalink, ENT_COMPAT, LANG_CHARSET)); ?>" /> <label for="permalink" title="<?php echo htmlentities(PLUGIN_EVENT_CUSTOM_PERMALINKS_PL, ENT_COMPAT, LANG_CHARSET); ?>"><?php echo PLUGIN_EVENT_CUSTOM_PERMALINKS_PL; ?>:</label> <input class="input_textbox" type="text" style="width: 60%" name="serendipity[permalink]" id="permalink" value="<?php echo (function_exists('serendipity_specialchars') ? serendipity_specialchars($permalink) : htmlspecialchars($permalink, ENT_COMPAT, LANG_CHARSET)); ?>" />
</fieldset> </fieldset>
<?php <?php
return true; }
break; break;
case 'backend_publish': case 'backend_publish':
@ -177,20 +214,21 @@ class serendipity_event_custom_permalinks extends serendipity_event {
if (!isset($serendipity['POST']['permalink']) || !isset($eventData['id'])) { if (!isset($serendipity['POST']['permalink']) || !isset($eventData['id'])) {
return true; return true;
} }
serendipity_db_query("DELETE FROM {$serendipity['dbPrefix']}entryproperties WHERE entryid = '" . $eventData['id'] . "' AND property = 'permalink'"); serendipity_db_query("DELETE FROM {$serendipity['dbPrefix']}entryproperties WHERE entryid = '" . $eventData['id'] . "' AND property = 'permalink'");
serendipity_db_query("INSERT INTO {$serendipity['dbPrefix']}entryproperties (entryid, value, property) VALUES ('" . $eventData['id'] . "', '" . serendipity_db_escape_string($serendipity['POST']['permalink']) . "', 'permalink')"); serendipity_db_query("INSERT INTO {$serendipity['dbPrefix']}entryproperties (entryid, value, property) VALUES ('" . $eventData['id'] . "', '" . serendipity_db_escape_string($serendipity['POST']['permalink']) . "', 'permalink')");
return true;
break; break;
default: default:
return false; return false;
break;
} }
return true;
} else { } else {
return false; return false;
} }
} }
} }
/* vim: set sts=4 ts=4 expandtab : */ /* vim: set sts=4 ts=4 expandtab : */
?>