2020-11-02 13:36:10 +00:00
|
|
|
Ext.define('PBS.window.AddTfaRecovery', {
|
2021-01-13 11:06:51 +00:00
|
|
|
extend: 'Proxmox.window.Edit',
|
2020-11-02 13:36:10 +00:00
|
|
|
alias: 'widget.pbsAddTfaRecovery',
|
|
|
|
mixins: ['Proxmox.Mixin.CBind'],
|
|
|
|
|
|
|
|
onlineHelp: 'user_mgmt',
|
2021-01-13 11:06:51 +00:00
|
|
|
isCreate: true,
|
|
|
|
isAdd: true,
|
|
|
|
subject: gettext('TFA recovery keys'),
|
2020-11-02 13:36:10 +00:00
|
|
|
width: 512,
|
2021-01-13 11:06:51 +00:00
|
|
|
method: 'POST',
|
2020-11-02 13:36:10 +00:00
|
|
|
|
|
|
|
fixedUser: false,
|
|
|
|
|
2021-01-13 11:06:51 +00:00
|
|
|
url: '/api2/extjs/access/tfa',
|
|
|
|
submitUrl: function(url, values) {
|
|
|
|
let userid = values.userid;
|
|
|
|
delete values.userid;
|
|
|
|
return `${url}/${userid}`;
|
|
|
|
},
|
2020-11-02 13:36:10 +00:00
|
|
|
|
2021-01-13 11:06:51 +00:00
|
|
|
apiCallDone: function(success, response) {
|
|
|
|
if (!success) {
|
|
|
|
return;
|
|
|
|
}
|
|
|
|
|
|
|
|
let values = response.result.data.recovery.join("\n");
|
|
|
|
Ext.create('PBS.window.TfaRecoveryShow', {
|
|
|
|
autoShow: true,
|
|
|
|
values,
|
|
|
|
});
|
2020-11-02 13:36:10 +00:00
|
|
|
},
|
|
|
|
|
|
|
|
viewModel: {
|
|
|
|
data: {
|
|
|
|
has_entry: false,
|
|
|
|
},
|
|
|
|
},
|
|
|
|
|
|
|
|
controller: {
|
|
|
|
xclass: 'Ext.app.ViewController',
|
|
|
|
hasEntry: async function(userid) {
|
|
|
|
let me = this;
|
|
|
|
let view = me.getView();
|
|
|
|
|
|
|
|
try {
|
|
|
|
await PBS.Async.api2({
|
2021-01-13 11:06:51 +00:00
|
|
|
url: `${view.url}/${userid}/recovery`,
|
2020-11-02 13:36:10 +00:00
|
|
|
method: 'GET',
|
|
|
|
});
|
|
|
|
return true;
|
|
|
|
} catch (_ex) {
|
|
|
|
return false;
|
|
|
|
}
|
|
|
|
},
|
|
|
|
|
2021-01-13 11:06:51 +00:00
|
|
|
init: function(view) {
|
2020-11-02 13:36:10 +00:00
|
|
|
this.onUseridChange(null, Proxmox.UserName);
|
|
|
|
},
|
|
|
|
|
2021-01-13 11:06:51 +00:00
|
|
|
onUseridChange: async function(field, userid) {
|
2020-11-02 13:36:10 +00:00
|
|
|
let me = this;
|
|
|
|
|
|
|
|
me.userid = userid;
|
|
|
|
|
|
|
|
let has_entry = await me.hasEntry(userid);
|
|
|
|
me.getViewModel().set('has_entry', has_entry);
|
|
|
|
},
|
|
|
|
},
|
|
|
|
|
|
|
|
items: [
|
|
|
|
{
|
|
|
|
xtype: 'pmxDisplayEditField',
|
|
|
|
name: 'userid',
|
|
|
|
cbind: {
|
|
|
|
editable: (get) => !get('fixedUser'),
|
|
|
|
},
|
|
|
|
fieldLabel: gettext('User'),
|
|
|
|
editConfig: {
|
|
|
|
xtype: 'pbsUserSelector',
|
|
|
|
allowBlank: false,
|
2021-01-13 11:06:51 +00:00
|
|
|
validator: function(_value) {
|
|
|
|
return !this.up('window').getViewModel().get('has_entry');
|
|
|
|
},
|
2020-11-02 13:36:10 +00:00
|
|
|
},
|
|
|
|
renderer: Ext.String.htmlEncode,
|
|
|
|
value: Proxmox.UserName,
|
|
|
|
listeners: {
|
|
|
|
change: 'onUseridChange',
|
|
|
|
},
|
|
|
|
},
|
2021-01-13 11:06:51 +00:00
|
|
|
{
|
|
|
|
xtype: 'hiddenfield',
|
|
|
|
name: 'type',
|
|
|
|
value: 'recovery',
|
|
|
|
},
|
2020-11-02 13:36:10 +00:00
|
|
|
{
|
|
|
|
xtype: 'displayfield',
|
|
|
|
bind: {
|
|
|
|
hidden: '{!has_entry}',
|
|
|
|
},
|
2021-01-13 11:06:51 +00:00
|
|
|
hidden: true,
|
|
|
|
userCls: 'pmx-hint',
|
2020-11-02 13:36:10 +00:00
|
|
|
value: gettext('User already has recovery keys.'),
|
|
|
|
},
|
|
|
|
{
|
|
|
|
xtype: 'textfield',
|
|
|
|
inputType: 'password',
|
|
|
|
fieldLabel: gettext('Password'),
|
|
|
|
minLength: 5,
|
|
|
|
reference: 'password',
|
|
|
|
name: 'password',
|
|
|
|
allowBlank: false,
|
|
|
|
validateBlank: true,
|
2021-01-13 11:06:51 +00:00
|
|
|
hidden: Proxmox.UserName === 'root@pam',
|
|
|
|
disabled: Proxmox.UserName === 'root@pam',
|
2020-11-02 13:36:10 +00:00
|
|
|
emptyText: gettext('verify current password'),
|
|
|
|
},
|
|
|
|
],
|
|
|
|
});
|
|
|
|
|
|
|
|
Ext.define('PBS.window.TfaRecoveryShow', {
|
|
|
|
extend: 'Ext.window.Window',
|
|
|
|
alias: ['widget.pbsTfaRecoveryShow'],
|
|
|
|
mixins: ['Proxmox.Mixin.CBind'],
|
|
|
|
|
|
|
|
width: 600,
|
|
|
|
modal: true,
|
|
|
|
resizable: false,
|
|
|
|
title: gettext('Recovery Keys'),
|
|
|
|
|
|
|
|
items: [
|
|
|
|
{
|
2021-01-13 11:06:52 +00:00
|
|
|
xtype: 'form',
|
|
|
|
layout: 'anchor',
|
2020-11-02 13:36:10 +00:00
|
|
|
bodyPadding: 10,
|
|
|
|
border: false,
|
|
|
|
fieldDefaults: {
|
|
|
|
anchor: '100%',
|
|
|
|
},
|
|
|
|
items: [
|
|
|
|
{
|
|
|
|
xtype: 'textarea',
|
|
|
|
editable: false,
|
|
|
|
inputId: 'token-secret-value',
|
|
|
|
cbind: {
|
|
|
|
value: '{values}',
|
|
|
|
},
|
|
|
|
fieldStyle: {
|
|
|
|
'fontFamily': 'monospace',
|
|
|
|
},
|
|
|
|
height: '160px',
|
|
|
|
},
|
2021-01-13 11:06:52 +00:00
|
|
|
{
|
|
|
|
xtype: 'displayfield',
|
|
|
|
border: false,
|
|
|
|
padding: '5 0 0 0',
|
|
|
|
userCls: 'pmx-hint',
|
|
|
|
value: gettext('Please record recovery keys - they will only be displayed now'),
|
|
|
|
},
|
2020-11-02 13:36:10 +00:00
|
|
|
],
|
|
|
|
},
|
|
|
|
],
|
|
|
|
buttons: [
|
|
|
|
{
|
|
|
|
handler: function(b) {
|
|
|
|
document.getElementById('token-secret-value').select();
|
|
|
|
document.execCommand("copy");
|
|
|
|
},
|
|
|
|
text: gettext('Copy Secret Value'),
|
|
|
|
},
|
|
|
|
],
|
|
|
|
});
|