misc_pterodactyl-panel/app/Providers/MacroServiceProvider.php

71 lines
2 KiB
PHP
Raw Normal View History

<?php
/**
* Pterodactyl - Panel
2017-01-24 22:57:08 +00:00
* Copyright (c) 2015 - 2017 Dane Everitt <dane@daneeveritt.com>.
*
2017-09-26 02:43:01 +00:00
* This software is licensed under the terms of the MIT license.
* https://opensource.org/licenses/MIT
*/
2016-12-07 22:46:38 +00:00
2017-03-16 00:52:37 +00:00
namespace Pterodactyl\Providers;
2017-03-16 00:52:37 +00:00
use File;
use Cache;
use Carbon;
use Request;
use Pterodactyl\Models\APIKey;
2017-03-16 00:52:37 +00:00
use Illuminate\Support\ServiceProvider;
use Pterodactyl\Services\ApiKeyService;
2017-03-16 00:52:37 +00:00
class MacroServiceProvider extends ServiceProvider
2016-12-07 22:46:38 +00:00
{
/**
2017-03-16 00:52:37 +00:00
* Bootstrap the application services.
*/
2017-03-16 00:52:37 +00:00
public function boot()
{
2017-03-16 00:52:37 +00:00
File::macro('humanReadableSize', function ($path, $precision = 2) {
$size = File::size($path);
static $units = ['B', 'kB', 'MB', 'GB', 'TB'];
$i = 0;
while (($size / 1024) > 0.9) {
$size = $size / 1024;
2017-08-22 03:10:48 +00:00
++$i;
2017-03-16 00:52:37 +00:00
}
return round($size, ($i < 2) ? 0 : $precision) . ' ' . $units[$i];
});
Request::macro('apiKey', function () {
if (! Request::bearerToken()) {
return false;
}
$parts = explode('.', Request::bearerToken());
if (count($parts) === 2 && strlen($parts[0]) === ApiKeyService::PUB_CRYPTO_BYTES * 2) {
// Because the key itself isn't changing frequently, we simply cache this for
// 15 minutes to speed up the API and keep requests flowing.
return Cache::tags([
'ApiKeyMacro',
'ApiKeyMacro:Key:' . $parts[0],
2017-04-09 23:16:39 +00:00
])->remember('ApiKeyMacro.' . $parts[0], Carbon::now()->addMinutes(15), function () use ($parts) {
return APIKey::where('public', $parts[0])->first();
});
}
return false;
});
2017-04-09 23:16:39 +00:00
Request::macro('apiKeyHasPermission', function ($permission) {
$key = Request::apiKey();
if (! $key) {
return false;
}
return Request::user()->can($permission, $key);
});
}
}