blob: 366df7112bace4d9c2c2467dc7c45dad0684472d [file] [log] [blame]
Thomas Vachuska58de4162015-09-10 16:15:33 -07001/*
Brian O'Connora09fe5b2017-08-03 21:12:30 -07002 * Copyright 2015-present Open Networking Foundation
Thomas Vachuska58de4162015-09-10 16:15:33 -07003 *
4 * Licensed under the Apache License, Version 2.0 (the "License");
5 * you may not use this file except in compliance with the License.
6 * You may obtain a copy of the License at
7 *
8 * http://www.apache.org/licenses/LICENSE-2.0
9 *
10 * Unless required by applicable law or agreed to in writing, software
11 * distributed under the License is distributed on an "AS IS" BASIS,
12 * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
13 * See the License for the specific language governing permissions and
14 * limitations under the License.
15 */
Madan Jampani3e033bd2015-04-08 13:03:49 -070016package org.onosproject.store.core.impl;
17
Madan Jampanif4c88502016-01-21 12:35:36 -080018import org.onosproject.store.LogicalTimestamp;
Madan Jampani3e033bd2015-04-08 13:03:49 -070019import org.onosproject.store.Timestamp;
Madan Jampani3e033bd2015-04-08 13:03:49 -070020import org.onosproject.store.service.AtomicCounter;
21import org.onosproject.store.service.LogicalClockService;
22import org.onosproject.store.service.StorageService;
Ray Milkeyd84f89b2018-08-17 14:54:17 -070023import org.osgi.service.component.annotations.Activate;
24import org.osgi.service.component.annotations.Component;
25import org.osgi.service.component.annotations.Deactivate;
26import org.osgi.service.component.annotations.Reference;
27import org.osgi.service.component.annotations.ReferenceCardinality;
Madan Jampani3e033bd2015-04-08 13:03:49 -070028import org.slf4j.Logger;
29
Heedo Kang4a47a302016-02-29 17:40:23 +090030import static org.onosproject.security.AppGuard.checkPermission;
31import static org.onosproject.security.AppPermission.Type.CLOCK_WRITE;
Ray Milkeyd84f89b2018-08-17 14:54:17 -070032import static org.slf4j.LoggerFactory.getLogger;
Heedo Kang4a47a302016-02-29 17:40:23 +090033
Madan Jampani3e033bd2015-04-08 13:03:49 -070034/**
Madan Jampani78be2492016-06-03 23:27:07 -070035 * LogicalClockService implementation based on a {@link AtomicCounter}.
Madan Jampani3e033bd2015-04-08 13:03:49 -070036 */
Ray Milkeyd84f89b2018-08-17 14:54:17 -070037@Component(immediate = true, service = LogicalClockService.class)
Madan Jampani3e033bd2015-04-08 13:03:49 -070038public class LogicalClockManager implements LogicalClockService {
39
40 private final Logger log = getLogger(getClass());
41
Ray Milkeyd84f89b2018-08-17 14:54:17 -070042 @Reference(cardinality = ReferenceCardinality.MANDATORY)
Madan Jampani3e033bd2015-04-08 13:03:49 -070043 protected StorageService storageService;
44
45 private static final String SYSTEM_LOGICAL_CLOCK_COUNTER_NAME = "sys-clock-counter";
46 private AtomicCounter atomicCounter;
47
48 @Activate
49 public void activate() {
Madan Jampanid5714e02016-04-19 14:15:20 -070050 atomicCounter = storageService.getAtomicCounter(SYSTEM_LOGICAL_CLOCK_COUNTER_NAME);
Madan Jampani5756c352015-04-29 00:23:58 -070051 log.info("Started");
Madan Jampani3e033bd2015-04-08 13:03:49 -070052 }
53
54 @Deactivate
55 public void deactivate() {
Madan Jampani5756c352015-04-29 00:23:58 -070056 log.info("Stopped");
Madan Jampani3e033bd2015-04-08 13:03:49 -070057 }
58
59 @Override
60 public Timestamp getTimestamp() {
Heedo Kang4a47a302016-02-29 17:40:23 +090061 checkPermission(CLOCK_WRITE);
Madan Jampani3e033bd2015-04-08 13:03:49 -070062 return new LogicalTimestamp(atomicCounter.incrementAndGet());
63 }
Sho SHIMIZU5c396e32016-08-12 15:19:12 -070064}