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
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
|
/**
* ============LICENSE_START========================================================================
* ONAP : ccsdk feature sdnr wt odlux
* =================================================================================================
* Copyright (C) 2019 highstreet technologies GmbH 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.
* ============LICENSE_END==========================================================================
*/
import { Action } from '../../../../framework/src/flux/action';
import { Dispatch } from '../../../../framework/src/flux/store';
import { MountedNetworkElementType } from '../models/mountedNetworkElements';
import { RequiredNetworkElementType } from '../models/requiredNetworkElements';
import { connectService } from '../services/connectService';
import { AddSnackbarNotification } from '../../../../framework/src/actions/snackbarActions';
/** Represents the base action. */
export class BaseAction extends Action { }
/** Represents an action causing the store to load all mounted network elements. */
export class LoadAllMountedNetworkElementsAction extends BaseAction { }
/** Represents an action causing the store to update all mounted network elements. */
export class AllMountedNetworkElementsLoadedAction extends BaseAction {
constructor(public mountedNetworkElements: MountedNetworkElementType[] | null, public error?: string) {
super();
}
}
/** Represents an action causing the store to update all mounted network elements. */
export class AddOrUpdateMountedNetworkElement extends BaseAction {
constructor(public mountedNetworkElement: MountedNetworkElementType | null, public error?: string) {
super();
}
}
export class RemoveMountedNetworkElement extends BaseAction {
constructor(public mountId: string) {
super();
}
}
export class UpdateConnectionStateMountedNetworkElement extends BaseAction {
constructor(public mountId: string, connectionState: string) {
super();
}
}
export class UpdateRequiredMountedNetworkElement extends BaseAction {
constructor(public mountId: string, public required: boolean) {
super();
}
}
/**
* Represents an action crator for a async thunk action to add an allready mounted element to the state of this app.
* Note: Use this action to add created object notified by the websocket.
*/
export const addMountedNetworkElementAsyncActionCreator = (mountId: string) => async (dispatch: Dispatch) => {
return connectService.getMountedNetworkElementByMountId(mountId).then(mountedNetworkElement => {
mountedNetworkElement && dispatch(new AddOrUpdateMountedNetworkElement(mountedNetworkElement));
}).catch(error => {
dispatch(new AddOrUpdateMountedNetworkElement(null, error));
});
};
export const updateMountedNetworkElementAsyncActionCreator = (mountId: string) => async (dispatch: Dispatch) => {
return connectService.getMountedNetworkElementByMountId(mountId).then(mountedNetworkElement => {
if (mountedNetworkElement) {
dispatch(new AddOrUpdateMountedNetworkElement(mountedNetworkElement));
} else {
dispatch(new RemoveMountedNetworkElement(mountId));
}
}).catch(error => {
dispatch(new AddOrUpdateMountedNetworkElement(null, error));
});
};
/** Represents an async thunk action to load all mounted network elements. */
export const loadAllMountedNetworkElementsAsync = (dispatch: Dispatch) => {
dispatch(new LoadAllMountedNetworkElementsAction());
return connectService.getMountedNetworkElementsList().then(mountedNetworkElements => {
mountedNetworkElements && dispatch(new AllMountedNetworkElementsLoadedAction(mountedNetworkElements));
}).catch(error => {
dispatch(new AllMountedNetworkElementsLoadedAction(null, error));
});
};
/** Represents an action crator for a async thunk action to mount a network element. */
export const mountNetworkElementAsyncActionCreator = (networkElement: RequiredNetworkElementType) => (dispatch: Dispatch) => {
return connectService.mountNetworkElement(networkElement).then((success) => {
success && (
dispatch(addMountedNetworkElementAsyncActionCreator(networkElement.mountId)) &&
dispatch(new AddSnackbarNotification({ message: `Requesting mount [${networkElement.mountId}]`, options: { variant: 'info' } }))
) || dispatch(new AddSnackbarNotification({ message: `Failed to mount [${ networkElement.mountId }]`, options: { variant: 'warning' } }));
}).catch(error => {
dispatch(new AddOrUpdateMountedNetworkElement(null, error));
});
};
/** Represents an action crator for a async thunk action to unmount a network element. */
export const unmountNetworkElementAsyncActionCreator = (mountId: string) => (dispatch: Dispatch) => {
return connectService.unmountNetworkElement(mountId).then((success) => {
success && dispatch(new AddSnackbarNotification({ message: `Requesting unmount [${ mountId }]`, options: { variant: 'info' } }))
|| dispatch(new AddSnackbarNotification({ message: `Failed to unmount [${ mountId }]`, options: { variant: 'warning' } }));
}).catch(error => {
dispatch(new AddOrUpdateMountedNetworkElement(null, error));
});
};
|