aboutsummaryrefslogtreecommitdiffstats
path: root/catalog-be/src/main/java/org/openecomp/sdc/be/components/impl/ComponentLocker.java
blob: 8328098980ae50fa6a388516cb2407c008f64822 (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
package org.openecomp.sdc.be.components.impl;

import org.openecomp.sdc.be.datatypes.enums.ComponentTypeEnum;
import org.openecomp.sdc.be.datatypes.enums.NodeTypeEnum;
import org.openecomp.sdc.be.model.Component;
import org.openecomp.sdc.be.model.operations.StorageException;
import org.openecomp.sdc.be.model.operations.api.StorageOperationStatus;
import org.openecomp.sdc.be.model.operations.impl.GraphLockOperation;
import org.openecomp.sdc.common.log.wrappers.Logger;


@org.springframework.stereotype.Component
public class ComponentLocker  {

    private static final Logger log = Logger.getLogger(ComponentLocker.class.getName());
    private final GraphLockOperation graphLockOperation;

    public ComponentLocker(GraphLockOperation graphLockOperation) {
        this.graphLockOperation = graphLockOperation;
    }

    public void lock(String id, ComponentTypeEnum componentType) {
        lock(id, componentType.getNodeType());
    }

    public void lock(Component component) {
        doLockComponent(component.getUniqueId(), component.getComponentType().getNodeType());
    }

    public void lock(String id, NodeTypeEnum nodeTypeEnum) {
        doLockComponent(id, nodeTypeEnum);
    }

    private void doLockComponent(String id, NodeTypeEnum nodeTypeEnum) {
        log.debug("#doLockComponent - locking component {} of type {}", id, nodeTypeEnum);
        StorageOperationStatus storageOperationStatus = graphLockOperation.lockComponent(id, nodeTypeEnum);
        if (storageOperationStatus != StorageOperationStatus.OK) {
     		log.debug("#doLockComponent - failed to lock component {} with status {}", id, storageOperationStatus);
            throw new StorageException(storageOperationStatus);
        }
    }

    public void unlock(String id, ComponentTypeEnum componentType) {
        unlock(id, componentType.getNodeType());
    }

    public void unlock(String id, NodeTypeEnum nodeTypeEnum) {
        log.debug("#unlock - unlocking component {} of type {}", id, nodeTypeEnum);
        StorageOperationStatus storageOperationStatus = graphLockOperation.unlockComponent(id, nodeTypeEnum);
        if (storageOperationStatus != StorageOperationStatus.OK) {
            log.debug("#unlock - failed to unlock component {} with status {}", id, storageOperationStatus);
            throw new StorageException(storageOperationStatus, id);
        }
    }
}