aboutsummaryrefslogtreecommitdiffstats
path: root/openecomp-ui/src/sdc-app/onboarding/softwareProduct/components/monitoring/SoftwareProductComponentsMonitoringActionHelper.js
blob: 3db708bc92117f9b9c116f95272ef24b97ffe5bc (plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
/*!
 * Copyright (C) 2017 AT&T Intellectual Property. All rights reserved.
 *
 * 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 i18n from 'nfvo-utils/i18n/i18n.js';
import RestAPIUtil from 'nfvo-utils/RestAPIUtil.js';
import Configuration from 'sdc-app/config/Configuration.js';
import {actionTypes} from './SoftwareProductComponentsMonitoringConstants.js';
import {actionTypes as modalActionTypes} from 'nfvo-components/modal/GlobalModalConstants.js';

function baseUrl(vspId, version, componentId) {
	const versionId = version.id;
	const restPrefix = Configuration.get('restPrefix');
	return `${restPrefix}/v1.0/vendor-software-products/${vspId}/versions/${versionId}/components/${componentId}/uploads`;
}

let onInvalidFileSizeUpload = (dispatch) => dispatch({
	type: modalActionTypes.GLOBAL_MODAL_ERROR,
	data: {
		title: i18n('Upload Failed'),
		msg: i18n('no zip file was uploaded or zip file doesn\'t exist')
	}
});

let uploadFile = (dispatch, {softwareProductId, version, componentId, formData, type}) => {
	return RestAPIUtil.post(`${baseUrl(softwareProductId, version, componentId)}/types/${type}`, formData).then(()=> dispatch({
		type: actionTypes.MONITOR_UPLOADED, data: {filename: formData.get('upload').name, type : type}
	}));
};

let deleteFile = (dispatch, {softwareProductId, version, componentId, type}) => {
	return RestAPIUtil.destroy(`${baseUrl(softwareProductId, version, componentId)}/types/${type}`).then(()=> dispatch({
		type: actionTypes.MONITOR_DELETED,
		data : { type: type}
	}));
};


const SoftwareProductComponentsMonitoringAction = {

	fetchExistingFiles(dispatch, {softwareProductId, version, componentId}){
		return RestAPIUtil.fetch(`${baseUrl(softwareProductId, version, componentId)}`).then(response =>
			dispatch({
				type: actionTypes.MONITOR_FILES_DATA_CHANGE,
				data: response
			})
		);
	},

	uploadFile(dispatch, {softwareProductId, version, componentId, formData, type}){
		if (formData.get('upload').size) {
			return uploadFile(dispatch, {softwareProductId, version, componentId, formData, type});
		}
		else {
			onInvalidFileSizeUpload(dispatch);
		}
	},

	deleteFile(dispatch, {softwareProductId, version, componentId, type}){
		return deleteFile(dispatch, {softwareProductId, version, componentId, type});
	}

};

export default SoftwareProductComponentsMonitoringAction;