skyline/src/pages/network/containers/VPN/IPsecPolicy/actions/Edit.jsx
zhuyue fff9d8ee02 fix: Change vpn tunnel to ipsec site connection
change vpn tunnel to ipsec site connection

Change-Id: Ia59bc87d4e61879b063719c114a02133b7044805
2021-10-11 11:04:55 +08:00

172 lines
4.4 KiB
JavaScript

// Copyright 2021 99cloud
//
// Licensed under the Apache License, Version 2.0 (the "License");
// you may not use this file except in compliance with the License.
// You may obtain a copy of the License at
//
// http://www.apache.org/licenses/LICENSE-2.0
//
// Unless required by applicable law or agreed to in writing, software
// distributed under the License is distributed on an "AS IS" BASIS,
// WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
// See the License for the specific language governing permissions and
// limitations under the License.
import React from 'react';
import { inject, observer } from 'mobx-react';
import { ModalAction } from 'containers/Action';
import globalVpnIPsecPolicyStore from 'stores/neutron/vpn-ipsec-policy';
import globalVpnIPsecConnectionStore from 'stores/neutron/vpn-ipsec-connection';
@inject('rootStore')
@observer
export default class Edit extends ModalAction {
static id = 'edit-vpn-ipsec-policy';
static title = t('Edit VPN IPsec Policy');
static buttonText = t('Edit');
static policy = 'update_ipsecpolicy';
static allowed = () => Promise.resolve(true);
init() {
this.state = {
canSubmit: true,
connections: [],
};
globalVpnIPsecConnectionStore
.fetchList({ ipsecpolicy_id: this.item.id })
.then((connections) => {
connections.length > 0 &&
this.setState({
canSubmit: false,
connections,
});
});
}
get defaultValue() {
const { lifetime, canSubmit, ...rest } = this.item;
return {
...rest,
lifetimeValue: lifetime.value,
};
}
onSubmit = (values) => {
const { lifetimeValue, ...rest } = values;
const data = {
lifetime: {
units: 'seconds',
value: lifetimeValue,
},
...rest,
};
return globalVpnIPsecPolicyStore.update({ id: this.item.id }, data);
};
get formItems() {
const { canSubmit } = this.state;
return [
{
name: 'name',
label: t('Name'),
type: 'input-name',
required: true,
withoutChinese: true,
},
{
name: 'canSubmit',
label: t('Status'),
component: <>{t('In Use')}</>,
validator: () => {
const { connections } = this.state;
if (!canSubmit) {
return Promise.reject(
new Error(`${t(
'Unable to {action}, because : {reason}, instance: {name}.',
{
action: this.name,
name: this.item.name,
reason: t('the policy is in use'),
}
)}\n
${t('Used by tunnel(s): {names}. ID(s): {ids}', {
names: connections.map((i) => i.name).join(', '),
ids: connections.map((i) => i.id).join(', '),
})}`)
);
}
return Promise.resolve(true);
},
hidden: canSubmit,
},
{
name: 'description',
label: t('Description'),
type: 'textarea',
required: false,
},
{
name: 'auth_algorithm',
label: t('Auth Algorithm'),
type: 'select',
options: ['sha1', 'sha256', 'sha384', 'sha512'].map((i) => ({
label: i.toUpperCase(),
value: i,
})),
required: true,
},
{
name: 'encapsulation_mode',
label: t('Encapsulation Mode'),
type: 'select',
options: ['tunnel', 'transport'].map((i) => ({
label: i,
value: i,
})),
required: true,
},
{
name: 'encryption_algorithm',
label: t('Encryption Algorithm'),
type: 'select',
options: ['3des', 'aes-128', 'aes-192', 'aes-256'].map((i) => ({
label: i.toUpperCase(),
value: i,
})),
required: true,
},
{
name: 'pfs',
label: t('PFS'),
type: 'select',
options: ['group2', 'group5', 'group14'].map((i) => ({
label: i,
value: i,
})),
required: true,
},
{
name: 'lifetimeValue',
label: t('Lifetime Value'),
type: 'input-number',
min: 0,
required: true,
},
{
name: 'transform_protocol',
label: t('Transform Protocol'),
type: 'select',
options: ['esp', 'ah', 'ah-esp'].map((i) => ({
label: i,
value: i,
})),
required: true,
},
];
}
}