blob: 322c4859f5f115f41a01f9c3c78225cf3e33046b [file] [log] [blame]
Thomas Vachuska4f1a60c2014-10-28 13:39:07 -07001/*
Brian O'Connor5ab426f2016-04-09 01:19:45 -07002 * Copyright 2014-present Open Networking Laboratory
Thomas Vachuska4f1a60c2014-10-28 13:39:07 -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 */
Brian O'Connorabafb502014-12-02 22:26:20 -080016package org.onosproject.store.device.impl;
Madan Jampani61056bc2014-09-27 09:07:26 -070017
18import static org.slf4j.LoggerFactory.getLogger;
19
Madan Jampani15d773c2015-02-25 15:31:55 -080020import java.util.concurrent.atomic.AtomicLong;
Madan Jampani61056bc2014-09-27 09:07:26 -070021
22import org.apache.felix.scr.annotations.Activate;
23import org.apache.felix.scr.annotations.Component;
24import org.apache.felix.scr.annotations.Deactivate;
Madan Jampani565a66a2015-07-25 17:01:13 -070025import org.apache.felix.scr.annotations.Reference;
26import org.apache.felix.scr.annotations.ReferenceCardinality;
Madan Jampani61056bc2014-09-27 09:07:26 -070027import org.apache.felix.scr.annotations.Service;
Madan Jampani565a66a2015-07-25 17:01:13 -070028import org.onosproject.cluster.ClusterService;
29import org.onosproject.cluster.NodeId;
Brian O'Connorabafb502014-12-02 22:26:20 -080030import org.onosproject.mastership.MastershipTerm;
Madan Jampani565a66a2015-07-25 17:01:13 -070031import org.onosproject.mastership.MastershipTermService;
Brian O'Connorabafb502014-12-02 22:26:20 -080032import org.onosproject.net.DeviceId;
Brian O'Connorabafb502014-12-02 22:26:20 -080033import org.onosproject.net.device.DeviceClockService;
34import org.onosproject.store.Timestamp;
35import org.onosproject.store.impl.MastershipBasedTimestamp;
Madan Jampani61056bc2014-09-27 09:07:26 -070036import org.slf4j.Logger;
37
Yuta HIGUCHI67a527f2014-10-02 22:23:54 -070038/**
39 * Clock service to issue Timestamp based on Device Mastership.
40 */
Madan Jampani61056bc2014-09-27 09:07:26 -070041@Component(immediate = true)
42@Service
Madan Jampani565a66a2015-07-25 17:01:13 -070043public class DeviceClockManager implements DeviceClockService {
Yuta HIGUCHI2e963892014-09-27 13:00:39 -070044
Madan Jampani61056bc2014-09-27 09:07:26 -070045 private final Logger log = getLogger(getClass());
46
Madan Jampani565a66a2015-07-25 17:01:13 -070047 @Reference(cardinality = ReferenceCardinality.MANDATORY_UNARY)
48 protected MastershipTermService mastershipTermService;
49
50 @Reference(cardinality = ReferenceCardinality.MANDATORY_UNARY)
51 protected ClusterService clusterService;
52
53 protected NodeId localNodeId;
54
Madan Jampani15d773c2015-02-25 15:31:55 -080055 private final AtomicLong ticker = new AtomicLong(0);
Yuta HIGUCHI2e963892014-09-27 13:00:39 -070056
Madan Jampani61056bc2014-09-27 09:07:26 -070057 @Activate
58 public void activate() {
Madan Jampani565a66a2015-07-25 17:01:13 -070059 localNodeId = clusterService.getLocalNode().id();
Madan Jampani61056bc2014-09-27 09:07:26 -070060 log.info("Started");
61 }
62
63 @Deactivate
64 public void deactivate() {
65 log.info("Stopped");
66 }
Yuta HIGUCHI2e963892014-09-27 13:00:39 -070067
Madan Jampani61056bc2014-09-27 09:07:26 -070068 @Override
69 public Timestamp getTimestamp(DeviceId deviceId) {
Madan Jampani565a66a2015-07-25 17:01:13 -070070 MastershipTerm term = mastershipTermService.getMastershipTerm(deviceId);
71 if (term == null || !localNodeId.equals(term.master())) {
HIGUCHI Yuta3a6f7cd2015-02-25 18:51:25 -080072 throw new IllegalStateException("Requesting timestamp for " + deviceId + " without mastership");
Madan Jampani61056bc2014-09-27 09:07:26 -070073 }
Yuta HIGUCHI273dcc82014-10-03 00:32:12 -070074 return new MastershipBasedTimestamp(term.termNumber(), ticker.incrementAndGet());
Madan Jampani61056bc2014-09-27 09:07:26 -070075 }
76
77 @Override
Yuta HIGUCHI13c0b872014-10-30 18:09:22 -070078 public boolean isTimestampAvailable(DeviceId deviceId) {
Madan Jampani565a66a2015-07-25 17:01:13 -070079 MastershipTerm term = mastershipTermService.getMastershipTerm(deviceId);
80 return term != null && localNodeId.equals(term.master());
Yuta HIGUCHI13c0b872014-10-30 18:09:22 -070081 }
Madan Jampani61056bc2014-09-27 09:07:26 -070082}