mirror of
https://github.com/flarum/framework.git
synced 2025-01-20 05:32:49 +08:00
Move config/permission actions to API; clean up cache flushing
This commit is contained in:
parent
afe031f269
commit
2e4d38b3e7
|
@ -91,7 +91,7 @@ export default class PermissionDropdown extends Dropdown {
|
|||
|
||||
app.request({
|
||||
method: 'POST',
|
||||
url: app.forum.attribute('adminUrl') + '/permission',
|
||||
url: app.forum.attribute('apiUrl') + '/permission',
|
||||
data: {permission, groupIds}
|
||||
});
|
||||
}
|
||||
|
|
|
@ -5,7 +5,7 @@ export default function saveConfig(config) {
|
|||
|
||||
return app.request({
|
||||
method: 'POST',
|
||||
url: app.forum.attribute('adminUrl') + '/config',
|
||||
url: app.forum.attribute('apiUrl') + '/config',
|
||||
data: {config}
|
||||
}).catch(error => {
|
||||
app.config = oldConfig;
|
||||
|
|
|
@ -50,18 +50,6 @@ class AdminServiceProvider extends ServiceProvider
|
|||
'flarum.admin.index',
|
||||
$this->action('Flarum\Admin\Actions\ClientAction')
|
||||
);
|
||||
|
||||
$routes->post(
|
||||
'/config',
|
||||
'flarum.admin.updateConfig',
|
||||
$this->action('Flarum\Admin\Actions\UpdateConfigAction')
|
||||
);
|
||||
|
||||
$routes->post(
|
||||
'/permission',
|
||||
'flarum.admin.updatePermission',
|
||||
$this->action('Flarum\Admin\Actions\UpdatePermissionAction')
|
||||
);
|
||||
}
|
||||
|
||||
protected function action($class)
|
||||
|
|
|
@ -1,12 +1,13 @@
|
|||
<?php namespace Flarum\Admin\Actions;
|
||||
<?php namespace Flarum\Api\Actions;
|
||||
|
||||
use Psr\Http\Message\ServerRequestInterface as Request;
|
||||
use Flarum\Api\Request;
|
||||
use Flarum\Core\Settings\SettingsRepository;
|
||||
use Flarum\Support\Action;
|
||||
use Flarum\Core\Groups\Permission;
|
||||
use Flarum\Core\Exceptions\PermissionDeniedException;
|
||||
use Zend\Diactoros\Response\EmptyResponse;
|
||||
use Exception;
|
||||
|
||||
class UpdateConfigAction extends Action
|
||||
class ConfigAction implements Action
|
||||
{
|
||||
/**
|
||||
* @var SettingsRepository
|
||||
|
@ -26,7 +27,11 @@ class UpdateConfigAction extends Action
|
|||
*/
|
||||
public function handle(Request $request, array $routeParams = [])
|
||||
{
|
||||
$config = array_get($request->getAttributes(), 'config', []);
|
||||
if (! $request->actor->isAdmin()) {
|
||||
throw new PermissionDeniedException;
|
||||
}
|
||||
|
||||
$config = $request->get('config', []);
|
||||
|
||||
// TODO: throw HTTP status 400 or 422
|
||||
if (! is_array($config)) {
|
||||
|
@ -35,16 +40,16 @@ class UpdateConfigAction extends Action
|
|||
|
||||
foreach ($config as $k => $v) {
|
||||
$this->settings->set($k, $v);
|
||||
|
||||
if (strpos($k, 'theme_') === 0) {
|
||||
$forum = app('Flarum\Forum\Actions\ClientAction');
|
||||
$forum->flushAssets();
|
||||
|
||||
$admin = app('Flarum\Admin\Actions\ClientAction');
|
||||
$admin->flushAssets();
|
||||
}
|
||||
}
|
||||
|
||||
$assetPath = public_path('assets');
|
||||
$manifest = file_get_contents($assetPath . '/rev-manifest.json');
|
||||
$revisions = json_decode($manifest, true);
|
||||
|
||||
foreach ($revisions as $file => $revision) {
|
||||
@unlink($assetPath . '/' . substr_replace($file, '-' . $revision, strrpos($file, '.'), 0));
|
||||
}
|
||||
|
||||
return $this->success();
|
||||
return new EmptyResponse(204);
|
||||
}
|
||||
}
|
|
@ -32,12 +32,10 @@ class UpdateAction extends JsonApiAction
|
|||
|
||||
app('flarum.formatter')->flush();
|
||||
|
||||
$assetPath = public_path('assets');
|
||||
$manifest = file_get_contents($assetPath . '/rev-manifest.json');
|
||||
$revisions = json_decode($manifest, true);
|
||||
$forum = app('Flarum\Forum\Actions\ClientAction');
|
||||
$forum->flushAssets();
|
||||
|
||||
foreach ($revisions as $file => $revision) {
|
||||
@unlink($assetPath . '/' . substr_replace($file, '-' . $revision, strrpos($file, '.'), 0));
|
||||
}
|
||||
$admin = app('Flarum\Admin\Actions\ClientAction');
|
||||
$admin->flushAssets();
|
||||
}
|
||||
}
|
||||
|
|
|
@ -1,19 +1,23 @@
|
|||
<?php namespace Flarum\Admin\Actions;
|
||||
<?php namespace Flarum\Api\Actions;
|
||||
|
||||
use Psr\Http\Message\ServerRequestInterface as Request;
|
||||
use Flarum\Support\Action;
|
||||
use Flarum\Api\Request;
|
||||
use Flarum\Core\Groups\Permission;
|
||||
use Flarum\Core\Exceptions\PermissionDeniedException;
|
||||
use Zend\Diactoros\Response\EmptyResponse;
|
||||
|
||||
class UpdatePermissionAction extends Action
|
||||
class PermissionAction implements Action
|
||||
{
|
||||
/**
|
||||
* {@inheritdoc}
|
||||
*/
|
||||
public function handle(Request $request, array $routeParams = [])
|
||||
{
|
||||
$input = $request->getAttributes();
|
||||
$permission = array_get($input, 'permission');
|
||||
$groupIds = array_get($input, 'groupIds');
|
||||
if (! $request->actor->isAdmin()) {
|
||||
throw new PermissionDeniedException;
|
||||
}
|
||||
|
||||
$permission = $request->get('permission');
|
||||
$groupIds = $request->get('groupIds');
|
||||
|
||||
Permission::where('permission', $permission)->delete();
|
||||
|
||||
|
@ -24,6 +28,6 @@ class UpdatePermissionAction extends Action
|
|||
];
|
||||
}, $groupIds));
|
||||
|
||||
return $this->success();
|
||||
return new EmptyResponse(204);
|
||||
}
|
||||
}
|
|
@ -315,7 +315,7 @@ class ApiServiceProvider extends ServiceProvider
|
|||
|
||||
/*
|
||||
|--------------------------------------------------------------------------
|
||||
| Extensions
|
||||
| Administration
|
||||
|--------------------------------------------------------------------------
|
||||
*/
|
||||
|
||||
|
@ -326,6 +326,20 @@ class ApiServiceProvider extends ServiceProvider
|
|||
$this->action('Flarum\Api\Actions\Extensions\UpdateAction')
|
||||
);
|
||||
|
||||
// Update config settings
|
||||
$routes->post(
|
||||
'/config',
|
||||
'flarum.api.config',
|
||||
$this->action('Flarum\Api\Actions\ConfigAction')
|
||||
);
|
||||
|
||||
// Update a permission
|
||||
$routes->post(
|
||||
'/permission',
|
||||
'flarum.api.permission',
|
||||
$this->action('Flarum\Api\Actions\PermissionAction')
|
||||
);
|
||||
|
||||
event(new RegisterApiRoutes($routes));
|
||||
}
|
||||
|
||||
|
|
|
@ -57,4 +57,10 @@ class AssetManager
|
|||
{
|
||||
return $this->js->getFile();
|
||||
}
|
||||
|
||||
public function flush()
|
||||
{
|
||||
$this->less->flush();
|
||||
$this->js->flush();
|
||||
}
|
||||
}
|
||||
|
|
|
@ -79,6 +79,7 @@ class RevisionCompiler implements Compiler
|
|||
{
|
||||
if (file_exists($file = $this->getRevisionFile())) {
|
||||
$manifest = json_decode(file_get_contents($file), true);
|
||||
|
||||
return array_get($manifest, $this->filename);
|
||||
}
|
||||
}
|
||||
|
@ -95,4 +96,15 @@ class RevisionCompiler implements Compiler
|
|||
|
||||
return file_put_contents($this->getRevisionFile(), json_encode($manifest));
|
||||
}
|
||||
|
||||
public function flush()
|
||||
{
|
||||
$revision = $this->getRevision();
|
||||
|
||||
$ext = pathinfo($this->filename, PATHINFO_EXTENSION);
|
||||
|
||||
$file = $this->path . '/' . substr_replace($this->filename, '-' . $revision, -strlen($ext) - 1, 0);
|
||||
|
||||
@unlink($file);
|
||||
}
|
||||
}
|
||||
|
|
|
@ -118,6 +118,17 @@ abstract class ClientAction extends HtmlAction
|
|||
return $view;
|
||||
}
|
||||
|
||||
/**
|
||||
* Flush the client's assets so that they will be regenerated from scratch
|
||||
* on the next render.
|
||||
*
|
||||
* @return void
|
||||
*/
|
||||
public function flushAssets()
|
||||
{
|
||||
$this->getAssets()->flush();
|
||||
}
|
||||
|
||||
/**
|
||||
* Set up the asset manager, preloaded with a JavaScript compiler and a LESS
|
||||
* compiler. Automatically add the files necessary to boot a Flarum client,
|
||||
|
|
Loading…
Reference in New Issue
Block a user