summaryrefslogtreecommitdiffstats
path: root/catalog-be/src/main/java/org/openecomp/sdc/be/components/merge/resource/ResourceDataMergeBusinessLogic.java
blob: 9f2d96bf0e25224475d82608da793fe222ae9fcd (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
package org.openecomp.sdc.be.components.merge.resource;

import org.openecomp.sdc.be.components.merge.ComponentsMergeCommand;
import org.openecomp.sdc.be.dao.api.ActionStatus;
import org.openecomp.sdc.be.model.Resource;
import org.openecomp.sdc.common.log.wrappers.Logger;
import org.springframework.stereotype.Component;

import java.util.List;

@Component
public class ResourceDataMergeBusinessLogic implements MergeResourceBusinessLogic {

    private static final Logger log = Logger.getLogger(ResourceDataMergeBusinessLogic.class);
    public static final int FIRST_COMMAND = 0;
    public static final int LAST_COMMAND = Integer.MAX_VALUE;
    public static final int ANY_ORDER_COMMAND = 1;

    private MergeCommandsFactory mergeCommandsFactory;

    public ResourceDataMergeBusinessLogic(MergeCommandsFactory mergeCommandsFactory) {
        this.mergeCommandsFactory = mergeCommandsFactory;
    }

    @Override
    public ActionStatus mergeResourceEntities(Resource oldResource, Resource newResource) {
        if (oldResource == null) {
            return ActionStatus.OK;
        }
        return mergeCommandsFactory.getMergeCommands(oldResource, newResource)
                .either(mergeCommands -> executeMergeCommands(oldResource, newResource, mergeCommands),
                        err -> err);
    }

    private ActionStatus executeMergeCommands(Resource oldResource, Resource newResource, List<? extends ComponentsMergeCommand> componentMergingCommands) {
        for (ComponentsMergeCommand componentMergeCommand : componentMergingCommands) {
            ActionStatus mergeStatus = componentMergeCommand.mergeComponents(oldResource, newResource);
            if (mergeStatus != ActionStatus.OK) {
                log.error("failed on merge command {} of resource {} status is {}", componentMergeCommand.description(), newResource.getUniqueId(), mergeStatus);
                return mergeStatus;
            }
        }
        return ActionStatus.OK;
    }

}