blob: ccf0f3266903c32c46d4448490ae3396f57c9a60 [file] [log] [blame]
Madan Jampani3e033bd2015-04-08 13:03:49 -07001package org.onosproject.store.core.impl;
2
3import static org.slf4j.LoggerFactory.getLogger;
4
5import org.apache.felix.scr.annotations.Activate;
6import org.apache.felix.scr.annotations.Component;
7import org.apache.felix.scr.annotations.Deactivate;
8import org.apache.felix.scr.annotations.Reference;
9import org.apache.felix.scr.annotations.ReferenceCardinality;
10import org.apache.felix.scr.annotations.Service;
11import org.onosproject.store.Timestamp;
12import org.onosproject.store.impl.LogicalTimestamp;
13import org.onosproject.store.service.AtomicCounter;
14import org.onosproject.store.service.LogicalClockService;
15import org.onosproject.store.service.StorageService;
16import org.slf4j.Logger;
17
18/**
19 * LogicalClockService implementation based on a AtomicCounter.
20 */
21@Component(immediate = true, enabled = true)
22@Service
23public class LogicalClockManager implements LogicalClockService {
24
25 private final Logger log = getLogger(getClass());
26
27 @Reference(cardinality = ReferenceCardinality.MANDATORY_UNARY)
28 protected StorageService storageService;
29
30 private static final String SYSTEM_LOGICAL_CLOCK_COUNTER_NAME = "sys-clock-counter";
31 private AtomicCounter atomicCounter;
32
33 @Activate
34 public void activate() {
35 atomicCounter = storageService.atomicCounterBuilder()
36 .withName(SYSTEM_LOGICAL_CLOCK_COUNTER_NAME)
37 .withPartitionsDisabled()
38 .build();
Madan Jampani5756c352015-04-29 00:23:58 -070039 log.info("Started");
Madan Jampani3e033bd2015-04-08 13:03:49 -070040 }
41
42 @Deactivate
43 public void deactivate() {
Madan Jampani5756c352015-04-29 00:23:58 -070044 log.info("Stopped");
Madan Jampani3e033bd2015-04-08 13:03:49 -070045 }
46
47 @Override
48 public Timestamp getTimestamp() {
49 return new LogicalTimestamp(atomicCounter.incrementAndGet());
50 }
51}