2016-08-17 22:16:13 -04:00
|
|
|
<?php
|
|
|
|
|
2016-08-24 21:17:58 -04:00
|
|
|
namespace Miniflux\Helper;
|
2016-08-17 22:16:13 -04:00
|
|
|
|
2016-12-27 21:12:19 -05:00
|
|
|
use PicoDb\Database;
|
2016-12-26 09:44:53 -05:00
|
|
|
use PicoFeed\Logging\Logger;
|
|
|
|
|
2016-08-17 22:16:13 -04:00
|
|
|
function escape($value)
|
|
|
|
{
|
|
|
|
return htmlspecialchars($value, ENT_QUOTES, 'UTF-8', false);
|
|
|
|
}
|
|
|
|
|
|
|
|
function generate_token()
|
|
|
|
{
|
|
|
|
if (function_exists('random_bytes')) {
|
|
|
|
return bin2hex(random_bytes(30));
|
|
|
|
} elseif (function_exists('openssl_random_pseudo_bytes')) {
|
|
|
|
return bin2hex(openssl_random_pseudo_bytes(30));
|
|
|
|
} elseif (ini_get('open_basedir') === '' && strtoupper(substr(PHP_OS, 0, 3)) !== 'WIN') {
|
|
|
|
return hash('sha256', file_get_contents('/dev/urandom', false, null, 0, 30));
|
|
|
|
}
|
|
|
|
|
|
|
|
return hash('sha256', uniqid(mt_rand(), true));
|
|
|
|
}
|
|
|
|
|
|
|
|
function parse_app_version($refnames, $commithash)
|
|
|
|
{
|
|
|
|
$version = 'master';
|
|
|
|
|
|
|
|
if ($refnames !== '$Format:%d$') {
|
|
|
|
$tag = preg_replace('/\s*\(.*tag:\sv([^,]+).*\)/i', '\1', $refnames);
|
|
|
|
|
|
|
|
if ($tag !== null && $tag !== $refnames) {
|
|
|
|
return $tag;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
if ($commithash !== '$Format:%H$') {
|
|
|
|
$version .= '.'.$commithash;
|
|
|
|
}
|
|
|
|
|
|
|
|
return $version;
|
|
|
|
}
|
|
|
|
|
|
|
|
function get_current_base_url()
|
|
|
|
{
|
2017-01-22 03:11:03 +11:00
|
|
|
if(BASE_URL) {
|
|
|
|
$url = BASE_URL;
|
|
|
|
return rtrim($url, '/') . '/';
|
|
|
|
} else {
|
|
|
|
$url = is_secure_connection() ? 'https://' : 'http://';
|
|
|
|
$url .= $_SERVER['HTTP_HOST'];
|
|
|
|
|
|
|
|
if (strpos($_SERVER['HTTP_HOST'], ':') === false) {
|
|
|
|
$url .= $_SERVER['SERVER_PORT'] == 80 || $_SERVER['SERVER_PORT'] == 443 ? '' : ':'.$_SERVER['SERVER_PORT'];
|
|
|
|
}
|
|
|
|
$url .= str_replace('\\', '/', dirname($_SERVER['PHP_SELF'])) !== '/' ? str_replace('\\', '/', dirname($_SERVER['PHP_SELF'])).'/' : '/';
|
2016-12-26 09:44:53 -05:00
|
|
|
|
2017-01-22 03:11:03 +11:00
|
|
|
return $url;
|
2016-12-26 09:44:53 -05:00
|
|
|
}
|
2016-08-17 22:16:13 -04:00
|
|
|
}
|
|
|
|
|
|
|
|
function is_secure_connection()
|
|
|
|
{
|
|
|
|
return ! empty($_SERVER['HTTPS']) && $_SERVER['HTTPS'] !== 'off';
|
|
|
|
}
|
2016-12-26 09:44:53 -05:00
|
|
|
|
|
|
|
function write_debug_file() {
|
|
|
|
if (DEBUG_MODE) {
|
2016-12-27 21:12:19 -05:00
|
|
|
$feed_logs = Logger::getMessages();
|
|
|
|
$db_logs = Database::getInstance('db')->getLogMessages();
|
2016-12-27 21:34:28 -05:00
|
|
|
file_put_contents(DEBUG_FILENAME, implode(PHP_EOL, $feed_logs + $db_logs), FILE_APPEND|LOCK_EX);
|
2016-12-26 09:44:53 -05:00
|
|
|
}
|
|
|
|
}
|