mirror of
https://github.com/Poniverse/Pony.fm.git
synced 2024-11-30 00:28:00 +01:00
263ea48c5b
Shift automatically applies the Laravel coding style - which uses the PSR-2 coding style as a base with some minor additions. You may customize the adopted coding style by adding your own [PHP CS Fixer][1] `.php_cs` config file to your project root. Feel free to use [Shift's Laravel ruleset][2] to help you get started. [1]: https://github.com/FriendsOfPHP/PHP-CS-Fixer [2]: https://gist.github.com/laravel-shift/cab527923ed2a109dda047b97d53c200
93 lines
2.7 KiB
PHP
93 lines
2.7 KiB
PHP
<?php
|
|
|
|
/**
|
|
* Pony.fm - A community for pony fan music.
|
|
* Copyright (C) 2015 Feld0.
|
|
*
|
|
* This program is free software: you can redistribute it and/or modify
|
|
* it under the terms of the GNU Affero General Public License as published by
|
|
* the Free Software Foundation, either version 3 of the License, or
|
|
* (at your option) any later version.
|
|
*
|
|
* This program is distributed in the hope that it will be useful,
|
|
* but WITHOUT ANY WARRANTY; without even the implied warranty of
|
|
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
|
|
* GNU Affero General Public License for more details.
|
|
*
|
|
* You should have received a copy of the GNU Affero General Public License
|
|
* along with this program. If not, see <http://www.gnu.org/licenses/>.
|
|
*/
|
|
class Helpers
|
|
{
|
|
/**
|
|
* Removes whitespace and special characters from a string
|
|
* and sets all characters to lower case.
|
|
*/
|
|
public static function sanitizeInputForHashing($value)
|
|
{
|
|
$value = preg_replace('/[^A-Za-z0-9]/', '', $value);
|
|
|
|
return strtolower($value);
|
|
}
|
|
|
|
public static function template($template)
|
|
{
|
|
echo file_get_contents('templates/'.$template);
|
|
}
|
|
|
|
public static function angular($expression)
|
|
{
|
|
return '{{'.$expression.'}}';
|
|
}
|
|
|
|
public static function formatBytes($bytes, $precision = 2)
|
|
{
|
|
if ($bytes == 0) {
|
|
return '0 MB';
|
|
}
|
|
|
|
$units = ['B', 'KB', 'MB', 'GB', 'TB'];
|
|
|
|
$bytes = max($bytes, 0);
|
|
$pow = floor(($bytes ? log($bytes) : 0) / log(1024));
|
|
$pow = min($pow, count($units) - 1);
|
|
|
|
$bytes /= pow(1024, $pow);
|
|
|
|
return round($bytes, $precision).' '.$units[$pow];
|
|
}
|
|
|
|
/**
|
|
* timeago-style timestamp generator macro.
|
|
*
|
|
* @param string $timestamp A timestamp in SQL DATETIME syntax
|
|
* @return string
|
|
*/
|
|
public static function timestamp($timestamp)
|
|
{
|
|
if (gettype($timestamp) !== 'string' && get_class($timestamp) === 'DateTime') {
|
|
$timestamp = $timestamp->format('c');
|
|
}
|
|
|
|
$title = date('c', strtotime($timestamp));
|
|
$content = date('F j, Y \@ g:i:s a', strtotime($timestamp));
|
|
|
|
return '<abbr class="timeago" title="'.$title.'">'.$content.'</abbr>';
|
|
}
|
|
|
|
/**
|
|
* Converts an RGB array to a hex string.
|
|
*
|
|
* @param array[int] $rgb RGB values in an array
|
|
* @return string
|
|
*/
|
|
public static function rgb2hex($rgb)
|
|
{
|
|
$hex = '#';
|
|
$hex .= str_pad(dechex($rgb[0]), 2, '0', STR_PAD_LEFT);
|
|
$hex .= str_pad(dechex($rgb[1]), 2, '0', STR_PAD_LEFT);
|
|
$hex .= str_pad(dechex($rgb[2]), 2, '0', STR_PAD_LEFT);
|
|
|
|
return $hex;
|
|
}
|
|
}
|