2016-08-29 23:31:43 +08:00
|
|
|
<?php
|
|
|
|
|
2018-08-17 21:41:11 +08:00
|
|
|
use Carbon\Carbon;
|
2017-01-08 14:15:55 +08:00
|
|
|
use App\Models\User;
|
2016-09-30 16:31:45 +08:00
|
|
|
use Illuminate\Support\Arr;
|
2016-09-14 22:44:30 +08:00
|
|
|
|
2018-08-08 18:17:11 +08:00
|
|
|
if (! function_exists('webpack_assets')) {
|
|
|
|
function webpack_assets($relativeUri)
|
|
|
|
{
|
|
|
|
if (app()->environment('development')) {
|
2019-04-07 08:54:54 +08:00
|
|
|
return "http://127.0.0.1:8080/$relativeUri"; // @codeCoverageIgnore
|
2018-08-08 18:17:11 +08:00
|
|
|
} else {
|
2019-03-31 14:38:17 +08:00
|
|
|
$path = app('webpack')->$relativeUri;
|
2019-03-16 19:56:50 +08:00
|
|
|
$cdn = option('cdn_address');
|
2019-04-19 19:36:36 +08:00
|
|
|
|
2019-03-31 14:38:17 +08:00
|
|
|
return $cdn ? "$cdn/app/$path" : url("/app/$path");
|
2018-08-08 18:17:11 +08:00
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2017-01-08 16:05:54 +08:00
|
|
|
if (! function_exists('plugin')) {
|
|
|
|
|
2017-11-16 10:09:58 +08:00
|
|
|
/**
|
|
|
|
* @param string $id
|
|
|
|
* @return \App\Services\Plugin
|
|
|
|
*/
|
2017-01-08 16:05:54 +08:00
|
|
|
function plugin($id)
|
|
|
|
{
|
|
|
|
return app('plugins')->getPlugin($id);
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2016-12-31 16:07:12 +08:00
|
|
|
if (! function_exists('plugin_assets')) {
|
2017-01-08 16:05:54 +08:00
|
|
|
function plugin_assets($id, $relativeUri)
|
2016-12-31 16:07:12 +08:00
|
|
|
{
|
2017-01-08 16:05:54 +08:00
|
|
|
if ($plugin = plugin($id)) {
|
|
|
|
return $plugin->assets($relativeUri);
|
2016-12-31 16:07:12 +08:00
|
|
|
} else {
|
2019-03-02 22:58:37 +08:00
|
|
|
throw new InvalidArgumentException('No such plugin.');
|
2016-12-31 16:07:12 +08:00
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2016-09-10 21:39:45 +08:00
|
|
|
if (! function_exists('json')) {
|
|
|
|
function json()
|
|
|
|
{
|
|
|
|
$args = func_get_args();
|
|
|
|
|
|
|
|
if (count($args) == 1 && is_array($args[0])) {
|
|
|
|
return Response::json($args[0]);
|
2016-09-30 16:31:45 +08:00
|
|
|
} elseif (count($args) == 3 && is_array($args[2])) {
|
2018-02-16 17:31:04 +08:00
|
|
|
// The third argument is array of extra fields
|
2019-04-23 19:14:41 +08:00
|
|
|
return Response::json([
|
2019-04-23 11:47:45 +08:00
|
|
|
'code' => $args[1],
|
|
|
|
'message' => $args[0],
|
2019-04-23 19:14:41 +08:00
|
|
|
'data' => $args[2],
|
|
|
|
]);
|
2016-09-30 16:31:45 +08:00
|
|
|
} else {
|
|
|
|
return Response::json([
|
2019-04-23 11:47:45 +08:00
|
|
|
'code' => Arr::get($args, 1, 1),
|
|
|
|
'message' => $args[0],
|
2016-09-10 21:39:45 +08:00
|
|
|
]);
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
2016-09-15 11:04:08 +08:00
|
|
|
|
2017-07-03 20:54:19 +08:00
|
|
|
if (! function_exists('bs_footer_extra')) {
|
|
|
|
function bs_footer_extra()
|
2016-09-15 11:04:08 +08:00
|
|
|
{
|
2017-01-20 18:17:56 +08:00
|
|
|
$extraContents = [];
|
2016-12-10 19:36:01 +08:00
|
|
|
|
2019-02-27 23:44:50 +08:00
|
|
|
Event::dispatch(new App\Events\RenderingFooter($extraContents));
|
2016-12-10 19:36:01 +08:00
|
|
|
|
2017-07-03 20:54:19 +08:00
|
|
|
return implode("\n", $extraContents);
|
2016-09-15 11:04:08 +08:00
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2017-07-03 20:54:19 +08:00
|
|
|
if (! function_exists('bs_header_extra')) {
|
|
|
|
function bs_header_extra()
|
2016-09-15 11:04:08 +08:00
|
|
|
{
|
2017-01-20 18:17:56 +08:00
|
|
|
$extraContents = [];
|
2016-12-10 19:36:01 +08:00
|
|
|
|
2019-02-27 23:44:50 +08:00
|
|
|
Event::dispatch(new App\Events\RenderingHeader($extraContents));
|
2016-12-10 19:36:01 +08:00
|
|
|
|
2017-07-03 20:54:19 +08:00
|
|
|
return implode("\n", $extraContents);
|
2016-09-15 11:04:08 +08:00
|
|
|
}
|
|
|
|
}
|
2016-09-15 20:35:46 +08:00
|
|
|
|
|
|
|
if (! function_exists('bs_menu')) {
|
2016-09-30 17:00:41 +08:00
|
|
|
function bs_menu($type)
|
2016-09-15 20:35:46 +08:00
|
|
|
{
|
2016-11-21 21:50:24 +08:00
|
|
|
$menu = config('menu');
|
2016-09-15 20:35:46 +08:00
|
|
|
|
2019-04-25 23:24:24 +08:00
|
|
|
switch ($type) {
|
|
|
|
case 'user':
|
|
|
|
event(new App\Events\ConfigureUserMenu($menu));
|
|
|
|
break;
|
|
|
|
case 'admin':
|
|
|
|
event(new App\Events\ConfigureAdminMenu($menu));
|
|
|
|
break;
|
|
|
|
}
|
2016-10-25 22:47:50 +08:00
|
|
|
|
2018-02-16 17:31:04 +08:00
|
|
|
if (! isset($menu[$type])) {
|
2016-09-15 20:35:46 +08:00
|
|
|
throw new InvalidArgumentException;
|
|
|
|
}
|
|
|
|
|
2018-02-23 18:12:12 +08:00
|
|
|
$menu[$type] = array_map(function ($item) {
|
|
|
|
if (Arr::get($item, 'id') === 'plugin-configs') {
|
|
|
|
$availablePluginConfigs = [];
|
|
|
|
|
|
|
|
foreach (app('plugins')->getEnabledPlugins() as $plugin) {
|
|
|
|
if ($plugin->hasConfigView()) {
|
|
|
|
$availablePluginConfigs[] = [
|
|
|
|
'title' => trans($plugin->title),
|
|
|
|
'link' => 'admin/plugins/config/'.$plugin->name,
|
2019-03-02 22:58:37 +08:00
|
|
|
'icon' => 'fa-circle',
|
2018-02-23 18:12:12 +08:00
|
|
|
];
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
// Don't display this menu item when no plugin config is available
|
|
|
|
if (count($availablePluginConfigs) > 0) {
|
|
|
|
$item['children'] = array_merge($item['children'], $availablePluginConfigs);
|
2019-03-02 22:58:37 +08:00
|
|
|
|
2018-02-23 18:12:12 +08:00
|
|
|
return $item;
|
|
|
|
}
|
|
|
|
} else {
|
|
|
|
return $item;
|
|
|
|
}
|
|
|
|
}, $menu[$type]);
|
|
|
|
|
2017-01-20 18:17:56 +08:00
|
|
|
return bs_menu_render($menu[$type]);
|
2016-12-10 21:30:24 +08:00
|
|
|
}
|
|
|
|
|
|
|
|
function bs_menu_render($data)
|
|
|
|
{
|
2019-03-02 22:58:37 +08:00
|
|
|
$content = '';
|
2016-09-15 20:35:46 +08:00
|
|
|
|
2016-12-10 21:30:24 +08:00
|
|
|
foreach ($data as $key => $value) {
|
2016-12-17 19:02:56 +08:00
|
|
|
$active = app('request')->is(@$value['link']);
|
|
|
|
|
|
|
|
// also set parent as active if any child is active
|
|
|
|
foreach ((array) @$value['children'] as $childKey => $childValue) {
|
|
|
|
if (app('request')->is(@$childValue['link'])) {
|
|
|
|
$active = true;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2018-02-23 11:30:36 +08:00
|
|
|
$classes = [];
|
2018-02-23 16:51:50 +08:00
|
|
|
$active ? ($classes[] = 'active menu-open') : null;
|
2018-02-23 11:30:36 +08:00
|
|
|
isset($value['children']) ? ($classes[] = 'treeview') : null;
|
|
|
|
|
2018-02-23 16:51:50 +08:00
|
|
|
$attr = count($classes) ? sprintf(' class="%s"', implode(' ', $classes)) : '';
|
|
|
|
|
|
|
|
$content .= "<li{$attr}>";
|
2016-12-10 21:30:24 +08:00
|
|
|
|
|
|
|
if (isset($value['children'])) {
|
2018-08-08 12:30:50 +08:00
|
|
|
$content .= sprintf('<a href="#"><i class="fas %s"></i> <span>%s</span><span class="pull-right-container"><i class="fas fa-angle-left pull-right"></i></span></a>', $value['icon'], trans($value['title']));
|
2018-02-23 11:30:36 +08:00
|
|
|
|
2016-12-10 21:30:24 +08:00
|
|
|
// recurse
|
2018-02-23 16:51:50 +08:00
|
|
|
$content .= '<ul class="treeview-menu">'.bs_menu_render($value['children']).'</ul>';
|
2016-12-10 21:30:24 +08:00
|
|
|
} else {
|
2018-02-23 18:12:12 +08:00
|
|
|
if ($value) {
|
|
|
|
$content .= sprintf(
|
2018-09-06 23:14:54 +08:00
|
|
|
'<a href="%s"><i class="%s %s"></i> <span>%s</span></a>',
|
2018-02-23 18:12:12 +08:00
|
|
|
url((string) $value['link']),
|
2018-09-06 23:14:54 +08:00
|
|
|
$value['icon'] == 'fa-circle' ? 'far' : 'fas',
|
2018-02-23 18:12:12 +08:00
|
|
|
(string) $value['icon'],
|
|
|
|
trans((string) $value['title'])
|
|
|
|
);
|
|
|
|
}
|
2016-12-10 21:30:24 +08:00
|
|
|
}
|
2016-09-15 20:35:46 +08:00
|
|
|
|
2016-12-10 21:30:24 +08:00
|
|
|
$content .= '</li>';
|
2016-09-15 20:35:46 +08:00
|
|
|
}
|
|
|
|
|
2016-12-10 21:30:24 +08:00
|
|
|
return $content;
|
2016-09-15 20:35:46 +08:00
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2019-05-01 10:14:14 +08:00
|
|
|
if (! function_exists('bs_copyright')) {
|
|
|
|
function bs_copyright()
|
|
|
|
{
|
|
|
|
return Arr::get(
|
|
|
|
[
|
|
|
|
'Powered with ❤ by Blessing Skin Server.',
|
|
|
|
'Powered by Blessing Skin Server.',
|
|
|
|
'Proudly powered by Blessing Skin Server.',
|
|
|
|
'由 Blessing Skin Server 强力驱动。',
|
|
|
|
'自豪地采用 Blessing Skin Server。'
|
|
|
|
],
|
|
|
|
option_localized('copyright_prefer', 0)
|
|
|
|
);
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2016-09-15 20:35:46 +08:00
|
|
|
if (! function_exists('option')) {
|
2016-12-29 23:14:09 +08:00
|
|
|
/**
|
|
|
|
* Get / set the specified option value.
|
|
|
|
*
|
|
|
|
* If an array is passed as the key, we will assume you want to set an array of values.
|
|
|
|
*
|
|
|
|
* @param array|string $key
|
|
|
|
* @param mixed $default
|
2017-01-02 10:39:50 +08:00
|
|
|
* @param raw $raw return raw value without convertion
|
2016-12-29 23:14:09 +08:00
|
|
|
* @return mixed
|
|
|
|
*/
|
2017-01-02 10:39:50 +08:00
|
|
|
function option($key = null, $default = null, $raw = false)
|
2016-09-15 20:35:46 +08:00
|
|
|
{
|
2016-11-18 16:46:58 +08:00
|
|
|
$options = app('options');
|
|
|
|
|
|
|
|
if (is_null($key)) {
|
|
|
|
return $options;
|
|
|
|
}
|
|
|
|
|
|
|
|
if (is_array($key)) {
|
2019-03-23 15:44:16 +08:00
|
|
|
$options->set($key);
|
2019-04-19 19:36:36 +08:00
|
|
|
|
2016-12-31 23:36:44 +08:00
|
|
|
return;
|
2016-11-18 16:46:58 +08:00
|
|
|
}
|
|
|
|
|
2017-01-02 10:39:50 +08:00
|
|
|
return $options->get($key, $default, $raw);
|
2016-09-15 20:35:46 +08:00
|
|
|
}
|
|
|
|
}
|
2016-09-27 22:35:04 +08:00
|
|
|
|
2018-07-06 14:46:25 +08:00
|
|
|
if (! function_exists('option_localized')) {
|
|
|
|
function option_localized($key = null, $default = null, $raw = false)
|
|
|
|
{
|
|
|
|
return option($key.'_'.config('app.locale'), option($key));
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2018-07-21 16:55:36 +08:00
|
|
|
if (! function_exists('humanize_db_type')) {
|
|
|
|
function humanize_db_type($type = null)
|
2018-02-22 21:26:23 +08:00
|
|
|
{
|
|
|
|
$map = [
|
|
|
|
'mysql' => 'MySQL',
|
|
|
|
'sqlite' => 'SQLite',
|
2019-03-02 22:58:37 +08:00
|
|
|
'pgsql' => 'PostgreSQL',
|
2018-02-22 21:26:23 +08:00
|
|
|
];
|
|
|
|
|
|
|
|
$type = $type ?: config('database.default');
|
|
|
|
|
|
|
|
return Arr::get($map, $type, '');
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
if (! function_exists('get_db_config')) {
|
|
|
|
function get_db_config($type = null)
|
|
|
|
{
|
|
|
|
$type = $type ?: config('database.default');
|
|
|
|
|
|
|
|
return config("database.connections.$type");
|
|
|
|
}
|
|
|
|
}
|
2018-08-17 21:41:11 +08:00
|
|
|
|
|
|
|
if (! function_exists('format_http_date')) {
|
|
|
|
/**
|
|
|
|
* Format a UNIX timestamp to string for HTTP headers.
|
|
|
|
*
|
|
|
|
* e.g. Wed, 21 Oct 2015 07:28:00 GMT
|
|
|
|
*
|
|
|
|
* @param int $timestamp
|
|
|
|
* @return string
|
|
|
|
*/
|
2019-03-02 22:58:37 +08:00
|
|
|
function format_http_date($timestamp)
|
|
|
|
{
|
2018-08-17 21:41:11 +08:00
|
|
|
return Carbon::createFromTimestampUTC($timestamp)->format('D, d M Y H:i:s \G\M\T');
|
|
|
|
}
|
|
|
|
}
|
2018-08-17 22:54:26 +08:00
|
|
|
|
|
|
|
if (! function_exists('get_datetime_string')) {
|
|
|
|
/**
|
|
|
|
* Get date time string in "Y-m-d H:i:s" format.
|
|
|
|
*
|
2019-03-02 22:58:37 +08:00
|
|
|
* @param int $timestamp
|
2018-08-17 22:54:26 +08:00
|
|
|
* @return string
|
|
|
|
*/
|
2019-03-02 22:58:37 +08:00
|
|
|
function get_datetime_string($timestamp = 0)
|
|
|
|
{
|
2018-08-17 22:54:26 +08:00
|
|
|
return $timestamp == 0 ? Carbon::now()->toDateTimeString() : Carbon::createFromTimestamp($timestamp)->toDateTimeString();
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
if (! function_exists('get_client_ip')) {
|
|
|
|
/**
|
|
|
|
* Return the client IP address.
|
|
|
|
*
|
|
|
|
* We define this function because Symfony's "Request::getClientIp()" method
|
|
|
|
* needs "setTrustedProxies()", which sucks when load balancer is enabled.
|
|
|
|
*
|
|
|
|
* @return string
|
|
|
|
*/
|
2019-03-02 22:58:37 +08:00
|
|
|
function get_client_ip()
|
|
|
|
{
|
|
|
|
if (option('ip_get_method') == '0') {
|
2018-08-17 22:54:26 +08:00
|
|
|
// Use `HTTP_X_FORWARDED_FOR` if available first
|
2019-02-27 23:44:50 +08:00
|
|
|
$ip = Arr::get(
|
2018-08-17 22:54:26 +08:00
|
|
|
$_SERVER,
|
|
|
|
'HTTP_X_FORWARDED_FOR',
|
|
|
|
// Fallback to `HTTP_CLIENT_IP`
|
2019-02-27 23:44:50 +08:00
|
|
|
Arr::get(
|
2018-08-17 22:54:26 +08:00
|
|
|
$_SERVER,
|
|
|
|
'HTTP_CLIENT_IP',
|
|
|
|
// Fallback to `REMOTE_ADDR`
|
2019-02-27 23:44:50 +08:00
|
|
|
Arr::get($_SERVER, 'REMOTE_ADDR')
|
2018-08-17 22:54:26 +08:00
|
|
|
)
|
|
|
|
);
|
|
|
|
} else {
|
2019-02-27 23:44:50 +08:00
|
|
|
$ip = Arr::get($_SERVER, 'REMOTE_ADDR');
|
2018-08-17 22:54:26 +08:00
|
|
|
}
|
|
|
|
|
|
|
|
return $ip;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
if (! function_exists('get_string_replaced')) {
|
|
|
|
/**
|
|
|
|
* Replace content of string according to given rules.
|
|
|
|
*
|
|
|
|
* @param string $str
|
|
|
|
* @param array $rules
|
|
|
|
* @return string
|
|
|
|
*/
|
|
|
|
function get_string_replaced($str, $rules)
|
|
|
|
{
|
|
|
|
foreach ($rules as $search => $replace) {
|
|
|
|
$str = str_replace($search, $replace, $str);
|
|
|
|
}
|
2019-03-02 22:58:37 +08:00
|
|
|
|
2018-08-17 22:54:26 +08:00
|
|
|
return $str;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
if (! function_exists('is_request_secure')) {
|
|
|
|
/**
|
|
|
|
* Check whether the request is secure or not.
|
|
|
|
* True is always returned when "X-Forwarded-Proto" header is set.
|
|
|
|
*
|
|
|
|
* We define this function because Symfony's "Request::isSecure()" method
|
|
|
|
* needs "setTrustedProxies()" which sucks when load balancer is enabled.
|
|
|
|
*
|
|
|
|
* @return bool
|
|
|
|
*/
|
|
|
|
function is_request_secure()
|
|
|
|
{
|
2019-03-02 22:58:37 +08:00
|
|
|
if (Arr::get($_SERVER, 'HTTPS') == 'on') {
|
2018-08-17 22:54:26 +08:00
|
|
|
return true;
|
2019-03-02 22:58:37 +08:00
|
|
|
}
|
2018-08-17 22:54:26 +08:00
|
|
|
|
2019-03-02 22:58:37 +08:00
|
|
|
if (Arr::get($_SERVER, 'HTTP_X_FORWARDED_PROTO') == 'https') {
|
2018-08-17 22:54:26 +08:00
|
|
|
return true;
|
2019-03-02 22:58:37 +08:00
|
|
|
}
|
2018-08-17 22:54:26 +08:00
|
|
|
|
2019-03-02 22:58:37 +08:00
|
|
|
if (Arr::get($_SERVER, 'HTTP_X_FORWARDED_SSL') == 'on') {
|
2018-08-17 22:54:26 +08:00
|
|
|
return true;
|
2019-03-02 22:58:37 +08:00
|
|
|
}
|
2018-08-17 22:54:26 +08:00
|
|
|
|
|
|
|
return false;
|
|
|
|
}
|
|
|
|
}
|
2018-08-18 09:48:39 +08:00
|
|
|
|
|
|
|
if (! function_exists('nl2p')) {
|
|
|
|
/**
|
|
|
|
* Wrap blocks of text (delimited by \n) in p tags (similar to nl2br).
|
|
|
|
*
|
|
|
|
* @param string $text
|
|
|
|
* @return string
|
|
|
|
*/
|
2019-03-02 22:58:37 +08:00
|
|
|
function nl2p($text)
|
|
|
|
{
|
2018-08-18 09:48:39 +08:00
|
|
|
$parts = explode("\n", $text);
|
|
|
|
$result = '<p>'.implode('</p><p>', $parts).'</p>';
|
|
|
|
// Remove empty paragraphs
|
|
|
|
return str_replace('<p></p>', '', $result);
|
|
|
|
}
|
|
|
|
}
|
2019-03-21 12:44:15 +08:00
|
|
|
|
|
|
|
if (! function_exists('png')) {
|
|
|
|
function png($resource)
|
|
|
|
{
|
|
|
|
ob_start();
|
|
|
|
imagepng($resource);
|
|
|
|
$image = ob_get_contents();
|
|
|
|
ob_end_clean();
|
|
|
|
imagedestroy($resource);
|
2019-04-19 19:36:36 +08:00
|
|
|
|
2019-03-21 12:44:15 +08:00
|
|
|
return $image;
|
|
|
|
}
|
|
|
|
}
|