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);
}
}
}
|