1. Update 'snaphost' to 'volume snaphost', 'backup' to 'volume backup' 2. Update e2e case Change-Id: I74dee2e2da7cbaac4ba7607c83848b28cfb81cde
208 lines
5.3 KiB
JavaScript
208 lines
5.3 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 { getOptions } from 'utils/index';
|
|
import { FolderOutlined, FolderAddOutlined } from '@ant-design/icons';
|
|
import globalProjectStore from 'stores/keystone/project';
|
|
import globalBackupStore from 'stores/cinder/backup';
|
|
|
|
export const backupStatus = {
|
|
available: t('Available'),
|
|
error: t('Error'),
|
|
updating: t('Updating'),
|
|
deleting: t('Deleting'),
|
|
error_deleting: t('Error Deleting'),
|
|
restoring: t('Restoring'),
|
|
creating: t('Creating'),
|
|
};
|
|
|
|
export const createTip = (
|
|
<span>
|
|
<span style={{ fontWeight: 600 }}>
|
|
{t(
|
|
'When you do online backup of the volume that has been bound, you need to pay attention to the following points:'
|
|
)}
|
|
</span>
|
|
<p>
|
|
{t(
|
|
'1. The backup can only capture the data that has been written to the volume at the beginning of the backup task, excluding the data in the cache at that time.'
|
|
)}
|
|
</p>
|
|
<p>
|
|
{t(
|
|
'2. To ensure the integrity of the data, it is recommended that you suspend the write operation of all files when creating a backup.'
|
|
)}
|
|
</p>
|
|
</span>
|
|
);
|
|
|
|
export const backupModeList = [
|
|
{ value: false, label: t('Full Backup') },
|
|
{ value: true, label: t('Increment Backup') },
|
|
];
|
|
|
|
export const modeTip = t(
|
|
'Create a full backup, the system will automatically create a new backup chain, the full backup name is the backup chain name; Create an incremental backup, the system will automatically create an incremental backup under the newly created backup chain.'
|
|
);
|
|
|
|
export const backupColumns = [];
|
|
|
|
export const backupPointColumns = [
|
|
{
|
|
title: t('Name'),
|
|
dataIndex: 'name',
|
|
ellipsis: true,
|
|
},
|
|
{
|
|
title: t('Size'),
|
|
dataIndex: 'size',
|
|
isHideable: true,
|
|
render: (value) => `${value} GiB`,
|
|
},
|
|
{
|
|
title: t('Status'),
|
|
dataIndex: 'status',
|
|
render: (value) => backupStatus[value] || value,
|
|
},
|
|
{
|
|
title: t('Backup Mode'),
|
|
dataIndex: 'is_incremental',
|
|
isHideable: true,
|
|
render: (value) => {
|
|
if (value) {
|
|
return (
|
|
<>
|
|
{' '}
|
|
<FolderAddOutlined />
|
|
<span style={{ marginLeft: 8 }}>{t('Incremental Backup')}</span>
|
|
</>
|
|
);
|
|
}
|
|
return (
|
|
<>
|
|
{' '}
|
|
<FolderOutlined />
|
|
<span style={{ marginLeft: 8 }}>{t('Full Backup')}</span>
|
|
</>
|
|
);
|
|
},
|
|
stringify: (value) => (value ? t('Incremental Backup') : t('Full Backup')),
|
|
},
|
|
{
|
|
title: t('description'),
|
|
dataIndex: 'description',
|
|
ellipsis: true,
|
|
isHideable: true,
|
|
},
|
|
{
|
|
title: t('Created At'),
|
|
dataIndex: 'created_at',
|
|
isHideable: true,
|
|
valueRender: 'sinceTime',
|
|
},
|
|
];
|
|
|
|
export const backupPointFilters = [
|
|
{
|
|
label: t('Name'),
|
|
name: 'name',
|
|
ellipsis: true,
|
|
},
|
|
{
|
|
label: t('Status'),
|
|
name: 'status',
|
|
options: getOptions(backupStatus),
|
|
},
|
|
];
|
|
|
|
export const restoreTip = (
|
|
<span>
|
|
<span style={{ fontWeight: 600 }}>
|
|
{t(
|
|
'When you restore a backup, you need to meet one of the following conditions:'
|
|
)}
|
|
</span>
|
|
<p>{t('1. The volume associated with the backup is available.')}</p>
|
|
<p>
|
|
{t(
|
|
'2. The volume associated with the backup has been mounted, and the instance is shut down.'
|
|
)}
|
|
</p>
|
|
</span>
|
|
);
|
|
|
|
// deal with quota
|
|
export async function fetchQuota(self) {
|
|
self.setState({
|
|
quota: {},
|
|
quotaLoading: true,
|
|
});
|
|
const result = await globalProjectStore.fetchProjectCinderQuota();
|
|
self.setState({
|
|
quota: result,
|
|
quotaLoading: false,
|
|
});
|
|
}
|
|
|
|
export const getQuota = (cinderQuota) => {
|
|
const { backups = {}, backup_gigabytes: gigabytes = {} } = cinderQuota || {};
|
|
return {
|
|
backups,
|
|
gigabytes,
|
|
};
|
|
};
|
|
|
|
export const getAdd = (cinderQuota) => {
|
|
const { backups, gigabytes } = getQuota(cinderQuota);
|
|
const { left = 0 } = backups || {};
|
|
const { left: sizeLeft = 0, limit } = gigabytes || {};
|
|
const { currentVolumeSize = 0 } = globalBackupStore;
|
|
const add =
|
|
left !== 0 && (limit === -1 || sizeLeft >= currentVolumeSize) ? 1 : 0;
|
|
return {
|
|
add,
|
|
addSize: add === 1 ? currentVolumeSize : 0,
|
|
};
|
|
};
|
|
|
|
export const getQuotaInfo = (self) => {
|
|
const { quota = {}, quotaLoading } = self.state;
|
|
if (quotaLoading) {
|
|
return [];
|
|
}
|
|
const { backups = {}, gigabytes = {} } = getQuota(quota);
|
|
const { add, addSize } = getAdd(quota);
|
|
const backupData = {
|
|
...backups,
|
|
add,
|
|
name: 'backup',
|
|
title: t('Volume Backup'),
|
|
};
|
|
const sizeData = {
|
|
...gigabytes,
|
|
add: addSize,
|
|
name: 'gigabytes',
|
|
title: t('Volume Backup Gigabytes (GiB)'),
|
|
type: 'line',
|
|
};
|
|
return [backupData, sizeData];
|
|
};
|
|
|
|
export const checkQuotaDisable = () => {
|
|
const { cinderQuota = {} } = globalProjectStore;
|
|
const { add } = getAdd(cinderQuota);
|
|
return add === 0;
|
|
};
|