cleanup index.xx files
This commit is contained in:
parent
d01496f5cf
commit
96fb6c7d23
@ -10,7 +10,9 @@
|
||||
# http://www.gnu.org/licenses/old-licenses/gpl-2.0.html
|
||||
# -- END LICENSE BLOCK ------------------------------------
|
||||
|
||||
if (!defined('DC_RC_PATH')){return;}
|
||||
if (!defined('DC_RC_PATH')) {
|
||||
return null;
|
||||
}
|
||||
|
||||
# Generic class to play easily with services
|
||||
class kUtRL
|
||||
@ -20,29 +22,28 @@ class kUtRL
|
||||
{
|
||||
$list = $core->getBehaviors('kutrlService');
|
||||
|
||||
if (empty($list)) return array();
|
||||
|
||||
$service = array();
|
||||
foreach($list as $k => $callback)
|
||||
{
|
||||
try
|
||||
{
|
||||
if (empty($list)) {
|
||||
return [];
|
||||
}
|
||||
$service = [];
|
||||
foreach($list as $k => $callback) {
|
||||
try {
|
||||
list($service_id,$service_class) = call_user_func($callback);
|
||||
$services[(string) $service_id] = (string) $service_class;
|
||||
} catch (Exception $e) {
|
||||
|
||||
}
|
||||
catch (Exception $e) {}
|
||||
}
|
||||
return $services;
|
||||
}
|
||||
|
||||
# Silently try to load a service according to its id
|
||||
# Return null on error else service on success
|
||||
public static function quickService($id='')
|
||||
public static function quickService($id = '')
|
||||
{
|
||||
global $core;
|
||||
|
||||
try
|
||||
{
|
||||
try {
|
||||
if (empty($id)) {
|
||||
return null;
|
||||
}
|
||||
@ -50,41 +51,39 @@ class kUtRL
|
||||
if (isset($services[$id])) {
|
||||
return new $services[$id]($core);
|
||||
}
|
||||
}
|
||||
catch(Exception $e) { }
|
||||
} catch(Exception $e) {
|
||||
|
||||
}
|
||||
return null;
|
||||
}
|
||||
|
||||
# Silently try to load a service according to its place
|
||||
# Return null on error else service on success
|
||||
public static function quickPlace($place='plugin')
|
||||
public static function quickPlace($place = 'plugin')
|
||||
{
|
||||
global $core;
|
||||
|
||||
try
|
||||
{
|
||||
if (!in_array($place,array('tpl','wiki','admin','plugin'))) {
|
||||
try {
|
||||
if (!in_array($place, ['tpl', 'wiki', 'admin', 'plugin'])) {
|
||||
return null;
|
||||
}
|
||||
$id = $core->blog->settings->kUtRL->get('kutrl_'.$place.'_service');
|
||||
$id = $core->blog->settings->kUtRL->get('kutrl_' . $place .'_service');
|
||||
if (!empty($id)) {
|
||||
return self::quickService($id);
|
||||
}
|
||||
}
|
||||
catch(Exception $e) { }
|
||||
} catch(Exception $e) {
|
||||
|
||||
}
|
||||
return null;
|
||||
}
|
||||
|
||||
# Silently try to reduce url (using 'plugin' place)
|
||||
# return long url on error else short url on success
|
||||
public static function quickReduce($url,$custom=null,$place='plugin')
|
||||
public static function quickReduce($url, $custom = null, $place = 'plugin')
|
||||
{
|
||||
global $core;
|
||||
|
||||
try
|
||||
{
|
||||
try {
|
||||
$srv = self::quickPlace($place);
|
||||
if (empty($srv)) {
|
||||
return $url;
|
||||
@ -93,12 +92,10 @@ class kUtRL
|
||||
if (empty($rs)) {
|
||||
return $url;
|
||||
}
|
||||
|
||||
return $srv->url_base.$rs->hash;
|
||||
}
|
||||
catch(Exception $e) { }
|
||||
} catch(Exception $e) {
|
||||
|
||||
}
|
||||
return $url;
|
||||
}
|
||||
}
|
||||
?>
|
@ -12,142 +12,128 @@
|
||||
|
||||
# This file manage admin link creation of kUtRL (called from index.php)
|
||||
|
||||
if (!defined('DC_CONTEXT_ADMIN')){return;}
|
||||
if (!defined('DC_CONTEXT_ADMIN')) {
|
||||
return null;
|
||||
}
|
||||
|
||||
$kut = kutrl::quickPlace('admin');
|
||||
|
||||
# Create a new link
|
||||
if ($action == 'createlink') {
|
||||
|
||||
try
|
||||
{
|
||||
if (null === $kut)
|
||||
try {
|
||||
if (null === $kut) {
|
||||
throw new Exception('Unknow service');
|
||||
|
||||
}
|
||||
$url = trim($core->con->escape($_POST['str']));
|
||||
$hash = empty($_POST['custom']) ? null : $_POST['custom'];
|
||||
|
||||
if (empty($url))
|
||||
if (empty($url)) {
|
||||
throw new Exception(__('There is nothing to shorten.'));
|
||||
|
||||
if (!$kut->testService())
|
||||
throw new Exception(__('Service is not well configured.'));
|
||||
|
||||
if (null !== $hash && !$kut->allow_custom_hash)
|
||||
throw new Exception(__('This service does not allowed custom hash.'));
|
||||
|
||||
if (!$kut->isValidUrl($url))
|
||||
throw new Exception(__('This link is not a valid URL.'));
|
||||
|
||||
if (!$kut->isLongerUrl($url))
|
||||
throw new Exception(__('This link is too short.'));
|
||||
|
||||
if (!$kut->isProtocolUrl($url))
|
||||
throw new Exception(__('This type of link is not allowed.'));
|
||||
|
||||
if (!$kut->allow_external_url && !$kut->isBlogUrl($url))
|
||||
throw new Exception(__('Short links are limited to this blog URL.'));
|
||||
|
||||
if ($kut->isServiceUrl($url))
|
||||
throw new Exception(__('This link is already a short link.'));
|
||||
|
||||
if (null !== $hash && false !== ($rs = $kut->isKnowHash($hash)))
|
||||
throw new Exception(__('This custom short url is already taken.'));
|
||||
|
||||
if (false !== ($rs = $kut->isKnowUrl($url)))
|
||||
{
|
||||
$url = $rs->url;
|
||||
$new_url = $kut->url_base.$rs->hash;
|
||||
$msg =
|
||||
'<p class="message">'.
|
||||
sprintf(__('Short link for %s is %s'),
|
||||
'<strong>'.html::escapeHTML($url).'</strong>',
|
||||
'<a href="'.$new_url.'">'.$new_url.'</a>'
|
||||
).'</p>';
|
||||
}
|
||||
else
|
||||
{
|
||||
if (false === ($rs = $kut->hash($url,$hash)))
|
||||
{
|
||||
if ($kut->error->flag())
|
||||
{
|
||||
if (!$kut->testService()) {
|
||||
throw new Exception(__('Service is not well configured.'));
|
||||
}
|
||||
if (null !== $hash && !$kut->allow_custom_hash) {
|
||||
throw new Exception(__('This service does not allowed custom hash.'));
|
||||
}
|
||||
if (!$kut->isValidUrl($url)) {
|
||||
throw new Exception(__('This link is not a valid URL.'));
|
||||
}
|
||||
if (!$kut->isLongerUrl($url)) {
|
||||
throw new Exception(__('This link is too short.'));
|
||||
}
|
||||
if (!$kut->isProtocolUrl($url)) {
|
||||
throw new Exception(__('This type of link is not allowed.'));
|
||||
}
|
||||
if (!$kut->allow_external_url && !$kut->isBlogUrl($url)) {
|
||||
throw new Exception(__('Short links are limited to this blog URL.'));
|
||||
}
|
||||
if ($kut->isServiceUrl($url)) {
|
||||
throw new Exception(__('This link is already a short link.'));
|
||||
}
|
||||
if (null !== $hash && false !== ($rs = $kut->isKnowHash($hash))) {
|
||||
throw new Exception(__('This custom short url is already taken.'));
|
||||
}
|
||||
if (false !== ($rs = $kut->isKnowUrl($url))) {
|
||||
$url = $rs->url;
|
||||
$new_url = $kut->url_base .$rs->hash;
|
||||
$msg =
|
||||
'<p class="message">' .
|
||||
sprintf(
|
||||
__('Short link for %s is %s') ,
|
||||
'<strong>' . html::escapeHTML($url) .'</strong>',
|
||||
'<a href="' . $new_url . '">' . $new_url . '</a>'
|
||||
) . '</p>';
|
||||
} else {
|
||||
if (false === ($rs = $kut->hash($url, $hash))) {
|
||||
if ($kut->error->flag()) {
|
||||
throw new Exception($kut->error->toHTML());
|
||||
}
|
||||
throw new Exception(__('Failed to create short link. This could be caused by a service failure.'));
|
||||
}
|
||||
else
|
||||
{
|
||||
} else {
|
||||
$url = $rs->url;
|
||||
$new_url = $kut->url_base.$rs->hash;
|
||||
$new_url = $kut->url_base . $rs->hash;
|
||||
$msg =
|
||||
'<p class="message">'.
|
||||
sprintf(__('Short link for %s is %s'),
|
||||
'<strong>'.html::escapeHTML($url).'</strong>',
|
||||
'<a href="'.$new_url.'">'.$new_url.'</a>'
|
||||
).'</p>';
|
||||
'<p class="message">' .
|
||||
sprintf(
|
||||
__('Short link for %s is %s'),
|
||||
'<strong>' . html::escapeHTML($url) . '</strong>',
|
||||
'<a href="' . $new_url . '">' . $new_url . '</a>'
|
||||
) . '</p>';
|
||||
|
||||
# ex: Send new url to messengers
|
||||
if (!empty($rs))
|
||||
{
|
||||
$core->callBehavior('adminAfterKutrlCreate',$core,$rs,__('New short URL'));
|
||||
if (!empty($rs)) {
|
||||
$core->callBehavior('adminAfterKutrlCreate', $core, $rs,__('New short URL'));
|
||||
}
|
||||
}
|
||||
}
|
||||
}
|
||||
catch (Exception $e)
|
||||
{
|
||||
} catch (Exception $e) {
|
||||
$core->error->add($e->getMessage());
|
||||
}
|
||||
}
|
||||
|
||||
echo '
|
||||
<html>
|
||||
<head><title>kUtRL, '.__('Links shortener').'</title>'.$header.'</head>
|
||||
<head><title>kUtRL, ' . __('Links shortener') . '</title>' . $header . '</head>
|
||||
<body>
|
||||
<h2>kUtRL'.
|
||||
' › <a href="'.$p_url.'&part=links">'.__('Links').'</a>'.
|
||||
' › '.__('New link').
|
||||
'</h2>'.$msg;
|
||||
<h2>kUtRL' .
|
||||
' › <a href="' . $p_url . '&part=links">' . __('Links') . '</a>' .
|
||||
' › ' . __('New link') .
|
||||
'</h2>' . $msg;
|
||||
|
||||
if (null === $kut)
|
||||
{
|
||||
echo '<p>'.__('You must set an admin service.').'</p>';
|
||||
}
|
||||
else
|
||||
{
|
||||
if (null === $kut) {
|
||||
echo '<p>' . __('You must set an admin service.') . '</p>';
|
||||
} else {
|
||||
echo '
|
||||
<form id="create-link" method="post" action="'.$p_url.'">
|
||||
<form id="create-link" method="post" action="' . $p_url . '">
|
||||
|
||||
<h3>'.sprintf(__('Shorten link using service "%s"'),$kut->name).'</h3>
|
||||
<p class="classic"><label for="str">'.__('Long link:').
|
||||
form::field('str',100,255,'').'</label></p>';
|
||||
<h3>' . sprintf(__('Shorten link using service "%s"'), $kut->name) . '</h3>
|
||||
<p class="classic"><label for="str">' . __('Long link:') .
|
||||
form::field('str', 100, 255, '') . '</label></p>';
|
||||
|
||||
if ($kut->allow_custom_hash)
|
||||
{
|
||||
if ($kut->allow_custom_hash) {
|
||||
echo
|
||||
'<p class="classic"><label for="custom">'.
|
||||
__('Custom short link:').
|
||||
form::field('custom',50,32,'').'</label></p>'.
|
||||
'<p class="form-note">'.__('Only if you want a custom short link.').'</p>';
|
||||
'<p class="classic"><label for="custom">' .
|
||||
__('Custom short link:') .
|
||||
form::field('custom', 50, 32, '') . '</label></p>' .
|
||||
'<p class="form-note">' . __('Only if you want a custom short link.') . '</p>';
|
||||
|
||||
if ($s_admin_service == 'local')
|
||||
{
|
||||
echo '<p class="form-note">'.
|
||||
__('You can use "bob!!" if you want a semi-custom link, it starts with "bob" and "!!" will be replaced by an increment value.').
|
||||
if ($s_admin_service == 'local') {
|
||||
echo '<p class="form-note">' .
|
||||
__('You can use "bob!!" if you want a semi-custom link, it starts with "bob" and "!!" will be replaced by an increment value.') .
|
||||
'</p>';
|
||||
}
|
||||
}
|
||||
|
||||
echo '
|
||||
<div class="clear">
|
||||
<p><input type="submit" name="save" value="'.__('save').'" />'.
|
||||
$core->formNonce().
|
||||
form::hidden(array('p'),'kUtRL').
|
||||
form::hidden(array('part'),'link').
|
||||
form::hidden(array('action'),'createlink').'
|
||||
<p><input type="submit" name="save" value="' . __('save') . '" />' .
|
||||
$core->formNonce() .
|
||||
form::hidden(['p'], 'kUtRL') .
|
||||
form::hidden(['part'], 'link') .
|
||||
form::hidden(['action'], 'createlink') . '
|
||||
</p></div>
|
||||
</form>';
|
||||
}
|
||||
dcPage::helpBlock('kUtRL');
|
||||
echo $footer.'</body></html>';
|
||||
?>
|
||||
echo $footer . '</body></html>';
|
@ -12,36 +12,37 @@
|
||||
|
||||
# This file manage links of kUtRL (called from index.php)
|
||||
|
||||
if (!defined('DC_CONTEXT_ADMIN')){return;}
|
||||
if (!defined('DC_CONTEXT_ADMIN')) {
|
||||
return null;
|
||||
}
|
||||
|
||||
# Short links list
|
||||
class kutrlLinkslist extends adminGenericList
|
||||
{
|
||||
public function display($page,$nb_per_page,$url)
|
||||
public function display($page, $nb_per_page, $url)
|
||||
{
|
||||
if ($this->rs->isEmpty())
|
||||
echo '<p><strong>'.__('No short link').'</strong></p>';
|
||||
|
||||
else {
|
||||
$pager = new pager($page,$this->rs_count,$nb_per_page,10);
|
||||
if ($this->rs->isEmpty()) {
|
||||
echo '<p><strong>' . __('No short link') . '</strong></p>';
|
||||
} else {
|
||||
$pager = new pager($page, $this->rs_count, $nb_per_page, 10);
|
||||
|
||||
$pager->base_url = $url;
|
||||
|
||||
$html_block =
|
||||
'<table class="clear">'.
|
||||
'<thead>'.
|
||||
'<tr>'.
|
||||
'<th class="nowrap" colspan="2">'.__('Hash').'</th>'.
|
||||
'<th class="maximal">'.__('Link').'</th>'.
|
||||
'<th class="nowrap">'.__('Date').'</th>'.
|
||||
'<th class="nowrap">'.__('Service').'</th>'.
|
||||
'</tr>'.
|
||||
'</thead>'.
|
||||
'<tbody>%s</tbody>'.
|
||||
'<table class="clear">' .
|
||||
'<thead>' .
|
||||
'<tr>' .
|
||||
'<th class="nowrap" colspan="2">' . __('Hash') . '</th>' .
|
||||
'<th class="maximal">' . __('Link') . '</th>' .
|
||||
'<th class="nowrap">' . __('Date') . '</th>' .
|
||||
'<th class="nowrap">' . __('Service') . '</th>' .
|
||||
'</tr>' .
|
||||
'</thead>' .
|
||||
'<tbody>%s</tbody>' .
|
||||
'</table>';
|
||||
|
||||
echo '<p>'.__('Page(s)').' : '.$pager->getLinks().'</p>';
|
||||
$blocks = explode('%s',$html_block);
|
||||
echo '<p>' . __('Page(s)') . ' : ' . $pager->getLinks() . '</p>';
|
||||
$blocks = explode('%s', $html_block);
|
||||
echo $blocks[0];
|
||||
|
||||
$this->rs->index(((integer)$page - 1) * $nb_per_page);
|
||||
@ -50,47 +51,46 @@ class kutrlLinkslist extends adminGenericList
|
||||
|
||||
echo $this->line($url,$iter);
|
||||
|
||||
if ($this->rs->isEnd())
|
||||
if ($this->rs->isEnd()) {
|
||||
break;
|
||||
else
|
||||
} else {
|
||||
$this->rs->moveNext();
|
||||
|
||||
}
|
||||
$iter++;
|
||||
}
|
||||
echo $blocks[1];
|
||||
echo '<p>'.__('Page(s)').' : '.$pager->getLinks().'</p>';
|
||||
echo '<p>' . __('Page(s)') . ' : ' . $pager->getLinks() . '</p>';
|
||||
}
|
||||
}
|
||||
|
||||
private function line($url,$loop)
|
||||
private function line($url, $loop)
|
||||
{
|
||||
$type = $this->rs->kut_type;
|
||||
$hash = $this->rs->kut_hash;
|
||||
|
||||
if (null !== ($o = kutrl::quickService($this->rs->kut_type)))
|
||||
{
|
||||
$type = '<a href="'.$o->home.'" title="'.$o->name.'">'.$o->name.'</a>';
|
||||
$hash = '<a href="'.$o->url_base.$hash.'" title="'.$o->url_base.$hash.'">'.$hash.'</a>';
|
||||
if (null !== ($o = kutrl::quickService($this->rs->kut_type))) {
|
||||
$type = '<a href="' . $o->home . '" title="' . $o->name . '">' . $o->name . '</a>';
|
||||
$hash = '<a href="' . $o->url_base . $hash . '" title="' . $o->url_base . $hash . '">' . $hash . '</a>';
|
||||
}
|
||||
|
||||
return
|
||||
'<tr class="line">'."\n".
|
||||
'<td class="nowrap">'.
|
||||
form::checkbox(array('entries['.$loop.']'),$this->rs->kut_id,0).
|
||||
'</td>'.
|
||||
'<td class="nowrap">'.
|
||||
$hash.
|
||||
"</td>\n".
|
||||
'<td class="maximal">'.
|
||||
'<a href="'.$this->rs->kut_url.'">'.$this->rs->kut_url.'</a>'.
|
||||
"</td>\n".
|
||||
'<td class="nowrap">'.
|
||||
dt::dt2str(__('%Y-%m-%d %H:%M'),$this->rs->kut_dt,$this->core->auth->getInfo('user_tz')).
|
||||
"</td>\n".
|
||||
'<td class="nowrap">'.
|
||||
$type.
|
||||
"</td>\n".
|
||||
'</tr>'."\n";
|
||||
'<tr class="line">' . "\n" .
|
||||
'<td class="nowrap">' .
|
||||
form::checkbox(['entries[' . $loop . ']'], $this->rs->kut_id, 0) .
|
||||
'</td>' .
|
||||
'<td class="nowrap">' .
|
||||
$hash .
|
||||
"</td>\n" .
|
||||
'<td class="maximal">' .
|
||||
'<a href="' . $this->rs->kut_url . '">' . $this->rs->kut_url . '</a>' .
|
||||
"</td>\n" .
|
||||
'<td class="nowrap">' .
|
||||
dt::dt2str(__('%Y-%m-%d %H:%M'), $this->rs->kut_dt, $this->core->auth->getInfo('user_tz')) .
|
||||
"</td>\n" .
|
||||
'<td class="nowrap">' .
|
||||
$type .
|
||||
"</td>\n" .
|
||||
'</tr>' . "\n";
|
||||
}
|
||||
}
|
||||
|
||||
@ -106,162 +106,158 @@ $order = !empty($_GET['order']) ? $_GET['order'] : 'desc';
|
||||
$page = !empty($_GET['page']) ? (integer) $_GET['page'] : 1;
|
||||
$nb_per_page = 30;
|
||||
if (!empty($_GET['nb']) && (integer) $_GET['nb'] > 0) {
|
||||
if ($nb_per_page != $_GET['nb']) $show_filters = true;
|
||||
if ($nb_per_page != $_GET['nb']) {
|
||||
$show_filters = true;
|
||||
}
|
||||
$nb_per_page = (integer) $_GET['nb'];
|
||||
}
|
||||
|
||||
# Combos
|
||||
$sortby_combo = array(
|
||||
$sortby_combo = [
|
||||
__('Date') => 'kut_dt',
|
||||
__('Long link') => 'kut_url',
|
||||
__('Short link') => 'kut_hash'
|
||||
);
|
||||
];
|
||||
|
||||
$order_combo = array(
|
||||
$order_combo = [
|
||||
__('Descending') => 'desc',
|
||||
__('Ascending') => 'asc'
|
||||
);
|
||||
];
|
||||
|
||||
$services_combo = array();
|
||||
$services_combo = [];
|
||||
foreach(kutrl::getServices($core) as $service_id => $service)
|
||||
{
|
||||
$o = new $service($core);
|
||||
$services_combo[__($o->name)] = $o->id;
|
||||
}
|
||||
$ext_services_combo = array_merge(array(__('Disabled')=>''),$services_combo);
|
||||
$lst_services_combo = array_merge(array('-'=>''),$services_combo);
|
||||
$ext_services_combo = array_merge([__('Disabled') => ''], $services_combo);
|
||||
$lst_services_combo = array_merge(['-' => ''], $services_combo);
|
||||
|
||||
# Params for list
|
||||
$params = array();
|
||||
$params['limit'] = array((($page-1)*$nb_per_page),$nb_per_page);
|
||||
$params = [];
|
||||
$params['limit'] = [(($page-1)*$nb_per_page), $nb_per_page];
|
||||
|
||||
if ($sortby != '' && in_array($sortby,$sortby_combo))
|
||||
{
|
||||
if ($urlsrv != '' && in_array($urlsrv,$lst_services_combo))
|
||||
if ($sortby != '' && in_array($sortby, $sortby_combo)) {
|
||||
if ($urlsrv != '' && in_array($urlsrv, $lst_services_combo)) {
|
||||
$params['kut_type'] = $urlsrv;
|
||||
|
||||
if ($order != '' && in_array($order,$order_combo))
|
||||
$params['order'] = $sortby.' '.$order;
|
||||
|
||||
if ($sortby != 'kut_dt' || $order != 'desc' || $urlsrv != '')
|
||||
}
|
||||
if ($order != '' && in_array($order, $order_combo)) {
|
||||
$params['order'] = $sortby . ' ' . $order;
|
||||
}
|
||||
if ($sortby != 'kut_dt' || $order != 'desc' || $urlsrv != '') {
|
||||
$show_filters = true;
|
||||
}
|
||||
}
|
||||
|
||||
$pager_base_url =
|
||||
$p_url.
|
||||
'&tab=list'.
|
||||
'&urlsrv='.$urlsrv.
|
||||
'&sortby='.$sortby.
|
||||
'&order='.$order.
|
||||
'&nb='.$nb_per_page.
|
||||
$p_url .
|
||||
'&tab=list' .
|
||||
'&urlsrv=' . $urlsrv .
|
||||
'&sortby=' . $sortby .
|
||||
'&order=' . $order .
|
||||
'&nb=' . $nb_per_page .
|
||||
'&page=%s';
|
||||
|
||||
|
||||
# Delete links from list
|
||||
if ($action == 'deletelinks')
|
||||
{
|
||||
try
|
||||
{
|
||||
foreach($_POST['entries'] as $k => $id)
|
||||
{
|
||||
$rs = $log->getLogs(array('kut_id'=>$id));
|
||||
if ($rs->isEmpty()) continue;
|
||||
|
||||
if (null === ($o = kutrl::quickService($rs->kut_type))) continue;
|
||||
if ($action == 'deletelinks') {
|
||||
try {
|
||||
foreach($_POST['entries'] as $k => $id) {
|
||||
$rs = $log->getLogs(['kut_id' => $id]);
|
||||
if ($rs->isEmpty()) {
|
||||
continue;
|
||||
}
|
||||
if (null === ($o = kutrl::quickService($rs->kut_type))) {
|
||||
continue;
|
||||
}
|
||||
$o->remove($rs->kut_url);
|
||||
}
|
||||
|
||||
$core->blog->triggerBlog();
|
||||
http::redirect($p_url.'&part=links&urlsrv='.$urlsrv.'&sortby='.$sortby.'&order='.$order.'&nb='.$nb_per_page.'&page='.$page.'&msg='.$action);
|
||||
}
|
||||
catch (Exception $e) {
|
||||
http::redirect($p_url . '&part=links&urlsrv=' . $urlsrv . '&sortby=' . $sortby . '&order=' . $order . '&nb=' . $nb_per_page . '&page=' . $page . '&msg=' . $action);
|
||||
} catch (Exception $e) {
|
||||
$core->error->add($e->getMessage());
|
||||
}
|
||||
}
|
||||
|
||||
# Get links and pager
|
||||
try
|
||||
{
|
||||
try {
|
||||
$list_all = $log->getLogs($params);
|
||||
$list_counter = $log->getLogs($params,true)->f(0);
|
||||
$list_current = new kutrlLinksList($core,$list_all,$list_counter,$pager_base_url);
|
||||
}
|
||||
catch (Exception $e)
|
||||
{
|
||||
$list_counter = $log->getLogs($params, true)->f(0);
|
||||
$list_current = new kutrlLinksList($core, $list_all, $list_counter, $pager_base_url);
|
||||
} catch (Exception $e) {
|
||||
$core->error->add($e->getMessage());
|
||||
}
|
||||
|
||||
if (!$show_filters) {
|
||||
$header .= dcPage::jsLoad('js/filter-controls.js');
|
||||
}
|
||||
|
||||
echo '
|
||||
<html>
|
||||
<head><title>kUtRL, '.__('Links shortener').'</title>'.
|
||||
"\n<script type=\"text/javascript\"> \n".
|
||||
"$(function(){ $('.checkboxes-helpers').each(function(){dotclear.checkboxesHelpers(this);}); }); \n".
|
||||
"</script>\n".
|
||||
$header.'</head>
|
||||
<head><title>kUtRL, ' . __('Links shortener') . '</title>' .
|
||||
"\n<script type=\"text/javascript\"> \n" .
|
||||
"$(function(){ $('.checkboxes-helpers').each(function(){dotclear.checkboxesHelpers(this);}); }); \n" .
|
||||
"</script>\n" .
|
||||
$header . '</head>
|
||||
<body>
|
||||
<h2>kUtRL'.
|
||||
' › '.__('Links').
|
||||
' - <a class="button" href="'.$p_url.'&part=link">'.__('New link').'</a>'.
|
||||
'</h2>'.$msg;
|
||||
<h2>kUtRL' .
|
||||
' › ' . __('Links') .
|
||||
' - <a class="button" href="' . $p_url . '&part=link">' . __('New link') . '</a>' .
|
||||
'</h2>' . $msg;
|
||||
|
||||
if (!$show_filters) {
|
||||
echo '<p><a id="filter-control" class="form-control" href="#">'.
|
||||
__('Filters').'</a></p>';
|
||||
echo '<p><a id="filter-control" class="form-control" href="#">' .
|
||||
__('Filters') . '</a></p>';
|
||||
}
|
||||
|
||||
echo '
|
||||
<form action="'.$p_url.'&part=links" method="get" id="filters-form">
|
||||
<fieldset><legend>'.__('Filters').'</legend>
|
||||
<form action="' . $p_url . '&part=links" method="get" id="filters-form">
|
||||
<fieldset><legend>' . __('Filters') . '</legend>
|
||||
<div class="three-cols">
|
||||
<div class="col">
|
||||
<label>'.__('Service:').form::combo('urlsrv',$lst_services_combo,$urlsrv).'
|
||||
<label>' . __('Service:') . form::combo('urlsrv', $lst_services_combo, $urlsrv) . '
|
||||
</label>
|
||||
</div>
|
||||
<div class="col">
|
||||
<label>'.__('Order by:').form::combo('sortby',$sortby_combo,$sortby).'
|
||||
<label>' . __('Order by:') . form::combo('sortby', $sortby_combo, $sortby) . '
|
||||
</label>
|
||||
<label>'.__('Sort:').form::combo('order',$order_combo,$order).'
|
||||
<label>' . __('Sort:') . form::combo('order', $order_combo, $order) . '
|
||||
</label>
|
||||
</div>
|
||||
<div class="col">
|
||||
<p>
|
||||
<label class="classic">'.form::field('nb',3,3,$nb_per_page).' '.__('Entries per page').'
|
||||
<label class="classic">' . form::field('nb', 3, 3, $nb_per_page) . ' ' . __('Entries per page') . '
|
||||
</label>
|
||||
<input type="submit" value="'.__('filter').'" />'.
|
||||
form::hidden(array('p'),'kUtRL').
|
||||
form::hidden(array('part'),'links').'
|
||||
<input type="submit" value="' . __('filter') . '" />' .
|
||||
form::hidden(['p'], 'kUtRL') .
|
||||
form::hidden(['part'], 'links') . '
|
||||
</p>
|
||||
</div>
|
||||
</div>
|
||||
<br class="clear" />
|
||||
</fieldset>
|
||||
</form>
|
||||
<form action="'.$p_url.'&part=links" method="post" id="form-actions">';
|
||||
<form action="' . $p_url . '&part=links" method="post" id="form-actions">';
|
||||
|
||||
$list_current->display($page,$nb_per_page,$pager_base_url);
|
||||
$list_current->display($page, $nb_per_page, $pager_base_url);
|
||||
|
||||
echo '
|
||||
<div class="two-cols">
|
||||
<p class="col checkboxes-helpers"></p>
|
||||
<p class="col right">
|
||||
<input type="submit" value="'.__('Delete selected short links').'" />'.
|
||||
form::hidden(array('action'),'deletelinks').
|
||||
form::hidden(array('urlsrv'),$urlsrv).
|
||||
form::hidden(array('sortby'),$sortby).
|
||||
form::hidden(array('order'),$order).
|
||||
form::hidden(array('page'),$page).
|
||||
form::hidden(array('nb'),$nb_per_page).
|
||||
form::hidden(array('p'),'kUtRL').
|
||||
form::hidden(array('part'),'links').
|
||||
$core->formNonce().'
|
||||
<input type="submit" value="' . __('Delete selected short links') . '" />' .
|
||||
form::hidden(['action'], 'deletelinks') .
|
||||
form::hidden(['urlsrv'], $urlsrv) .
|
||||
form::hidden(['sortby'], $sortby) .
|
||||
form::hidden(['order'], $order) .
|
||||
form::hidden(['page'], $page) .
|
||||
form::hidden(['nb'], $nb_per_page) .
|
||||
form::hidden(['p'], 'kUtRL') .
|
||||
form::hidden(['part'], 'links') .
|
||||
$core->formNonce() . '
|
||||
</p>
|
||||
</div>
|
||||
</form>';
|
||||
|
||||
dcPage::helpBlock('kUtRL');
|
||||
echo $footer.'</body></html>';
|
||||
echo $footer . '</body></html>';
|
||||
?>
|
@ -12,66 +12,58 @@
|
||||
|
||||
# This file manage services of kUtRL (called from index.php)
|
||||
|
||||
if (!defined('DC_CONTEXT_ADMIN')){return;}
|
||||
if (!defined('DC_CONTEXT_ADMIN')) {
|
||||
return null;
|
||||
}
|
||||
|
||||
# Save services settings
|
||||
if ($action == 'saveservice')
|
||||
{
|
||||
try
|
||||
{
|
||||
foreach(kutrl::getServices($core) as $service_id => $service)
|
||||
{
|
||||
if ($action == 'saveservice') {
|
||||
try {
|
||||
foreach(kutrl::getServices($core) as $service_id => $service) {
|
||||
$o = new $service($core);
|
||||
$o->saveSettings();
|
||||
}
|
||||
$core->blog->triggerBlog();
|
||||
http::redirect($p_url.'&part=service§ion='.$section.'&msg='.$action);
|
||||
}
|
||||
catch (Exception $e)
|
||||
{
|
||||
http::redirect($p_url . '&part=service§ion=' . $section . '&msg=' . $action);
|
||||
} catch (Exception $e) {
|
||||
$core->error->add($e->getMessage());
|
||||
}
|
||||
}
|
||||
|
||||
echo '
|
||||
<html>
|
||||
<head><title>kUtRL, '.__('Links shortener').'</title>'.$header.
|
||||
dcPage::jsLoad('index.php?pf=kUtRL/js/service.js').
|
||||
"<script type=\"text/javascript\">\n//<![CDATA[\n".
|
||||
dcPage::jsVar('jcToolsBox.prototype.section',$section).
|
||||
"\n//]]>\n</script>\n".
|
||||
<head><title>kUtRL, ' . __('Links shortener') . '</title>' . $header .
|
||||
dcPage::jsLoad('index.php?pf=kUtRL/js/service.js') .
|
||||
"<script type=\"text/javascript\">\n//<![CDATA[\n" .
|
||||
dcPage::jsVar('jcToolsBox.prototype.section', $section) .
|
||||
"\n//]]>\n</script>\n" .
|
||||
'</head>
|
||||
<body>
|
||||
<h2>kUtRL'.
|
||||
' › <a href="'.$p_url.'&part=links">'.__('Links').'</a>'.
|
||||
' › '.__('Services').
|
||||
' - <a class="button" href="'.$p_url.'&part=link">'.__('New link').'</a>'.
|
||||
'</h2>'.$msg.'
|
||||
<form id="service-form" method="post" action="'.$p_url.'">';
|
||||
<h2>kUtRL' .
|
||||
' › <a href="' . $p_url . '&part=links">' . __('Links') . '</a>' .
|
||||
' › ' . __('Services') .
|
||||
' - <a class="button" href="' . $p_url . '&part=link">' . __('New link') . '</a>' .
|
||||
'</h2>' . $msg . '
|
||||
<form id="service-form" method="post" action="' . $p_url . '">';
|
||||
|
||||
foreach(kutrl::getServices($core) as $service_id => $service)
|
||||
{
|
||||
foreach(kutrl::getServices($core) as $service_id => $service) {
|
||||
$o = new $service($core);
|
||||
|
||||
echo '<fieldset id="setting-'.$service_id.'"><legend>'.$o->name.'</legend>';
|
||||
echo '<fieldset id="setting-' . $service_id . '"><legend>' . $o->name . '</legend>';
|
||||
|
||||
if (!empty($msg))
|
||||
{
|
||||
echo '<p><em>'.(
|
||||
if (!empty($msg)) {
|
||||
echo '<p><em>' . (
|
||||
$o->testService() ?
|
||||
$img_green.' '.sprintf(__('%s API is well configured and runing.'),$o->name) :
|
||||
$img_red.' '.sprintf(__('Failed to test %s API.'),$o->name)
|
||||
).'</em></p>';
|
||||
$img_green . ' ' . sprintf(__('%s API is well configured and runing.'), $o->name) :
|
||||
$img_red . ' ' . sprintf(__('Failed to test %s API.'), $o->name)
|
||||
) . '</em></p>';
|
||||
//if ($o->error->flag()) {
|
||||
echo $o->error->toHTML();
|
||||
//}
|
||||
}
|
||||
|
||||
if (!empty($o->home))
|
||||
{
|
||||
echo '<p><a title="'.__('homepage').'" href="'.$o->home.'">'.sprintf(__('Learn more about %s.'),$o->name).'</a></p>';
|
||||
if (!empty($o->home)) {
|
||||
echo '<p><a title="' . __('homepage') . '" href="' . $o->home . '">' . sprintf(__('Learn more about %s.'), $o->name) . '</a></p>';
|
||||
}
|
||||
|
||||
$o->settingsForm();
|
||||
|
||||
echo '</fieldset>';
|
||||
@ -79,14 +71,13 @@ foreach(kutrl::getServices($core) as $service_id => $service)
|
||||
|
||||
echo '
|
||||
<div class="clear">
|
||||
<p><input type="submit" name="save" value="'.__('save').'" />'.
|
||||
$core->formNonce().
|
||||
form::hidden(array('p'),'kUtRL').
|
||||
form::hidden(array('part'),'service').
|
||||
form::hidden(array('action'),'saveservice').
|
||||
form::hidden(array('section'),$section).'
|
||||
<p><input type="submit" name="save" value="' . __('save') . '" />' .
|
||||
$core->formNonce() .
|
||||
form::hidden(['p'], 'kUtRL') .
|
||||
form::hidden(['part'], 'service') .
|
||||
form::hidden(['action'], 'saveservice') .
|
||||
form::hidden(['section'], $section) . '
|
||||
</p></div>
|
||||
</form>';
|
||||
dcPage::helpBlock('kUtRL');
|
||||
echo $footer.'</body></html>';
|
||||
?>
|
||||
echo $footer . '</body></html>';
|
@ -12,7 +12,9 @@
|
||||
|
||||
# This file manage settings of kUtRL (called from index.php)
|
||||
|
||||
if (!defined('DC_CONTEXT_ADMIN')){return;}
|
||||
if (!defined('DC_CONTEXT_ADMIN')) {
|
||||
return null;
|
||||
}
|
||||
|
||||
$s_active = (boolean) $s->kutrl_active;
|
||||
$s_plugin_service = (string) $s->kutrl_plugin_service;
|
||||
@ -24,8 +26,7 @@ $s_tpl_passive = (boolean) $s->kutrl_tpl_passive;
|
||||
$s_tpl_active = (boolean) $s->kutrl_tpl_active;
|
||||
$s_admin_entry_default = (string) $s->kutrl_admin_entry_default;
|
||||
|
||||
if ($default_part == 'setting' && $action == 'savesetting')
|
||||
{
|
||||
if ($default_part == 'setting' && $action == 'savesetting') {
|
||||
try {
|
||||
$s_active = !empty($_POST['s_active']);
|
||||
$s_admin_service = $_POST['s_admin_service'];
|
||||
@ -37,128 +38,125 @@ if ($default_part == 'setting' && $action == 'savesetting')
|
||||
$s_tpl_active = !empty($_POST['s_tpl_active']);
|
||||
$s_admin_entry_default = !empty($_POST['s_admin_entry_default']);
|
||||
|
||||
$s->put('kutrl_active',$s_active);
|
||||
$s->put('kutrl_plugin_service',$s_plugin_service);
|
||||
$s->put('kutrl_admin_service',$s_admin_service);
|
||||
$s->put('kutrl_tpl_service',$s_tpl_service);
|
||||
$s->put('kutrl_wiki_service',$s_wiki_service);
|
||||
$s->put('kutrl_allow_external_url',$s_allow_external_url);
|
||||
$s->put('kutrl_tpl_passive',$s_tpl_passive);
|
||||
$s->put('kutrl_tpl_active',$s_tpl_active);
|
||||
$s->put('kutrl_admin_entry_default',$s_admin_entry_default);
|
||||
$s->put('kutrl_active', $s_active);
|
||||
$s->put('kutrl_plugin_service', $s_plugin_service);
|
||||
$s->put('kutrl_admin_service', $s_admin_service);
|
||||
$s->put('kutrl_tpl_service', $s_tpl_service);
|
||||
$s->put('kutrl_wiki_service', $s_wiki_service);
|
||||
$s->put('kutrl_allow_external_url', $s_allow_external_url);
|
||||
$s->put('kutrl_tpl_passive', $s_tpl_passive);
|
||||
$s->put('kutrl_tpl_active', $s_tpl_active);
|
||||
$s->put('kutrl_admin_entry_default', $s_admin_entry_default);
|
||||
|
||||
$core->blog->triggerBlog();
|
||||
|
||||
http::redirect($p_url.'&part=setting&msg='.$action.'§ion='.$section);
|
||||
}
|
||||
catch (Exception $e) {
|
||||
http::redirect($p_url . '&part=setting&msg=' . $action . '§ion=' . $section);
|
||||
} catch (Exception $e) {
|
||||
$core->error->add($e->getMessage());
|
||||
}
|
||||
}
|
||||
|
||||
$services_combo = array();
|
||||
foreach(kutrl::getServices($core) as $service_id => $service)
|
||||
{
|
||||
$services_combo = [];
|
||||
foreach(kutrl::getServices($core) as $service_id => $service) {
|
||||
$o = new $service($core);
|
||||
$services_combo[__($o->name)] = $o->id;
|
||||
}
|
||||
$ext_services_combo = array_merge(array(__('Disabled')=>''),$services_combo);
|
||||
$lst_services_combo = array_merge(array('-'=>''),$services_combo);
|
||||
$ext_services_combo = array_merge([__('Disabled')=>''], $services_combo);
|
||||
$lst_services_combo = array_merge(['-'=>''], $services_combo);
|
||||
|
||||
echo '
|
||||
<html>
|
||||
<head><title>kUtRL, '.__('Links shortener').'</title>'.$header.
|
||||
dcPage::jsLoad('index.php?pf=kUtRL/js/setting.js').
|
||||
"<script type=\"text/javascript\">\n//<![CDATA[\n".
|
||||
dcPage::jsVar('jcToolsBox.prototype.section',$section).
|
||||
"\n//]]>\n</script>\n".
|
||||
<head><title>kUtRL, ' . __('Links shortener') . '</title>' . $header .
|
||||
dcPage::jsLoad('index.php?pf=kUtRL/js/setting.js') .
|
||||
"<script type=\"text/javascript\">\n//<![CDATA[\n" .
|
||||
dcPage::jsVar('jcToolsBox.prototype.section', $section) .
|
||||
"\n//]]>\n</script>\n" .
|
||||
'</head>
|
||||
<body>
|
||||
<h2>kUtRL'.
|
||||
' › <a href="'.$p_url.'&part=links">'.__('Links').'</a>'.
|
||||
' › '.__('Settings').
|
||||
' - <a class="button" href="'.$p_url.'&part=link">'.__('New link').'</a>'.
|
||||
'</h2>'.$msg.'
|
||||
<form id="setting-form" method="post" action="'.$p_url.'">
|
||||
<h2>kUtRL' .
|
||||
' › <a href="' . $p_url . '&part=links">' . __('Links') . '</a>' .
|
||||
' › ' . __('Settings') .
|
||||
' - <a class="button" href="' . $p_url . '&part=link">' . __('New link') . '</a>' .
|
||||
'</h2>' . $msg . '
|
||||
<form id="setting-form" method="post" action="' . $p_url . '">
|
||||
|
||||
<fieldset id="setting-plugin"><legend>'. __('Plugin activation').'</legend>
|
||||
<p><label class="classic">'.
|
||||
form::checkbox(array('s_active'),'1',$s_active).
|
||||
__('Enable plugin').'</label></p>
|
||||
<fieldset id="setting-plugin"><legend>' . __('Plugin activation') . '</legend>
|
||||
<p><label class="classic">' .
|
||||
form::checkbox(['s_active'], '1', $s_active) .
|
||||
__('Enable plugin') . '</label></p>
|
||||
</fieldset>
|
||||
|
||||
<fieldset id="setting-option"><legend>'. __('General rules').'</legend>
|
||||
<p><label class="classic">'.
|
||||
form::checkbox(array('s_allow_external_url'),'1',$s_allow_external_url).
|
||||
__('Allow short link for external URL').'</label></p>
|
||||
<p class="form-note">'.__('Not only link started with this blog URL could be shortened.').'</p>
|
||||
<p><label class="classic">'.
|
||||
form::checkbox(array('s_tpl_passive'),'1',$s_tpl_passive).
|
||||
__('Passive mode').'</label></p>
|
||||
<p class="form-note">'.__('If this extension is disabled and the passive mode is enabled, "kutrl" tags (like EntryKurl) will display long urls instead of nothing on templates.').'</p>
|
||||
<p><label class="classic">'.
|
||||
form::checkbox(array('s_tpl_active'),'1',$s_tpl_active).
|
||||
__('Active mode').'</label></p>
|
||||
<p class="form-note">'.__('If the active mode is enabled, all know default template tags (like EntryURL) will display short urls instead of long ones on templates.').'<br />'.
|
||||
__('You can disable URL shortening for a specific template tag by adding attribute disable_kutrl="1" to it.').'</p>
|
||||
<p><label class="classic">'.
|
||||
form::checkbox(array('s_admin_entry_default'),'1',$s_admin_entry_default).
|
||||
__('Create short link for new entries').'</label></p>
|
||||
<p class="form-note">'.__('This can be changed on page of creation/edition of an entry.').'</p>
|
||||
<fieldset id="setting-option"><legend>' . __('General rules') . '</legend>
|
||||
<p><label class="classic">' .
|
||||
form::checkbox(['s_allow_external_url'], '1', $s_allow_external_url) .
|
||||
__('Allow short link for external URL') . '</label></p>
|
||||
<p class="form-note">' . __('Not only link started with this blog URL could be shortened.') . '</p>
|
||||
<p><label class="classic">' .
|
||||
form::checkbox(['s_tpl_passive'], '1', $s_tpl_passive) .
|
||||
__('Passive mode') . '</label></p>
|
||||
<p class="form-note">' . __('If this extension is disabled and the passive mode is enabled, "kutrl" tags (like EntryKurl) will display long urls instead of nothing on templates.') . '</p>
|
||||
<p><label class="classic">' .
|
||||
form::checkbox(['s_tpl_active'], '1', $s_tpl_active) .
|
||||
__('Active mode') . '</label></p>
|
||||
<p class="form-note">' . __('If the active mode is enabled, all know default template tags (like EntryURL) will display short urls instead of long ones on templates.') . '<br />' .
|
||||
__('You can disable URL shortening for a specific template tag by adding attribute disable_kutrl="1" to it . ') . '</p>
|
||||
<p><label class="classic">' .
|
||||
form::checkbox(['s_admin_entry_default'], '1', $s_admin_entry_default) .
|
||||
__('Create short link for new entries') . '</label></p>
|
||||
<p class="form-note">' . __('This can be changed on page of creation/edition of an entry.') . '</p>
|
||||
</fieldset>
|
||||
|
||||
<fieldset id="setting-service"><legend>'. __('Default services').'</legend>
|
||||
<fieldset id="setting-service"><legend>' . __('Default services') . '</legend>
|
||||
<p><label>';
|
||||
if (!empty($msg)) {
|
||||
if (null !== ($o = kutrl::quickPlace($s_admin_service))) {
|
||||
echo $o->testService() ? $img_green : $img_red;
|
||||
}
|
||||
}
|
||||
echo ' '.__('Administration:').'<br />'.
|
||||
form::combo(array('s_admin_service'),$services_combo,$s_admin_service).'
|
||||
echo ' ' . __('Administration:') . '<br />' .
|
||||
form::combo(['s_admin_service'], $services_combo, $s_admin_service) . '
|
||||
</label></p>
|
||||
<p class="form-note">'.__('Service to use in this admin page and on edit page of an entry.').'</p>
|
||||
<p class="form-note">' . __('Service to use in this admin page and on edit page of an entry.') . '</p>
|
||||
<p><label>';
|
||||
if (!empty($msg)) {
|
||||
if (null !== ($o = kutrl::quickPlace($s_plugin_service))) {
|
||||
echo $o->testService() ? $img_green : $img_red;
|
||||
}
|
||||
}
|
||||
echo ' '.__('Extensions:').'<br />'.
|
||||
form::combo(array('s_plugin_service'),$services_combo,$s_plugin_service).'
|
||||
echo ' ' . __('Extensions:') . '<br />' .
|
||||
form::combo(['s_plugin_service'], $services_combo, $s_plugin_service) . '
|
||||
</label></p>
|
||||
<p class="form-note">'.__('Service to use on third part plugins.').'</p>
|
||||
<p class="form-note">' . __('Service to use on third part plugins.') . '</p>
|
||||
<p><label>';
|
||||
if (!empty($msg)) {
|
||||
if (null !== ($o = kutrl::quickPlace($s_tpl_service))) {
|
||||
echo $o->testService() ? $img_green : $img_red;
|
||||
}
|
||||
}
|
||||
echo ' '.__('Templates:').'<br />'.
|
||||
form::combo(array('s_tpl_service'),$ext_services_combo,$s_tpl_service).'
|
||||
echo ' ' . __('Templates:') . '<br />' .
|
||||
form::combo(['s_tpl_service'], $ext_services_combo, $s_tpl_service) . '
|
||||
</label></p>
|
||||
<p class="form-note">'.__('Shorten links automatically when using template value like "EntryKutrl".').'</p>
|
||||
<p class="form-note">' . __('Shorten links automatically when using template value like "EntryKutrl".') . '</p>
|
||||
<p><label>';
|
||||
if (!empty($msg)) {
|
||||
if (null !== ($o = kutrl::quickPlace($s_wiki_service))) {
|
||||
echo $o->testService() ? $img_green : $img_red;
|
||||
}
|
||||
}
|
||||
echo ' '.__('Contents:').'<br />'.
|
||||
form::combo(array('s_wiki_service'),$ext_services_combo,$s_wiki_service).'
|
||||
echo ' ' . __('Contents:') . '<br />' .
|
||||
form::combo(['s_wiki_service'], $ext_services_combo, $s_wiki_service) . '
|
||||
</label></p>
|
||||
<p class="form-note">'.__('Shorten links automatically found in contents using wiki synthax.').'</p>
|
||||
<p class="form-note">' . __('Shorten links automatically found in contents using wiki synthax.') . '</p>
|
||||
</fieldset>
|
||||
|
||||
<div class="clear">
|
||||
<p><input type="submit" name="save" value="'.__('save').'" />'.
|
||||
$core->formNonce().
|
||||
form::hidden(array('p'),'kUtRL').
|
||||
form::hidden(array('part'),'setting').
|
||||
form::hidden(array('action'),'savesetting').
|
||||
form::hidden(array('section'),$section).'
|
||||
<p><input type="submit" name="save" value="' . __('save') . '" />' .
|
||||
$core->formNonce() .
|
||||
form::hidden(['p'], 'kUtRL') .
|
||||
form::hidden(['part'], 'setting') .
|
||||
form::hidden(['action'], 'savesetting') .
|
||||
form::hidden(['section'], $section) . '
|
||||
</p></div>
|
||||
</form>';
|
||||
dcPage::helpBlock('kUtRL');
|
||||
echo $footer.'</body></html>';
|
||||
?>
|
||||
echo $footer . '</body></html>';
|
@ -12,9 +12,11 @@
|
||||
|
||||
# This file is used with plugin activityReport
|
||||
|
||||
if (!defined('DC_RC_PATH')){return;}
|
||||
if (!defined('DC_RC_PATH')) {
|
||||
return null;
|
||||
}
|
||||
|
||||
$core->activityReport->addGroup('kutrl',__('Plugin kUtRL'));
|
||||
$core->activityReport->addGroup('kutrl', __('Plugin kUtRL'));
|
||||
|
||||
# from BEHAVIOR kutrlAfterCreateShortUrl in kUtRL/inc/lib.kutrl.srv.php
|
||||
$core->activityReport->addAction(
|
||||
@ -23,16 +25,15 @@ $core->activityReport->addAction(
|
||||
__('Short link creation'),
|
||||
__('New short link of type "%s" and hash "%s" was created.'),
|
||||
'kutrlAfterCreateShortUrl',
|
||||
array('kutrlActivityReportBehaviors','kutrlCreate')
|
||||
['kutrlActivityReportBehaviors', 'kutrlCreate']
|
||||
);
|
||||
|
||||
class kutrlActivityReportBehaviors
|
||||
{
|
||||
public static function kutrlCreate($rs)
|
||||
{
|
||||
$logs = array($rs->type,$rs->hash);
|
||||
$logs = [$rs->type,$rs->hash];
|
||||
|
||||
$GLOBALS['core']->activityReport->addLog('kutrl','create',$logs);
|
||||
$GLOBALS['core']->activityReport->addLog('kutrl', 'create', $logs);
|
||||
}
|
||||
}
|
||||
?>
|
@ -22,7 +22,7 @@ class kutrlLog
|
||||
public function __construct($core)
|
||||
{
|
||||
$this->core = $core;
|
||||
$this->table = $core->prefix.'kutrl';
|
||||
$this->table = $core->prefix . 'kutrl';
|
||||
$this->blog = $core->con->escape($core->blog->id);
|
||||
$this->con = $core->con;
|
||||
}
|
||||
@ -30,11 +30,11 @@ class kutrlLog
|
||||
public function nextId()
|
||||
{
|
||||
return $this->con->select(
|
||||
'SELECT MAX(kut_id) FROM '.$this->table
|
||||
'SELECT MAX(kut_id) FROM ' . $this->table
|
||||
)->f(0) + 1;
|
||||
}
|
||||
|
||||
public function insert($url,$hash,$type,$service='kutrl')
|
||||
public function insert($url, $hash, $type, $service = 'kutrl')
|
||||
{
|
||||
$cur = $this->con->openCursor($this->table);
|
||||
$this->con->writeLock($this->table);
|
||||
@ -52,50 +52,47 @@ class kutrlLog
|
||||
$cur->insert();
|
||||
$this->con->unlock();
|
||||
|
||||
return array(
|
||||
return [
|
||||
'id' => $cur->kut_id,
|
||||
'url' => $url,
|
||||
'hash' => $hash,
|
||||
'type' => $type,
|
||||
'service' => $service,
|
||||
'counter '=> 0
|
||||
);
|
||||
}
|
||||
catch (Exception $e)
|
||||
{
|
||||
];
|
||||
} catch (Exception $e) {
|
||||
$this->con->unlock();
|
||||
throw $e;
|
||||
}
|
||||
return false;
|
||||
}
|
||||
|
||||
public function select($url=null,$hash=null,$type=null,$service='kutrl')
|
||||
public function select($url = null, $hash = null, $type =null, $service = 'kutrl')
|
||||
{
|
||||
//$this->con->writeLock($this->table);
|
||||
|
||||
$req =
|
||||
'SELECT kut_id as id, kut_hash as hash, kut_url as url, '.
|
||||
'kut_type as type, kut_service as service, kut_counter as counter '.
|
||||
'FROM '.$this->table.' '.
|
||||
"WHERE blog_id = '".$this->blog."' ".
|
||||
"AND kut_service = '".$this->con->escape($service)."' ";
|
||||
|
||||
if (null !== $url)
|
||||
$req .= "AND kut_url = '".$this->con->escape($url)."' ";
|
||||
|
||||
if (null !== $hash)
|
||||
$req .= "AND kut_hash = '".$this->con->escape($hash)."' ";
|
||||
'SELECT kut_id as id, kut_hash as hash, kut_url as url, ' .
|
||||
'kut_type as type, kut_service as service, kut_counter as counter ' .
|
||||
'FROM ' . $this->table . ' ' .
|
||||
"WHERE blog_id = '" . $this->blog . "' " .
|
||||
"AND kut_service = '" . $this->con->escape($service) . "' ";
|
||||
|
||||
if (null !== $url) {
|
||||
$req .= "AND kut_url = '" . $this->con->escape($url) . "' ";
|
||||
}
|
||||
if (null !== $hash) {
|
||||
$req .= "AND kut_hash = '" . $this->con->escape($hash) . "' ";
|
||||
}
|
||||
if (null !== $type) {
|
||||
if (is_array($type)) {
|
||||
$req .= "AND kut_type '".$this->con->in($type)."' ";
|
||||
}
|
||||
else {
|
||||
$req .= "AND kut_type = '".$this->con->escape($type)."' ";
|
||||
$req .= "AND kut_type '" . $this->con->in($type) ."' ";
|
||||
} else {
|
||||
$req .= "AND kut_type = '" . $this->con->escape($type) . "' ";
|
||||
}
|
||||
}
|
||||
|
||||
$req .= 'ORDER BY kut_dt DESC '.$this->con->limit(1);
|
||||
$req .= 'ORDER BY kut_dt DESC ' . $this->con->limit(1);
|
||||
|
||||
$rs = $this->con->select($req);
|
||||
//$this->con->unlock();
|
||||
@ -110,22 +107,19 @@ class kutrlLog
|
||||
$cur = $this->con->openCursor($this->table);
|
||||
$this->con->writeLock($this->table);
|
||||
|
||||
try
|
||||
{
|
||||
try {
|
||||
$cur->kut_url = '';
|
||||
$cur->kut_dt = date('Y-m-d H:i:s');
|
||||
$cur->kut_counter = 0;
|
||||
|
||||
$cur->update(
|
||||
"WHERE blog_id='".$this->blog."' ".
|
||||
"AND kut_id='".$id."' "
|
||||
"WHERE blog_id='" . $this->blog . "' " .
|
||||
"AND kut_id='" . $id . "' "
|
||||
);
|
||||
$this->con->unlock();
|
||||
|
||||
return true;
|
||||
}
|
||||
catch (Exception $e)
|
||||
{
|
||||
} catch (Exception $e) {
|
||||
$this->con->unlock();
|
||||
throw $e;
|
||||
}
|
||||
@ -137,39 +131,32 @@ class kutrlLog
|
||||
$id = (integer) $id;
|
||||
|
||||
return $this->con->execute(
|
||||
'DELETE FROM '.$this->table.' '.
|
||||
"WHERE blog_id='".$this->blog."' ".
|
||||
"AND kut_id='".$id."' "
|
||||
'DELETE FROM ' . $this->table . ' ' .
|
||||
"WHERE blog_id='" . $this->blog . "' " .
|
||||
"AND kut_id='" . $id . "' "
|
||||
);
|
||||
}
|
||||
|
||||
public function counter($id,$do='get')
|
||||
public function counter($id, $do = 'get')
|
||||
{
|
||||
$id = (integer) $id;
|
||||
|
||||
$rs = $this->con->select(
|
||||
'SELECT kut_counter '.
|
||||
'FROM '.$this->table.' '.
|
||||
"WHERE blog_id='".$this->blog."' ".
|
||||
"AND kut_id='".$id."' "
|
||||
'SELECT kut_counter ' .
|
||||
'FROM ' . $this->table . ' ' .
|
||||
"WHERE blog_id='" . $this->blog . "' " .
|
||||
"AND kut_id='" . $id . "' "
|
||||
);
|
||||
|
||||
$counter = $rs->isEmpty() ? 0 : $rs->kut_counter;
|
||||
|
||||
if ('get' == $do)
|
||||
{
|
||||
if ('get' == $do) {
|
||||
return $counter;
|
||||
}
|
||||
elseif ('up' == $do)
|
||||
{
|
||||
} elseif ('up' == $do) {
|
||||
$counter += 1;
|
||||
}
|
||||
elseif ('reset' == $do)
|
||||
{
|
||||
} elseif ('reset' == $do) {
|
||||
$counter = 0;
|
||||
}
|
||||
else
|
||||
{
|
||||
} else {
|
||||
return 0;
|
||||
}
|
||||
|
||||
@ -178,137 +165,93 @@ class kutrlLog
|
||||
|
||||
$cur->kut_counter = (integer) $counter;
|
||||
$cur->update(
|
||||
"WHERE blog_id='".$this->blog."' ".
|
||||
"AND kut_id='".$id."'"
|
||||
"WHERE blog_id='" . $this->blog . "' " .
|
||||
"AND kut_id='" . $id . "'"
|
||||
);
|
||||
$this->con->unlock();
|
||||
|
||||
return $counter;
|
||||
}
|
||||
|
||||
public function getLogs($p,$count_only=false)
|
||||
{
|
||||
if ($count_only)
|
||||
public function getLogs($p, $count_only = false)
|
||||
{
|
||||
if ($count_only) {
|
||||
$r = 'SELECT count(S.kut_id) ';
|
||||
}
|
||||
else
|
||||
{
|
||||
} else {
|
||||
$content_req = '';
|
||||
|
||||
if (!empty($p['columns']) && is_array($p['columns']))
|
||||
{
|
||||
$content_req .= implode(', ',$p['columns']).', ';
|
||||
if (!empty($p['columns']) && is_array($p['columns'])) {
|
||||
$content_req .= implode(', ', $p['columns']) . ', ';
|
||||
}
|
||||
$r =
|
||||
'SELECT S.kut_id, S.kut_type, S.kut_hash, S.kut_url, '.
|
||||
$content_req.'S.kut_dt ';
|
||||
'SELECT S.kut_id, S.kut_type, S.kut_hash, S.kut_url, ' .
|
||||
$content_req . 'S.kut_dt ';
|
||||
}
|
||||
|
||||
$r .= 'FROM '.$this->table.' S ';
|
||||
|
||||
if (!empty($p['from']))
|
||||
{
|
||||
$r .= $p['from'].' ';
|
||||
$r .= 'FROM ' . $this->table . ' S ';
|
||||
if (!empty($p['from'])) {
|
||||
$r .= $p['from'] . ' ';
|
||||
}
|
||||
$r .= "WHERE S.blog_id = '".$this->blog."' ";
|
||||
|
||||
if (isset($p['kut_service']))
|
||||
{
|
||||
$r .= "AND kut_service='".$this->con->escape($p['kut_service'])."' ";
|
||||
}
|
||||
else
|
||||
{
|
||||
$r .= "WHERE S.blog_id = '" . $this->blog . "' ";
|
||||
if (isset($p['kut_service'])) {
|
||||
$r .= "AND kut_service='" . $this->con->escape($p['kut_service']) . "' ";
|
||||
} else {
|
||||
$r .= "AND kut_service='kutrl' ";
|
||||
}
|
||||
|
||||
if (isset($p['kut_type']))
|
||||
{
|
||||
if (isset($p['kut_type'])) {
|
||||
if (is_array($p['kut_type']) && !empty($p['kut_type']))
|
||||
{
|
||||
$r .= 'AND kut_type '.$this->con->in($p['kut_type']);
|
||||
}
|
||||
elseif ($p['kut_type'] != '')
|
||||
{
|
||||
$r .= "AND kut_type = '".$this->con->escape($p['kut_type'])."' ";
|
||||
$r .= 'AND kut_type ' . $this->con->in($p['kut_type']);
|
||||
} elseif ($p['kut_type'] != '') {
|
||||
$r .= "AND kut_type = '" . $this->con->escape($p['kut_type']) . "' ";
|
||||
}
|
||||
}
|
||||
|
||||
if (isset($p['kut_id']))
|
||||
{
|
||||
if (is_array($p['kut_id']) && !empty($p['kut_id']))
|
||||
{
|
||||
$r .= 'AND kut_id '.$this->con->in($p['kut_id']);
|
||||
}
|
||||
elseif ($p['kut_id'] != '')
|
||||
{
|
||||
$r .= "AND kut_id = '".$this->con->escape($p['kut_id'])."' ";
|
||||
if (isset($p['kut_id'])) {
|
||||
if (is_array($p['kut_id']) && !empty($p['kut_id'])) {
|
||||
$r .= 'AND kut_id ' . $this->con->in($p['kut_id']);
|
||||
} elseif ($p['kut_id'] != '') {
|
||||
$r .= "AND kut_id = '" . $this->con->escape($p['kut_id']) . "' ";
|
||||
}
|
||||
}
|
||||
|
||||
if (isset($p['kut_hash']))
|
||||
{
|
||||
if (is_array($p['kut_hash']) && !empty($p['kut_hash']))
|
||||
{
|
||||
$r .= 'AND kut_hash '.$this->con->in($p['kut_hash']);
|
||||
}
|
||||
elseif ($p['kut_hash'] != '')
|
||||
{
|
||||
$r .= "AND kut_hash = '".$this->con->escape($p['kut_hash'])."' ";
|
||||
if (isset($p['kut_hash'])) {
|
||||
if (is_array($p['kut_hash']) && !empty($p['kut_hash'])) {
|
||||
$r .= 'AND kut_hash ' . $this->con->in($p['kut_hash']);
|
||||
} elseif ($p['kut_hash'] != '') {
|
||||
$r .= "AND kut_hash = '" . $this->con->escape($p['kut_hash']) . "' ";
|
||||
}
|
||||
}
|
||||
|
||||
if (isset($p['kut_url']))
|
||||
{
|
||||
if (is_array($p['kut_url']) && !empty($p['kut_url']))
|
||||
{
|
||||
$r .= 'AND kut_url '.$this->con->in($p['kut_url']);
|
||||
}
|
||||
elseif ($p['kut_url'] != '')
|
||||
{
|
||||
$r .= "AND kut_url = '".$this->con->escape($p['kut_url'])."' ";
|
||||
if (isset($p['kut_url'])) {
|
||||
if (is_array($p['kut_url']) && !empty($p['kut_url'])) {
|
||||
$r .= 'AND kut_url ' . $this->con->in($p['kut_url']);
|
||||
} elseif ($p['kut_url'] != '') {
|
||||
$r .= "AND kut_url = '" . $this->con->escape($p['kut_url']) . "' ";
|
||||
}
|
||||
}
|
||||
|
||||
if (!empty($p['kut_year']))
|
||||
{
|
||||
if (!empty($p['kut_year'])) {
|
||||
$r .=
|
||||
'AND '.$this->con->dateFormat('kut_dt','%Y').' = '.
|
||||
"'".sprintf('%04d',$p['kut_year'])."' ";
|
||||
'AND ' . $this->con->dateFormat('kut_dt', '%Y') . ' = ' .
|
||||
"'" . sprintf('%04d', $p['kut_year']) . "' ";
|
||||
}
|
||||
|
||||
if (!empty($p['kut_month']))
|
||||
{
|
||||
if (!empty($p['kut_month'])) {
|
||||
$r .=
|
||||
'AND '.$this->con->dateFormat('kut_dt','%m').' = '.
|
||||
"'".sprintf('%02d',$p['kut_month'])."' ";
|
||||
'AND ' . $this->con->dateFormat('kut_dt', '%m') . ' = ' .
|
||||
"'" . sprintf('%02d', $p['kut_month']) . "' ";
|
||||
}
|
||||
|
||||
if (!empty($p['kut_day']))
|
||||
{
|
||||
if (!empty($p['kut_day'])) {
|
||||
$r .=
|
||||
'AND '.$this->con->dateFormat('kut_dt','%d').' = '.
|
||||
"'".sprintf('%02d',$p['kut_day'])."' ";
|
||||
'AND ' . $this->con->dateFormat('kut_dt', '%d') . ' = ' .
|
||||
"'" . sprintf('%02d', $p['kut_day']) . "' ";
|
||||
}
|
||||
|
||||
if (!empty($p['sql']))
|
||||
{
|
||||
$r .= $p['sql'].' ';
|
||||
if (!empty($p['sql'])) {
|
||||
$r .= $p['sql'] . ' ';
|
||||
}
|
||||
|
||||
if (!$count_only)
|
||||
{
|
||||
if (!$count_only) {
|
||||
$r .= empty($p['order']) ?
|
||||
'ORDER BY kut_dt DESC ' :
|
||||
'ORDER BY '.$this->con->escape($p['order']).' ';
|
||||
'ORDER BY ' . $this->con->escape($p['order']) . ' ';
|
||||
}
|
||||
|
||||
if (!$count_only && !empty($p['limit']))
|
||||
{
|
||||
if (!$count_only && !empty($p['limit'])) {
|
||||
$r .= $this->con->limit($p['limit']);
|
||||
}
|
||||
|
||||
return $this->con->select($r);
|
||||
}
|
||||
}
|
||||
?>
|
@ -27,7 +27,7 @@ class kutrlService
|
||||
$this->settings = $core->blog->settings->kUtRL;
|
||||
$this->log = new kutrlLog($core);
|
||||
$this->error = new dcError();
|
||||
$this->error->setHTMLFormat('%s',"%s\n");
|
||||
$this->error->setHTMLFormat('%s', "%s\n");
|
||||
|
||||
$this->init();
|
||||
|
||||
@ -37,20 +37,20 @@ class kutrlService
|
||||
true : $allow_external_url;
|
||||
|
||||
$this->config = array_merge(
|
||||
array(
|
||||
[
|
||||
'id' => 'undefined',
|
||||
'name' => 'undefined',
|
||||
'home' => '',
|
||||
|
||||
'allow_external_url' => true,
|
||||
'allow_custom_hash' => false,
|
||||
'allow_protocols' => array('http://'),
|
||||
'allow_protocols' => ['http://'],
|
||||
|
||||
'url_test' => 'http://dotclear.jcdenis.com/go/kUtRL',
|
||||
'url_api' => '',
|
||||
'url_base' => '',
|
||||
'url_min_len' => 0
|
||||
),
|
||||
],
|
||||
$this->config
|
||||
);
|
||||
}
|
||||
@ -77,8 +77,8 @@ class kutrlService
|
||||
public function settingsForm()
|
||||
{
|
||||
echo
|
||||
'<p class="form-note">'.
|
||||
__('There is nothing to configure for this service.').
|
||||
'<p class="form-note">' .
|
||||
__('There is nothing to configure for this service.') .
|
||||
'</p>';
|
||||
}
|
||||
|
||||
@ -91,13 +91,13 @@ class kutrlService
|
||||
# Test if an url is valid
|
||||
public function isValidUrl($url)
|
||||
{
|
||||
return (boolean) filter_var($url,FILTER_VALIDATE_URL);
|
||||
return (boolean) filter_var($url, FILTER_VALIDATE_URL);
|
||||
}
|
||||
|
||||
# Test if an url contents know prefix
|
||||
public function isServiceUrl($url)
|
||||
{
|
||||
return strpos($url,$this->url_base) === 0;
|
||||
return strpos($url, $this->url_base) === 0;
|
||||
}
|
||||
|
||||
# Test if an url is long enoutgh
|
||||
@ -109,11 +109,13 @@ class kutrlService
|
||||
# Test if an url protocol (eg: http://) is allowed
|
||||
public function isProtocolUrl($url)
|
||||
{
|
||||
foreach($this->allow_protocols as $protocol)
|
||||
{
|
||||
if (empty($protocol)) continue;
|
||||
|
||||
if (strpos($url,$protocol) === 0) return true;
|
||||
foreach($this->allow_protocols as $protocol) {
|
||||
if (empty($protocol)) {
|
||||
continue;
|
||||
}
|
||||
if (strpos($url,$protocol) === 0) {
|
||||
return true;
|
||||
}
|
||||
}
|
||||
return false;
|
||||
}
|
||||
@ -122,7 +124,7 @@ class kutrlService
|
||||
public function isBlogUrl($url)
|
||||
{
|
||||
$base = $this->core->blog->url;
|
||||
$url = substr($url,0,strlen($base));
|
||||
$url = substr($url, 0, strlen($base));
|
||||
|
||||
return $url == $base;
|
||||
}
|
||||
@ -130,64 +132,54 @@ class kutrlService
|
||||
# Test if an url is know
|
||||
public function isKnowUrl($url)
|
||||
{
|
||||
return $this->log->select($url,null,$this->id,'kutrl');
|
||||
return $this->log->select($url, null, $this->id, 'kutrl');
|
||||
}
|
||||
|
||||
# Test if an custom short url is know
|
||||
public function isKnowHash($hash)
|
||||
{
|
||||
return $this->log->select(null,$hash,$this->id,'kutrl');
|
||||
return $this->log->select(null, $hash, $this->id, 'kutrl');
|
||||
}
|
||||
|
||||
# Create hash from url
|
||||
public function hash($url,$hash=null)
|
||||
public function hash($url, $hash = null)
|
||||
{
|
||||
$url = trim($this->core->con->escape($url));
|
||||
if ('undefined' === $this->id)
|
||||
{
|
||||
if ('undefined' === $this->id) {
|
||||
return false;
|
||||
}
|
||||
if ($hash && !$this->allow_custom_hash)
|
||||
{
|
||||
if ($hash && !$this->allow_custom_hash) {
|
||||
return false;
|
||||
}
|
||||
if ($this->isServiceUrl($url))
|
||||
{
|
||||
if ($this->isServiceUrl($url)) {
|
||||
return false;
|
||||
}
|
||||
if (!$this->isLongerUrl($url))
|
||||
{
|
||||
if (!$this->isLongerUrl($url)) {
|
||||
return false;
|
||||
}
|
||||
if (!$this->allow_external_url && $this->isBlogUrl($url))
|
||||
{
|
||||
if (!$this->allow_external_url && $this->isBlogUrl($url)) {
|
||||
return false;
|
||||
}
|
||||
if ($hash && false !== ($rs = $this->isKnowHash($hash)))
|
||||
{
|
||||
if ($hash && false !== ($rs = $this->isKnowHash($hash))) {
|
||||
return false;
|
||||
}
|
||||
if (false === ($rs = $this->isKnowUrl($url)))
|
||||
{
|
||||
if (false === ($rs = $this->createHash($url,$hash)))
|
||||
{
|
||||
if (false === ($rs = $this->isKnowUrl($url))) {
|
||||
if (false === ($rs = $this->createHash($url, $hash))) {
|
||||
return false;
|
||||
}
|
||||
|
||||
$this->log->insert($rs->url,$rs->hash,$rs->type,'kutrl');
|
||||
$this->log->insert($rs->url, $rs->hash, $rs->type, 'kutrl');
|
||||
$this->core->blog->triggerBlog();
|
||||
|
||||
|
||||
# --BEHAVIOR-- kutrlAfterCreateShortUrl
|
||||
$this->core->callBehavior('kutrlAfterCreateShortUrl',$rs);
|
||||
|
||||
$this->core->callBehavior('kutrlAfterCreateShortUrl', $rs);
|
||||
|
||||
}
|
||||
return $rs;
|
||||
}
|
||||
|
||||
# Create a hash for a given url (and its custom hash)
|
||||
public function createHash($url,$hash=null)
|
||||
public function createHash($url, $hash = null)
|
||||
{
|
||||
return false;
|
||||
}
|
||||
@ -195,15 +187,16 @@ class kutrlService
|
||||
# Remove an url from list of know urls
|
||||
public function remove($url)
|
||||
{
|
||||
if (!($rs = $this->isKnowUrl($url))) return false;
|
||||
echo 'la';
|
||||
if (!($rs = $this->isKnowUrl($url))) {
|
||||
return false;
|
||||
}
|
||||
$this->deleteUrl($url);
|
||||
$this->log->delete($rs->id);
|
||||
return true;
|
||||
}
|
||||
|
||||
# Delete url on service (second argument really delete urls)
|
||||
public function deleteUrl($url,$delete=false)
|
||||
public function deleteUrl($url, $delete = false)
|
||||
{
|
||||
return null;
|
||||
}
|
||||
@ -215,40 +208,29 @@ class kutrlService
|
||||
}
|
||||
|
||||
# Post request
|
||||
public static function post($server,$data,$verbose=true,$get=false,$headers=array())
|
||||
public static function post($server, $data, $verbose = true, $get = false, $headers = [])
|
||||
{
|
||||
$url = (string) $server;
|
||||
$client = netHttp::initClient($url,$url);
|
||||
$client = netHttp::initClient($url, $url);
|
||||
$client->setUserAgent('kUtRL - http://kutrl.fr');
|
||||
$client->setPersistReferers(false);
|
||||
|
||||
if (is_array($headers) && !empty($headers))
|
||||
{
|
||||
foreach($headers as $header)
|
||||
{
|
||||
if (is_array($headers) && !empty($headers)) {
|
||||
foreach($headers as $header) {
|
||||
$client->setMoreHeader($header);
|
||||
}
|
||||
}
|
||||
|
||||
if ($get)
|
||||
{
|
||||
$client->get($url,$data);
|
||||
if ($get) {
|
||||
$client->get($url, $data);
|
||||
} else {
|
||||
$client->post($url, $data);
|
||||
}
|
||||
else
|
||||
{
|
||||
$client->post($url,$data);
|
||||
}
|
||||
|
||||
if (!$verbose && $client->getStatus() != 200)
|
||||
{
|
||||
if (!$verbose && $client->getStatus() != 200) {
|
||||
return false;
|
||||
}
|
||||
|
||||
if ($verbose)
|
||||
{
|
||||
if ($verbose) {
|
||||
return $client->getContent();
|
||||
}
|
||||
return true;
|
||||
}
|
||||
}
|
||||
?>
|
@ -12,7 +12,9 @@
|
||||
|
||||
# This file contents class to shorten url pass through wiki
|
||||
|
||||
if (!defined('DC_RC_PATH')){return;}
|
||||
if (!defined('DC_RC_PATH')) {
|
||||
return null;
|
||||
}
|
||||
|
||||
class kutrlWiki
|
||||
{
|
||||
@ -24,57 +26,52 @@ class kutrlWiki
|
||||
# Do nothing on comment preview and post preview
|
||||
if (!empty($_POST['preview'])
|
||||
|| !empty($GLOBALS['_ctx']) && $GLOBALS['_ctx']->preview
|
||||
|| !$s->kutrl_active) return;
|
||||
|
||||
if (null === ($kut = kutrl::quickPlace('wiki'))) return;
|
||||
|
||||
foreach($kut->allow_protocols as $protocol)
|
||||
{
|
||||
|| !$s->kutrl_active) {
|
||||
return null;
|
||||
}
|
||||
if (null === ($kut = kutrl::quickPlace('wiki'))) {
|
||||
return null;
|
||||
}
|
||||
foreach($kut->allow_protocols as $protocol) {
|
||||
$wiki2xhtml->registerFunction(
|
||||
'url:'.$protocol,
|
||||
array('kutrlWiki','transform')
|
||||
'url:' . $protocol,
|
||||
['kutrlWiki', 'transform']
|
||||
);
|
||||
}
|
||||
}
|
||||
|
||||
public static function transform($url,$content)
|
||||
public static function transform($url, $content)
|
||||
{
|
||||
global $core;
|
||||
$s = $core->blog->settings->kUtRL;
|
||||
|
||||
if (!$s->kutrl_active) return;
|
||||
|
||||
if (null === ($kut = kutrl::quickPlace('wiki'))) return array();
|
||||
|
||||
if (!$s->kutrl_active) {
|
||||
return null;
|
||||
}
|
||||
if (null === ($kut = kutrl::quickPlace('wiki'))) {
|
||||
return [];
|
||||
}
|
||||
# Test if long url exists
|
||||
$is_new = false;
|
||||
$rs = $kut->isKnowUrl($url);
|
||||
if (!$rs)
|
||||
{
|
||||
if (!$rs) {
|
||||
$is_new = true;
|
||||
$rs = $kut->hash($url);
|
||||
}
|
||||
|
||||
if (!$rs)
|
||||
{
|
||||
return array();
|
||||
}
|
||||
else
|
||||
{
|
||||
$res = array();
|
||||
$testurl = strlen($rs->url) > 35 ? substr($rs->url,0,35).'...' : $rs->url;
|
||||
$res['url'] = $kut->url_base.$rs->hash;
|
||||
$res['title'] = sprintf(__('%s (Shorten with %s)'),$rs->url,__($kut->name));
|
||||
if (!$rs) {
|
||||
return [];
|
||||
} else {
|
||||
$res = [];
|
||||
$testurl = strlen($rs->url) > 35 ? substr($rs->url, 0, 35) . '...' : $rs->url;
|
||||
$res['url'] = $kut->url_base . $rs->hash;
|
||||
$res['title'] = sprintf(__('%s (Shorten with %s)'), $rs->url, __($kut->name));
|
||||
if ($testurl == $content) $res['content'] = $res['url'];
|
||||
|
||||
# ex: Send new url to messengers
|
||||
if (!empty($rs))
|
||||
{
|
||||
$core->callBehavior('wikiAfterKutrlCreate',$core,$rs,__('New short URL'));
|
||||
if (!empty($rs)) {
|
||||
$core->callBehavior('wikiAfterKutrlCreate', $core, $rs, __('New short URL'));
|
||||
}
|
||||
|
||||
return $res;
|
||||
}
|
||||
}
|
||||
}
|
||||
?>
|
Loading…
Reference in New Issue
Block a user