Don't treat the execute tab as a special tab in the web panel,
otherwise configurations with enabled_plugins/disabled_plugins won't work with it
This commit is contained in:
parent
be5c5d365c
commit
a6488e15fe
4 changed files with 8 additions and 15 deletions
|
@ -1,3 +1,4 @@
|
|||
import json
|
||||
import os
|
||||
|
||||
from flask import Blueprint, render_template, request
|
||||
|
@ -31,6 +32,7 @@ def index():
|
|||
if plugin not in configured_plugins:
|
||||
configured_plugins[plugin] = {}
|
||||
|
||||
configured_plugins['execute'] = {}
|
||||
disabled_plugins = set(request.args.get('disabled_plugins', '').split(','))
|
||||
|
||||
js_folder = os.path.abspath(
|
||||
|
@ -38,8 +40,10 @@ def index():
|
|||
style_folder = os.path.abspath(
|
||||
os.path.join(template_folder, '..', 'static', 'css', 'dist'))
|
||||
|
||||
for plugin, conf in configured_plugins.items():
|
||||
for plugin, conf in configured_plugins.copy().items():
|
||||
if plugin in disabled_plugins:
|
||||
if plugin == 'execute':
|
||||
configured_plugins.pop('execute')
|
||||
continue
|
||||
|
||||
template_file = os.path.join(
|
||||
|
@ -67,7 +71,7 @@ def index():
|
|||
websocket_port=get_websocket_port(),
|
||||
template_folder=template_folder, static_folder=static_folder,
|
||||
plugins=Config.get_plugins(), backends=Config.get_backends(),
|
||||
procedures=Config.get_procedures(),
|
||||
procedures=json.dumps(Config.get_procedures()),
|
||||
has_ssl=http_conf.get('ssl_cert') is not None)
|
||||
|
||||
|
||||
|
|
|
@ -32,7 +32,7 @@ Vue.component('execute', {
|
|||
methods: {
|
||||
refresh: async function() {
|
||||
this.loading = true;
|
||||
this.procedures = JSON.parse(this.config);
|
||||
this.procedures = window.config.procedures;
|
||||
this.plugins = await request('inspect.get_all_plugins', {html_doc: true});
|
||||
|
||||
for (const plugin of Object.values(this.plugins)) {
|
||||
|
|
|
@ -8,7 +8,6 @@
|
|||
<link rel="stylesheet" href="{{ url_for('static', filename='css/normalize.css') }}">
|
||||
<link rel="stylesheet" href="{{ url_for('static', filename='font-awesome/css/all.css') }}">
|
||||
<link rel="stylesheet" href="{{ url_for('static', filename='css/dist/webpanel.css') }}">
|
||||
<link rel="stylesheet" href="{{ url_for('static', filename='css/dist/webpanel/plugins/execute.css') }}">
|
||||
|
||||
<script type="text/javascript">
|
||||
if (!window.config) {
|
||||
|
@ -20,6 +19,7 @@
|
|||
has_ssl: {{ 'true' if has_ssl else 'false' }},
|
||||
templates: JSON.parse('{{ utils.to_json(templates)|safe }}'),
|
||||
scripts: JSON.parse('{{ utils.to_json(scripts)|safe }}'),
|
||||
procedures: JSON.parse('{{ procedures.replace("\'", "\\\'")|safe }}'),
|
||||
};
|
||||
|
||||
|
||||
|
@ -51,7 +51,6 @@
|
|||
{% endfor %}
|
||||
|
||||
{% include 'elements.html' %}
|
||||
{% include 'plugins/execute/index.html' %}
|
||||
|
||||
{% for plugin, conf in templates.items() %}
|
||||
{% with configuration=templates[plugin] %}
|
||||
|
@ -59,7 +58,6 @@
|
|||
{% endwith %}
|
||||
{% endfor %}
|
||||
|
||||
<script type="text/javascript" src="{{ url_for('static', filename='js/plugins/execute/index.js') }}"></script>
|
||||
{% for script in scripts.values() %}
|
||||
<script type="text/javascript" src="{{ url_for('static', filename=script['_script_file']) }}"></script>
|
||||
{% endfor %}
|
||||
|
@ -73,9 +71,6 @@
|
|||
|
||||
<main>
|
||||
<div class="plugins-container">
|
||||
<plugin tag="execute" key="execute" :class="{hidden: selectedPlugin != 'execute'}"
|
||||
config="{{ utils.to_json(procedures) }}"></plugin>
|
||||
|
||||
<plugin v-for="(conf, plugin) in {{ utils.to_json(templates) }}"
|
||||
:tag="plugin.replace(/\./g, '-')"
|
||||
:key="plugin"
|
||||
|
|
|
@ -20,12 +20,6 @@
|
|||
|
||||
<nav>
|
||||
<ul>
|
||||
<li :class="{selected: 'execute' == selectedPlugin}" title="execute">
|
||||
<a href="#execute" @click="selectedPlugin = 'execute'">
|
||||
<i class="{{ pluginIcons['execute'] }}"></i>
|
||||
</a>
|
||||
</li>
|
||||
|
||||
{% for plugin in plugins|sort %}
|
||||
<li :class="{selected: '{{ plugin }}' == selectedPlugin}" title="{{ plugin }}">
|
||||
<a href="#{{ plugin }}" @click="selectedPlugin = '{{ plugin }}'">
|
||||
|
|
Loading…
Reference in a new issue