blob: d9da6c6f6da0122c4866a57e3bd90c5bd1ee41f8 [file] [log] [blame]
Thomas Vachuska4f1a60c2014-10-28 13:39:07 -07001/*
2 * Copyright 2014 Open Networking Laboratory
3 *
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.cluster.impl;
tome4729872014-09-23 00:37:37 -070017
Madan Jampani7d2fab22015-03-18 17:21:57 -070018import static com.google.common.base.Preconditions.checkArgument;
19import static com.google.common.base.Preconditions.checkNotNull;
20import static org.slf4j.LoggerFactory.getLogger;
21
22import java.util.Set;
23
tome4729872014-09-23 00:37:37 -070024import org.apache.felix.scr.annotations.Activate;
25import org.apache.felix.scr.annotations.Component;
26import org.apache.felix.scr.annotations.Deactivate;
27import org.apache.felix.scr.annotations.Reference;
28import org.apache.felix.scr.annotations.ReferenceCardinality;
29import org.apache.felix.scr.annotations.Service;
Madan Jampani7d2fab22015-03-18 17:21:57 -070030import org.joda.time.DateTime;
31import org.onlab.packet.IpAddress;
Brian O'Connorabafb502014-12-02 22:26:20 -080032import org.onosproject.cluster.ClusterAdminService;
33import org.onosproject.cluster.ClusterEvent;
34import org.onosproject.cluster.ClusterEventListener;
35import org.onosproject.cluster.ClusterService;
36import org.onosproject.cluster.ClusterStore;
37import org.onosproject.cluster.ClusterStoreDelegate;
38import org.onosproject.cluster.ControllerNode;
39import org.onosproject.cluster.NodeId;
40import org.onosproject.event.AbstractListenerRegistry;
41import org.onosproject.event.EventDeliveryService;
tome4729872014-09-23 00:37:37 -070042import org.slf4j.Logger;
43
tome4729872014-09-23 00:37:37 -070044/**
45 * Implementation of the cluster service.
46 */
Madan Jampanidd6479f2015-03-02 02:23:44 +000047@Component(immediate = true)
tome4729872014-09-23 00:37:37 -070048@Service
tomb41d1ac2014-09-24 01:51:24 -070049public class ClusterManager implements ClusterService, ClusterAdminService {
tome4729872014-09-23 00:37:37 -070050
51 public static final String INSTANCE_ID_NULL = "Instance ID cannot be null";
52 private final Logger log = getLogger(getClass());
53
tom0755a362014-09-24 11:54:43 -070054 private ClusterStoreDelegate delegate = new InternalStoreDelegate();
55
tome4729872014-09-23 00:37:37 -070056 protected final AbstractListenerRegistry<ClusterEvent, ClusterEventListener>
57 listenerRegistry = new AbstractListenerRegistry<>();
58
59 @Reference(cardinality = ReferenceCardinality.MANDATORY_UNARY)
60 protected ClusterStore store;
61
62 @Reference(cardinality = ReferenceCardinality.MANDATORY_UNARY)
63 protected EventDeliveryService eventDispatcher;
64
65 @Activate
66 public void activate() {
tom0755a362014-09-24 11:54:43 -070067 store.setDelegate(delegate);
tome4729872014-09-23 00:37:37 -070068 eventDispatcher.addSink(ClusterEvent.class, listenerRegistry);
69 log.info("Started");
70 }
71
72 @Deactivate
73 public void deactivate() {
tomf80c9722014-09-24 14:49:18 -070074 store.unsetDelegate(delegate);
tome4729872014-09-23 00:37:37 -070075 eventDispatcher.removeSink(ClusterEvent.class);
76 log.info("Stopped");
77 }
78
79 @Override
80 public ControllerNode getLocalNode() {
81 return store.getLocalNode();
82 }
83
84 @Override
85 public Set<ControllerNode> getNodes() {
86 return store.getNodes();
87 }
88
89 @Override
90 public ControllerNode getNode(NodeId nodeId) {
91 checkNotNull(nodeId, INSTANCE_ID_NULL);
92 return store.getNode(nodeId);
93 }
94
95 @Override
96 public ControllerNode.State getState(NodeId nodeId) {
97 checkNotNull(nodeId, INSTANCE_ID_NULL);
98 return store.getState(nodeId);
99 }
100
Madan Jampani7d2fab22015-03-18 17:21:57 -0700101
102 @Override
103 public DateTime getLastUpdated(NodeId nodeId) {
104 return store.getLastUpdated(nodeId);
105 }
106
tome4729872014-09-23 00:37:37 -0700107 @Override
Pavlin Radoslavov444b5192014-10-28 10:45:19 -0700108 public ControllerNode addNode(NodeId nodeId, IpAddress ip, int tcpPort) {
tomee49c372014-09-26 15:14:50 -0700109 checkNotNull(nodeId, INSTANCE_ID_NULL);
110 checkNotNull(ip, "IP address cannot be null");
111 checkArgument(tcpPort > 5000, "TCP port must be > 5000");
112 return store.addNode(nodeId, ip, tcpPort);
113 }
114
115 @Override
tomb41d1ac2014-09-24 01:51:24 -0700116 public void removeNode(NodeId nodeId) {
117 checkNotNull(nodeId, INSTANCE_ID_NULL);
118 store.removeNode(nodeId);
119 }
120
121 @Override
tome4729872014-09-23 00:37:37 -0700122 public void addListener(ClusterEventListener listener) {
123 listenerRegistry.addListener(listener);
124 }
125
126 @Override
127 public void removeListener(ClusterEventListener listener) {
128 listenerRegistry.removeListener(listener);
129 }
tom0755a362014-09-24 11:54:43 -0700130
131 // Store delegate to re-post events emitted from the store.
132 private class InternalStoreDelegate implements ClusterStoreDelegate {
133 @Override
134 public void notify(ClusterEvent event) {
135 checkNotNull(event, "Event cannot be null");
136 eventDispatcher.post(event);
137 }
138 }
tome4729872014-09-23 00:37:37 -0700139}