[pve-devel] [PATCH manager 6/6] ui: add ACMEClusterView
Dominik Csapak
d.csapak at proxmox.com
Tue May 5 14:38:18 CEST 2020
to show the list of accounts and defined plugins
for now we ignore 'standalone' plugins here and only show 'dns' ones
Signed-off-by: Dominik Csapak <d.csapak at proxmox.com>
---
www/manager6/Makefile | 1 +
www/manager6/dc/ACMEClusterView.js | 206 +++++++++++++++++++++++++++++
www/manager6/dc/Config.js | 10 ++
3 files changed, 217 insertions(+)
create mode 100644 www/manager6/dc/ACMEClusterView.js
diff --git a/www/manager6/Makefile b/www/manager6/Makefile
index fb4c51bb..4deb7990 100644
--- a/www/manager6/Makefile
+++ b/www/manager6/Makefile
@@ -217,6 +217,7 @@ JSSRC= \
ha/GroupEdit.js \
ha/Groups.js \
ha/Fencing.js \
+ dc/ACMEClusterView.js \
dc/ACMEPluginEdit.js \
dc/Summary.js \
grid/Replication.js \
diff --git a/www/manager6/dc/ACMEClusterView.js b/www/manager6/dc/ACMEClusterView.js
new file mode 100644
index 00000000..a0bbd8a5
--- /dev/null
+++ b/www/manager6/dc/ACMEClusterView.js
@@ -0,0 +1,206 @@
+Ext.define('pve-acme-accounts', {
+ extend: 'Ext.data.Model',
+ fields: ['name'],
+ proxy: {
+ type: 'proxmox',
+ url: "/api2/json/cluster/acme/account",
+ },
+ idProperty: 'name',
+});
+
+Ext.define('pve-acme-plugins', {
+ extend: 'Ext.data.Model',
+ fields: ['type', 'plugin'],
+ proxy: {
+ type: 'proxmox',
+ url: "/api2/json/cluster/acme/plugins",
+ },
+ idProperty: 'plugin',
+});
+
+Ext.define('PVE.dc.ACMEAccountView', {
+ extend: 'Ext.grid.Panel',
+ alias: 'widget.pveACMEAccountView',
+
+ title: gettext('Accounts'),
+
+ controller: {
+ xclass: 'Ext.app.ViewController',
+
+ addAccount: function() {
+ let me = this;
+ Ext.create('PVE.node.ACMEAccountCreate', {
+ taskDone: function() {
+ me.reload();
+ },
+ }).show();
+ },
+
+ viewAccount: function() {
+ let me = this;
+ let view = me.getView();
+ let selection = view.getSelection();
+ if (selection.length < 1) return;
+ Ext.create('PVE.node.ACMEAccountView', {
+ accountname: selection[0].data.name,
+ }).show();
+ },
+
+ reload: function() {
+ let me = this;
+ let view = me.getView();
+ view.getStore().load();
+ },
+ },
+
+ columns: [
+ {
+ dataIndex: 'name',
+ text: gettext('Name'),
+ renderer: Ext.String.htmlEncode,
+ flex: 1,
+ },
+ ],
+
+ tbar: [
+ {
+ xtype: 'proxmoxButton',
+ text: gettext('Add'),
+ selModel: false,
+ handler: 'addAccount',
+ },
+ {
+ xtype: 'proxmoxButton',
+ text: gettext('View'),
+ handler: 'viewAccount',
+ disabled: true,
+ },
+ {
+ xtype: 'proxmoxStdRemoveButton',
+ baseurl: '/cluster/acme/account',
+ callback: 'reload',
+ },
+ ],
+
+ listeners: {
+ itemdblclick: 'viewAccount',
+ },
+
+ store: {
+ model: 'pve-acme-accounts',
+ autoLoad: true,
+ sorters: 'name',
+ },
+});
+
+Ext.define('PVE.dc.ACMEPluginView', {
+ extend: 'Ext.grid.Panel',
+ alias: 'widget.pveACMEPluginView',
+
+ title: gettext('Plugins'),
+
+ controller: {
+ xclass: 'Ext.app.ViewController',
+
+ addPlugin: function() {
+ let me = this;
+ Ext.create('PVE.dc.ACMEPluginEditor', {
+ isCreate: true,
+ apiCallDone: function() {
+ me.reload();
+ },
+ }).show();
+ },
+
+ editPlugin: function() {
+ let me = this;
+ let view = me.getView();
+ let selection = view.getSelection();
+ if (selection.length < 1) return;
+ let plugin = selection[0].data.plugin;
+ Ext.create('PVE.dc.ACMEPluginEditor', {
+ url: `/cluster/acme/plugins/${plugin}`,
+ apiCallDone: function() {
+ me.reload();
+ },
+ }).show();
+ },
+
+ reload: function() {
+ let me = this;
+ let view = me.getView();
+ view.getStore().load();
+ },
+ },
+
+ columns: [
+ {
+ dataIndex: 'plugin',
+ text: gettext('Plugin'),
+ renderer: Ext.String.htmlEncode,
+ flex: 1,
+ },
+ {
+ dataIndex: 'api',
+ text: gettext('API'),
+ renderer: Ext.String.htmlEncode,
+ flex: 1,
+ },
+ ],
+
+ tbar: [
+ {
+ xtype: 'proxmoxButton',
+ text: gettext('Add'),
+ handler: 'addPlugin',
+ selModel: false,
+ },
+ {
+ xtype: 'proxmoxButton',
+ text: gettext('Edit'),
+ handler: 'editPlugin',
+ disabled: true,
+ },
+ {
+ xtype: 'proxmoxStdRemoveButton',
+ baseurl: '/cluster/acme/plugins',
+ callback: 'reload',
+ },
+ ],
+
+ listeners: {
+ itemdblclick: 'editPlugin',
+ },
+
+ store: {
+ model: 'pve-acme-plugins',
+ autoLoad: true,
+ filters: item => !!item.data.api,
+ sorters: 'plugin',
+ },
+});
+
+Ext.define('PVE.dc.ACMEClusterView', {
+ extend: 'Ext.panel.Panel',
+ alias: 'widget.pveACMEClusterView',
+
+ stateful: true,
+ stateId: 'grid-acme',
+
+ layout: 'border',
+
+ items: [
+ {
+ region: 'west',
+ width: '25%',
+ border: false,
+ split: true,
+ xtype: 'pveACMEAccountView',
+ },
+ {
+ region: 'center',
+ border: false,
+ xtype: 'pveACMEPluginView',
+ },
+ ],
+});
diff --git a/www/manager6/dc/Config.js b/www/manager6/dc/Config.js
index ec099494..905c3dc0 100644
--- a/www/manager6/dc/Config.js
+++ b/www/manager6/dc/Config.js
@@ -178,6 +178,16 @@ Ext.define('PVE.dc.Config', {
itemId: 'sdnvnet'
});
}
+
+ if (Proxmox.UserName === 'root at pam') {
+ me.items.push({
+ xtype: 'pveACMEClusterView',
+ title: gettext('ACME'),
+ iconCls: 'fa fa-certificate',
+ itemId: 'acme'
+ });
+ }
+
me.items.push({
xtype: 'pveFirewallRules',
title: gettext('Firewall'),
--
2.20.1
More information about the pve-devel
mailing list