009a0456633c4cd793cfba517843a5d3ef2ef993
[sdc.git] /
1 /*-
2  * ============LICENSE_START=======================================================
3  * SDC
4  * ================================================================================
5  * Copyright (C) 2019 AT&T Intellectual Property. All rights reserved.
6  * ================================================================================
7  * Licensed under the Apache License, Version 2.0 (the "License");
8  * you may not use this file except in compliance with the License.
9  * You may obtain a copy of the License at
10  * 
11  *      http://www.apache.org/licenses/LICENSE-2.0
12  * 
13  * Unless required by applicable law or agreed to in writing, software
14  * distributed under the License is distributed on an "AS IS" BASIS,
15  * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
16  * See the License for the specific language governing permissions and
17  * limitations under the License.
18  * ============LICENSE_END=========================================================
19  */
20
21 package org.openecomp.sdc.be.components.merge.resource;
22
23 import org.openecomp.sdc.be.components.merge.ComponentsMergeCommand;
24 import org.openecomp.sdc.be.dao.api.ActionStatus;
25 import org.openecomp.sdc.be.model.Resource;
26 import org.openecomp.sdc.common.log.wrappers.Logger;
27 import org.springframework.stereotype.Component;
28
29 import java.util.List;
30
31 @Component
32 public class ResourceDataMergeBusinessLogic implements MergeResourceBusinessLogic {
33
34     private static final Logger log = Logger.getLogger(ResourceDataMergeBusinessLogic.class);
35     public static final int FIRST_COMMAND = 0;
36     public static final int LAST_COMMAND = Integer.MAX_VALUE;
37     public static final int ANY_ORDER_COMMAND = 1;
38
39     private MergeCommandsFactory mergeCommandsFactory;
40
41     public ResourceDataMergeBusinessLogic(MergeCommandsFactory mergeCommandsFactory) {
42         this.mergeCommandsFactory = mergeCommandsFactory;
43     }
44
45     @Override
46     public ActionStatus mergeResourceEntities(Resource oldResource, Resource newResource) {
47         if (oldResource == null) {
48             return ActionStatus.OK;
49         }
50         return mergeCommandsFactory.getMergeCommands(oldResource, newResource)
51                 .either(mergeCommands -> executeMergeCommands(oldResource, newResource, mergeCommands),
52                         err -> err);
53     }
54
55     private ActionStatus executeMergeCommands(Resource oldResource, Resource newResource, List<? extends ComponentsMergeCommand> componentMergingCommands) {
56         for (ComponentsMergeCommand componentMergeCommand : componentMergingCommands) {
57             ActionStatus mergeStatus = componentMergeCommand.mergeComponents(oldResource, newResource);
58             if (mergeStatus != ActionStatus.OK) {
59                 log.error("failed on merge command {} of resource {} status is {}", componentMergeCommand.description(), newResource.getUniqueId(), mergeStatus);
60                 return mergeStatus;
61             }
62         }
63         return ActionStatus.OK;
64     }
65
66 }