diff --git a/admin.php b/admin.php
index 4f0fa940..ae8fe25d 100644
--- a/admin.php
+++ b/admin.php
@@ -47,7 +47,7 @@ class AdminPlugin extends Plugin
*/
public static function getSubscribedEvents() {
return [
- 'onPluginsInitialized' => ['onPluginsInitialized', 1000],
+ 'onPluginsInitialized' => [['login', 100000], ['onPluginsInitialized', 1000]],
'onShutdown' => ['onShutdown', 1000]
];
}
@@ -57,21 +57,45 @@ class AdminPlugin extends Plugin
*
* Disables system cache.
*/
- public function onPluginsInitialized()
+ public function login()
{
-
// Check for Pro version and disable this plugin if found
// if (file_exists(PLUGINS_DIR . 'admin_pro/admin_pro.php')) {
// $this->enabled = false;
// return;
// }
- // echo "
Admin Free
";
- //
- require_once PLUGINS_DIR . 'admin/classes/popularity.php';
- $this->popularity = new Popularity();
+ $route = $this->config->get('plugins.admin.route');
+ if (!$route) {
+ return;
+ }
- $this->initializeAdmin();
+ $this->base = '/' . trim($route, '/');
+ $this->uri = $this->grav['uri'];
+
+ // Only activate admin if we're inside the admin path.
+ if (substr($this->uri->route(), 0, strlen($this->base)) == $this->base) {
+ // Disable system caching.
+ $this->config->set('system.cache.enabled', false);
+
+ // Change login behavior.
+ $this->config->set('plugins.login', $this->config->get('plugins.admin.login'));
+
+ $this->active = true;
+ }
+ }
+
+ /**
+ * Initialize administration plugin if admin path matches.
+ *
+ * Disables system cache.
+ */
+ public function onPluginsInitialized()
+ {
+ // Only activate admin if we're inside the admin path.
+ if ($this->active) {
+ $this->initializeAdmin();
+ }
}
/**
@@ -88,17 +112,6 @@ class AdminPlugin extends Plugin
$this->grav['admin']->routes = $pages->routes();
$pages->dispatch('/', true)->route($home);
- }
-
- /**
- * Main administration controller.
- */
- public function onPageInitialized()
- {
- // Set page if user hasn't been authorised.
- if (!$this->admin->authorise()) {
- $this->template = $this->admin->user ? 'denied' : 'login';
- }
// Make local copy of POST.
$post = !empty($_POST) ? $_POST : array();
@@ -116,16 +129,16 @@ class AdminPlugin extends Plugin
exit();
}
- /** @var Grav $grav */
- $grav = $this->grav;
+ $self = $this;
- // Finally create admin page.
- $page = new Page;
- $page->init(new \SplFileInfo(__DIR__ . "/pages/admin/{$this->template}.md"));
- $page->slug(basename($this->template));
+ // Replace page service with admin.
+ $this->grav['page'] = function ($c) use ($self) {
+ $page = new Page;
+ $page->init(new \SplFileInfo(__DIR__ . "/pages/admin/{$self->template}.md"));
+ $page->slug(basename($self->template));
- unset($grav['page']);
- $grav['page'] = $page;
+ return $page;
+ };
}
/**
@@ -181,52 +194,41 @@ class AdminPlugin extends Plugin
protected function initializeAdmin()
{
- $this->route = $this->config->get('plugins.admin.route');
+ $this->enable([
+ 'onPagesInitialized' => ['onPagesInitialized', 1000],
+ 'onTwigTemplatePaths' => ['onTwigTemplatePaths', 1000],
+ 'onTwigSiteVariables' => ['onTwigSiteVariables', 1000]
+ ]);
- if (!$this->route) {
- return;
- }
+ require_once PLUGINS_DIR . 'admin/classes/popularity.php';
+ $this->popularity = new Popularity();
- $this->uri = $this->grav['uri'];
- $base = '/' . trim($this->route, '/');
+ // Disable system caching.
+ $this->config->set('system.cache.enabled', false);
- // Only activate admin if we're inside the admin path.
- if (substr($this->uri->route(), 0, strlen($base)) == $base) {
- $this->active = true;
- $this->enable([
- 'onPagesInitialized' => ['onPagesInitialized', 1000],
- 'onPageInitialized' => ['onPageInitialized', 1000],
- 'onTwigTemplatePaths' => ['onTwigTemplatePaths', 1000],
- 'onTwigSiteVariables' => ['onTwigSiteVariables', 1000]
- ]);
+ // Change login behavior.
+ $this->config->set('plugins.login', $this->config->get('plugins.admin.login'));
- // Disable system caching.
- $this->config->set('system.cache.enabled', false);
+ // Decide admin template and route.
+ $path = trim(substr($this->uri->route(), strlen($this->base)), '/');
+ $this->template = 'dashboard';
- // Decide admin template and route.
- $path = trim(substr($this->uri->route(), strlen($base)), '/');
- $this->template = 'dashboard';
+ if ($path) {
+ $array = explode('/', $path, 2);
+ $this->template = array_shift($array);
+ $this->route = array_shift($array);
- if ($path) {
- $array = explode('/', $path, 2);
- $this->template = array_shift($array);
- $this->route = array_shift($array);
-
- // Set path for new page.
- if ($this->uri->param('new')) {
- $this->route .= '/new';
- }
+ // Set path for new page.
+ if ($this->uri->param('new')) {
+ $this->route .= '/new';
}
-
- // Initialize admin class.
- require_once PLUGINS_DIR . 'admin/classes/admin.php';
- $this->admin = new Admin($this->grav, $base, $this->template, $this->route);
-
-
-
- // And store the class into DI container.
- $this->grav['admin'] = $this->admin;
-
}
+
+ // Initialize admin class.
+ require_once __DIR__ . '/classes/admin.php';
+ $this->admin = new Admin($this->grav, $this->base, $this->template, $this->route);
+
+ // And store the class into DI container.
+ $this->grav['admin'] = $this->admin;
}
}
diff --git a/admin.yaml b/admin.yaml
index 3eeca1fc..66bf7980 100644
--- a/admin.yaml
+++ b/admin.yaml
@@ -1,5 +1,10 @@
enabled: true
route: '/admin'
+theme: grav
+login:
+ enabled: true
+ route: null
+ timeout: 1800
popularity:
enabled: true
ignore: ['/test*','/modular']
@@ -7,4 +12,3 @@ popularity:
daily: 7
monthly: 12
visitors: 20
-theme: grav
diff --git a/classes/admin.php b/classes/admin.php
index 08e37e51..aa94fcde 100644
--- a/classes/admin.php
+++ b/classes/admin.php
@@ -2,7 +2,6 @@
namespace Grav\Plugin;
use Grav\Common\User\User;
-use Grav\Common\User\Authentication;
use Grav\Common\Filesystem\File;
use Grav\Common\Grav;
use Grav\Common\Plugins;
@@ -40,11 +39,6 @@ class Admin
*/
protected $blueprints;
- /**
- * @var string
- */
- public $message;
-
/**
* @var string
*/
@@ -61,7 +55,7 @@ class Admin
public $route;
/**
- * @var array
+ * @var User
*/
public $user;
@@ -81,17 +75,9 @@ class Admin
$this->location = $location;
$this->route = $route;
- /** @var Uri uri */
$this->uri = $this->grav['uri'];
-
- // TODO: add session timeout into configuration
- $this->session = new Session\Session(1800, $this->uri->rootUrl(false) . $base);
- $this->session->start();
-
- // Get current user from the session.
- if (isset($this->session->user)) {
- $this->user = $this->session->user;
- }
+ $this->session = $this->grav['session'];
+ $this->user = $this->grav['user'];
}
/**
@@ -112,12 +98,8 @@ class Admin
*/
public function setMessage($msg, $type = 'info')
{
- if (!isset($this->session->messages)) {
- $this->session->messages = new Session\Message;
- }
-
/** @var Session\Message $messages */
- $messages = $this->session->messages;
+ $messages = $this->grav['messages'];
$messages->add($msg, $type);
}
@@ -125,14 +107,13 @@ class Admin
* Fetch and delete messages from the session queue.
*
* @param string $type
+ * @return array
*/
public function messages($type = null)
{
- if (!isset($this->session->messages)) {
- $this->session->messages = new Session\Message;
- }
-
- return $this->session->messages->fetch($type);
+ /** @var Session\Message $messages */
+ $messages = $this->grav['messages'];
+ return $messages->fetch($type);
}
/**
@@ -143,10 +124,11 @@ class Admin
*/
public function authenticate($form)
{
- if (!$this->session->user && isset($form['username']) && isset($form['password'])) {
+ if (!$this->user->authenticated && isset($form['username']) && isset($form['password'])) {
$file = File\Yaml::instance(ACCOUNTS_DIR . $form['username'] . YAML_EXT);
if ($file->exists()) {
$user = new User($file->content());
+ $user->authenticated = true;
// Authenticate user.
$result = $user->authenticate($form['password']);
@@ -172,7 +154,7 @@ class Admin
*/
public function authorise($action = 'admin.login')
{
- return isset($this->user) && $this->user->authorise($action);
+ return $this->user->authorise($action);
}
/**
@@ -409,9 +391,7 @@ class Admin
$page->filePath($parent->path().'/'.$slug.'/'.$page->name());
$page->header();
- // Attach page to parent and add routing information.
- // FIXME:
- $parent->{$slug} = $page;
+ // Add routing information.
$pages->addPage($page, $path);
// Determine page type.
diff --git a/pages/admin/configuration.md b/pages/admin/configuration.md
index 460f7639..f38e9b84 100644
--- a/pages/admin/configuration.md
+++ b/pages/admin/configuration.md
@@ -1,3 +1,7 @@
---
title: Configuration
+
+access:
+ admin.configuration: true
+ admin.super: true
---
diff --git a/pages/admin/dashboard.md b/pages/admin/dashboard.md
index 7331ffb1..eb1f7e26 100644
--- a/pages/admin/dashboard.md
+++ b/pages/admin/dashboard.md
@@ -1,5 +1,9 @@
---
title: Dashboard
+
+access:
+ admin.login: true
+ admin.super: true
---
Lorem ipsum dolor sit amet, consectetur adipisicing elit, sed do eiusmod
diff --git a/pages/admin/denied.md b/pages/admin/denied.md
new file mode 100644
index 00000000..1dc329d0
--- /dev/null
+++ b/pages/admin/denied.md
@@ -0,0 +1,4 @@
+---
+title: Access Denied
+---
+
diff --git a/pages/admin/installer.md b/pages/admin/installer.md
new file mode 100644
index 00000000..91a6a69b
--- /dev/null
+++ b/pages/admin/installer.md
@@ -0,0 +1,7 @@
+---
+title: Users
+
+access:
+ admin.users: true
+ admin.super: true
+---
diff --git a/pages/admin/login.md b/pages/admin/login.md
index 2748c45d..b076f336 100644
--- a/pages/admin/login.md
+++ b/pages/admin/login.md
@@ -2,12 +2,13 @@
title: Dashboard Login
form:
- - name: username
- type: text
- placeholder: Username
+ fields:
+ - name: username
+ type: text
+ placeholder: Username
- - name: password
- type: password
- placeholder: Password
+ - name: password
+ type: password
+ placeholder: Password
---
diff --git a/pages/admin/logs.md b/pages/admin/logs.md
index 33f07c62..58d64350 100644
--- a/pages/admin/logs.md
+++ b/pages/admin/logs.md
@@ -1,3 +1,7 @@
---
title: Error Log
+
+access:
+ admin.logs: true
+ admin.super: true
---
diff --git a/pages/admin/pages.md b/pages/admin/pages.md
index da761cbf..b1f7fc40 100644
--- a/pages/admin/pages.md
+++ b/pages/admin/pages.md
@@ -1,3 +1,7 @@
---
title: Pages
+
+access:
+ admin.pages: true
+ admin.super: true
---
diff --git a/pages/admin/plugins.md b/pages/admin/plugins.md
index 298ff164..d61155fc 100644
--- a/pages/admin/plugins.md
+++ b/pages/admin/plugins.md
@@ -1,3 +1,7 @@
---
title: Plugins
+
+access:
+ admin.plugins: true
+ admin.super: true
---
diff --git a/pages/admin/settings.md b/pages/admin/settings.md
index 05c8d0e9..699bf794 100644
--- a/pages/admin/settings.md
+++ b/pages/admin/settings.md
@@ -1,3 +1,7 @@
---
title: Site Settings
+
+access:
+ admin.settings: true
+ admin.super: true
---
diff --git a/pages/admin/statistics.md b/pages/admin/statistics.md
new file mode 100644
index 00000000..85a7d08d
--- /dev/null
+++ b/pages/admin/statistics.md
@@ -0,0 +1,7 @@
+---
+title: Installer
+
+access:
+ admin.install: true
+ admin.super: true
+---
diff --git a/pages/admin/users.md b/pages/admin/users.md
new file mode 100644
index 00000000..d61155fc
--- /dev/null
+++ b/pages/admin/users.md
@@ -0,0 +1,7 @@
+---
+title: Plugins
+
+access:
+ admin.plugins: true
+ admin.super: true
+---
diff --git a/theme-old/templates/login.html.twig b/theme-old/templates/login.html.twig
index fd2a7a97..9f37ccf3 100644
--- a/theme-old/templates/login.html.twig
+++ b/theme-old/templates/login.html.twig
@@ -9,7 +9,7 @@
{% include 'partials/messages.html.twig' %}
{% else %}
- {% set theme = admin.themes[admin.route] %}
- {% set blueprints = theme.blueprints() %}
-
-
- {{ blueprints.get('name')|e }}
- {{ blueprints.get('version') ? 'v' ~ blueprints.get('version')|e }}
-
-
- {% include 'partials/messages.html.twig' %}
-
- {{ blueprints.get('description') }}
-
- {% include 'partials/blueprints.html.twig' with { data: theme } %}
+ {% include 'partials/theme.html.twig' %}
{% endif %}
diff --git a/themes/grav/templates/installer.html.twig b/themes/grav/templates/installer.html.twig
new file mode 100644
index 00000000..25a632d5
--- /dev/null
+++ b/themes/grav/templates/installer.html.twig
@@ -0,0 +1,14 @@
+{% extends 'partials/base.html.twig' %}
+
+
+{% block content %}
+
+
+
+ Users
+
+
+ {% include 'partials/messages.html.twig' %}
+
+{% endblock %}
+
diff --git a/themes/grav/templates/partials/theme.html.twig b/themes/grav/templates/partials/theme.html.twig
new file mode 100644
index 00000000..b18b6c51
--- /dev/null
+++ b/themes/grav/templates/partials/theme.html.twig
@@ -0,0 +1,13 @@
+{% set theme = admin.themes[admin.route] %}
+{% set blueprints = theme.blueprints() %}
+
+
+ {{ blueprints.get('name')|e }}
+ {{ blueprints.get('version') ? 'v' ~ blueprints.get('version')|e }}
+
+
+{% include 'partials/messages.html.twig' %}
+
+{{ blueprints.get('description') }}
+
+{% include 'partials/blueprints.html.twig' with { data: theme } %}
diff --git a/themes/grav/templates/statistics.html.twig b/themes/grav/templates/statistics.html.twig
new file mode 100644
index 00000000..25a632d5
--- /dev/null
+++ b/themes/grav/templates/statistics.html.twig
@@ -0,0 +1,14 @@
+{% extends 'partials/base.html.twig' %}
+
+
+{% block content %}
+
+
+
+ Users
+
+
+ {% include 'partials/messages.html.twig' %}
+
+{% endblock %}
+
diff --git a/themes/grav/templates/users.html.twig b/themes/grav/templates/users.html.twig
new file mode 100644
index 00000000..51003824
--- /dev/null
+++ b/themes/grav/templates/users.html.twig
@@ -0,0 +1,50 @@
+{% extends 'partials/base.html.twig' %}
+
+
+{% block content %}
+
+
+ {% if not admin.route %}
+
+ Plugins
+
+
+ {% include 'partials/messages.html.twig' %}
+
+
+ {% for plugin in admin.plugins %}
+ {% set blueprints = plugin.blueprints() %}
+
+
+ |
+ {{ blueprints.get('name') }}
+ |
+
+
+ |
+
+ {% endfor %}
+
+ {% else %}
+ {% set plugin = admin.plugins[admin.route] %}
+ {% set blueprints = plugin.blueprints() %}
+
+
+ {{ blueprints.get('name')|e }}
+ {{ blueprints.get('version') ? 'v' ~ blueprints.get('version')|e }}
+
+
+ {% include 'partials/messages.html.twig' %}
+
{{ blueprints.get('description') }}
+
+ {% include 'partials/blueprints.html.twig' with { data: plugin } %}
+ {% endif %}
+
+{% endblock %}
+