2013-06-03 17:05:59 +02:00
|
|
|
<?php
|
2013-06-07 13:29:11 +02:00
|
|
|
|
2013-06-27 13:46:01 +02:00
|
|
|
// TODO: Search for the best and safest quoting
|
|
|
|
// TODO: Check whether attributes are safe. Script, title in combination with
|
|
|
|
// Hover-Tips etc. Eventually create a whitelist for a few options only.
|
|
|
|
use Icinga\Web\Url;
|
2013-06-03 17:05:59 +02:00
|
|
|
|
|
|
|
class Zend_View_Helper_Qlink extends Zend_View_Helper_Abstract
|
|
|
|
{
|
2013-06-27 13:46:01 +02:00
|
|
|
|
|
|
|
public function qlink($htmlContent, $urlFormat, array $uriParams = array(),
|
|
|
|
array $properties = array())
|
|
|
|
{
|
2013-06-03 17:05:59 +02:00
|
|
|
$quote = true;
|
|
|
|
$attributes = array();
|
|
|
|
$baseUrl = null;
|
|
|
|
foreach ($properties as $key => $val) {
|
2013-06-27 13:46:01 +02:00
|
|
|
if ($key === 'baseUrl' ) {
|
2013-06-03 17:05:59 +02:00
|
|
|
// $baseUrl = filter_var($val, FILTER_SANITIZE_URL) . '/';
|
2013-06-27 13:46:01 +02:00
|
|
|
$baseUrl = $val; //rawurlencode($val) . '/';
|
2013-06-03 17:05:59 +02:00
|
|
|
continue;
|
|
|
|
}
|
|
|
|
if ($key === 'quote') {
|
|
|
|
$quote = $val;
|
|
|
|
continue;
|
|
|
|
}
|
2013-06-20 14:02:58 +02:00
|
|
|
if ($key === 'target') {
|
|
|
|
$attibutes[] = 'target="'.$val.'"';
|
|
|
|
}
|
2013-06-03 17:05:59 +02:00
|
|
|
if ($key === 'style' && is_array($val)) {
|
|
|
|
if (empty($val)) {
|
|
|
|
continue;
|
|
|
|
}
|
|
|
|
$parts = array();
|
|
|
|
foreach ($val as $k => $v) {
|
|
|
|
$parts[] = "$k: $v";
|
|
|
|
}
|
|
|
|
$attributes[] = 'style="' . implode('; ', $parts) . '"';
|
|
|
|
continue;
|
|
|
|
}
|
|
|
|
$attributes[] = sprintf(
|
|
|
|
'%s="%s"',
|
|
|
|
//filter_var($key, FILTER_SANITIZE_URL),
|
|
|
|
rawurlencode($key),
|
|
|
|
//filter_var($val, FILTER_SANITIZE_FULL_SPECIAL_CHARS)
|
|
|
|
rawurlencode($val)
|
|
|
|
);
|
|
|
|
|
|
|
|
}
|
2013-06-27 13:46:01 +02:00
|
|
|
if ($urlFormat instanceof Url) {
|
|
|
|
$url = $urlFormat;
|
|
|
|
$uriParams = $url->getParams() + $uriParams;
|
|
|
|
} else {
|
|
|
|
$url = Url::create($urlFormat);
|
|
|
|
}
|
|
|
|
$url->setParams($uriParams)->setBaseUrl($baseUrl);
|
2013-06-03 17:05:59 +02:00
|
|
|
return sprintf(
|
|
|
|
'<a href="%s"%s>%s</a>',
|
2013-06-27 13:46:01 +02:00
|
|
|
// $this->getFormattedUrl($urlFormat, $uriParams, $baseUrl),
|
|
|
|
$url,
|
2013-06-03 17:05:59 +02:00
|
|
|
!empty($attributes) ? ' ' . implode(' ', $attributes) : '',
|
2013-06-27 13:46:01 +02:00
|
|
|
$quote
|
|
|
|
? filter_var(
|
2013-06-03 17:05:59 +02:00
|
|
|
$htmlContent,
|
|
|
|
FILTER_SANITIZE_FULL_SPECIAL_CHARS,
|
|
|
|
FILTER_FLAG_NO_ENCODE_QUOTES
|
2013-06-27 13:46:01 +02:00
|
|
|
)
|
|
|
|
// Alternativ: htmlentities($htmlContent)
|
|
|
|
: $htmlContent
|
2013-06-03 17:05:59 +02:00
|
|
|
);
|
|
|
|
}
|
2013-06-27 13:46:01 +02:00
|
|
|
/*
|
2013-06-03 17:05:59 +02:00
|
|
|
public function getFormattedUrl($urlFormat, $uriParams, $baseUrl = null)
|
|
|
|
{
|
|
|
|
$params = $args = array();
|
|
|
|
foreach ($uriParams as $name => $value) {
|
|
|
|
if (is_int($name)) {
|
|
|
|
$params[] = rawurlencode($value);
|
|
|
|
} else {
|
|
|
|
$args[] = rawurlencode($name) . '=' . rawurlencode($value);
|
|
|
|
}
|
|
|
|
}
|
|
|
|
$url = $urlFormat;
|
|
|
|
$url = vsprintf($url, $params);
|
2013-06-27 13:46:01 +02:00
|
|
|
if (! empty($args)) {
|
2013-06-03 17:05:59 +02:00
|
|
|
$url .= '?' . implode('&', $args);
|
|
|
|
}
|
2013-06-27 13:46:01 +02:00
|
|
|
return is_null($baseUrl) ? $this->view->baseUrl($url) : $baseUrl.$url;
|
2013-06-03 17:05:59 +02:00
|
|
|
}
|
2013-06-27 13:46:01 +02:00
|
|
|
*/
|
2013-06-03 17:05:59 +02:00
|
|
|
}
|
2013-06-27 13:46:01 +02:00
|
|
|
|