blob: 74660b1a17a44dd88f434e168dad36e3ded42bed [file] [log] [blame]
Priyanka B94395bf2016-05-21 18:39:46 +05301/*
2 * Copyright 2016-present 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 */
16package org.onosproject.provider.pcep.topology.impl;
17
18import java.util.Collection;
19import java.util.Collections;
20import java.util.HashSet;
21import java.util.LinkedList;
22import java.util.Set;
23import java.util.concurrent.ConcurrentHashMap;
24
25import org.apache.felix.scr.annotations.Activate;
26import org.apache.felix.scr.annotations.Deactivate;
27import org.onlab.packet.IpAddress;
28import org.onosproject.pcep.controller.ClientCapability;
29import org.onosproject.pcep.controller.PccId;
30import org.onosproject.pcep.controller.PcepClient;
31import org.onosproject.pcep.controller.PcepClientController;
32import org.onosproject.pcep.controller.PcepClientListener;
33import org.onosproject.pcep.controller.PcepEventListener;
34import org.onosproject.pcep.controller.PcepNodeListener;
Avantika-Huaweid1e36bd2016-05-26 12:47:16 +053035import org.onosproject.pcep.controller.PcepPacketListener;
Priyanka B94395bf2016-05-21 18:39:46 +053036import org.onosproject.pcep.controller.driver.PcepAgent;
37import org.onosproject.pcepio.protocol.PcepError;
38import org.onosproject.pcepio.protocol.PcepErrorInfo;
39import org.onosproject.pcepio.protocol.PcepErrorMsg;
40import org.onosproject.pcepio.protocol.PcepErrorObject;
41import org.onosproject.pcepio.protocol.PcepFactory;
42import org.onosproject.pcepio.protocol.PcepMessage;
43import org.onosproject.pcepio.protocol.PcepVersion;
44
45import com.google.common.collect.Sets;
46
47import static org.onosproject.pcepio.types.PcepErrorDetailInfo.ERROR_TYPE_19;
48import static org.onosproject.pcepio.types.PcepErrorDetailInfo.ERROR_VALUE_5;
49
50/**
51 * Representation of PCEP client controller adapter.
52 */
53public class PcepClientControllerAdapter implements PcepClientController {
54
55 protected ConcurrentHashMap<PccId, PcepClient> connectedClients =
56 new ConcurrentHashMap<PccId, PcepClient>();
57
58 protected PcepClientAgent agent = new PcepClientAgent();
59 protected Set<PcepClientListener> pcepClientListener = new HashSet<>();
60
61 protected Set<PcepEventListener> pcepEventListener = Sets.newHashSet();
62 public Set<PcepNodeListener> pcepNodeListener = Sets.newHashSet();
63
64 @Activate
65 public void activate() {
66 }
67
68 @Deactivate
69 public void deactivate() {
70 }
71
72 @Override
73 public Collection<PcepClient> getClients() {
74 return connectedClients.values();
75 }
76
77 @Override
78 public PcepClient getClient(PccId pccId) {
79 if (null != connectedClients.get(pccId)) {
80 return connectedClients.get(pccId);
81 }
82 PcepClientAdapter pc = new PcepClientAdapter();
83 if (pccId.ipAddress().equals(IpAddress.valueOf(0xC010103))
84 || pccId.ipAddress().equals(IpAddress.valueOf(0xB6024E22))) {
85 pc.setCapability(new ClientCapability(true, false, false, false, false));
86 } else {
87 pc.setCapability(new ClientCapability(true, true, true, false, false));
88 }
89 pc.init(PccId.pccId(pccId.ipAddress()), PcepVersion.PCEP_1);
90 connectedClients.put(pccId, pc);
91 return pc;
92 }
93
94 @Override
95 public void addListener(PcepClientListener listener) {
96 if (!pcepClientListener.contains(listener)) {
97 this.pcepClientListener.add(listener);
98 }
99 }
100
101 @Override
102 public void addNodeListener(PcepNodeListener listener) {
103 pcepNodeListener.add(listener);
104 }
105
106 @Override
107 public void removeNodeListener(PcepNodeListener listener) {
108 pcepNodeListener.remove(listener);
109 }
110
111 @Override
112 public void removeListener(PcepClientListener listener) {
113 this.pcepClientListener.remove(listener);
114 }
115
116 @Override
117 public void addEventListener(PcepEventListener listener) {
118 pcepEventListener.add(listener);
119 }
120
121 @Override
122 public void removeEventListener(PcepEventListener listener) {
123 pcepEventListener.remove(listener);
124 }
125
126 @Override
127 public void writeMessage(PccId pccId, PcepMessage msg) {
128 this.getClient(pccId).sendMessage(msg);
129 }
130
131 @Override
132 public void processClientMessage(PccId pccId, PcepMessage msg) {
133
134 PcepClient pc = getClient(pccId);
135
136 switch (msg.getType()) {
137 case NONE:
138 break;
139 case OPEN:
140 break;
141 case KEEP_ALIVE:
142 //log.debug("Sending Keep Alive Message to {" + pccIpAddress.toString() + "}");
143 pc.sendMessage(Collections.singletonList(pc.factory().buildKeepaliveMsg().build()));
144 break;
145 case PATH_COMPUTATION_REQUEST:
146 break;
147 case PATH_COMPUTATION_REPLY:
148 break;
149 case NOTIFICATION:
150 break;
151 case ERROR:
152 break;
153 case CLOSE:
154 //log.debug("Sending Close Message to { }", pccIpAddress.toString());
155 pc.sendMessage(Collections.singletonList(pc.factory().buildCloseMsg().build()));
156 break;
157 case INITIATE:
158 if (!pc.capability().pcInstantiationCapability()) {
159 pc.sendMessage(Collections.singletonList(getErrMsg(pc.factory(),
160 ERROR_TYPE_19, ERROR_VALUE_5)));
161 }
162 break;
163 case REPORT:
164 //Only update the listener if respective capability is supported else send PCEP-ERR msg
165 if (pc.capability().statefulPceCapability()) {
166 for (PcepEventListener l : pcepEventListener) {
167 l.handleMessage(pccId, msg);
168 }
169 } else {
170 // Send PCEP-ERROR message.
171 pc.sendMessage(Collections.singletonList(getErrMsg(pc.factory(),
172 ERROR_TYPE_19, ERROR_VALUE_5)));
173 }
174 break;
175 case UPDATE:
176 if (!pc.capability().statefulPceCapability()) {
177 pc.sendMessage(Collections.singletonList(getErrMsg(pc.factory(),
178 ERROR_TYPE_19, ERROR_VALUE_5)));
179 }
180 break;
181 case LABEL_UPDATE:
182 if (!pc.capability().pceccCapability()) {
183 pc.sendMessage(Collections.singletonList(getErrMsg(pc.factory(),
184 ERROR_TYPE_19, ERROR_VALUE_5)));
185 }
186 break;
187 case MAX:
188 break;
189 case END:
190 break;
191 default:
192 break;
193 }
194 }
195
196 @Override
197 public void closeConnectedClients() {
198 PcepClient pc;
199 for (PccId id : connectedClients.keySet()) {
200 pc = getClient(id);
201 pc.disconnectClient();
202 }
203 }
204
205 private PcepErrorMsg getErrMsg(PcepFactory factory, byte errorType, byte errorValue) {
206 LinkedList<PcepError> llPcepErr = new LinkedList<>();
207
208 LinkedList<PcepErrorObject> llerrObj = new LinkedList<>();
209 PcepErrorMsg errMsg;
210
211 PcepErrorObject errObj = factory.buildPcepErrorObject().setErrorValue(errorValue).setErrorType(errorType)
212 .build();
213
214 llerrObj.add(errObj);
215 PcepError pcepErr = factory.buildPcepError().setErrorObjList(llerrObj).build();
216
217 llPcepErr.add(pcepErr);
218
219 PcepErrorInfo errInfo = factory.buildPcepErrorInfo().setPcepErrorList(llPcepErr).build();
220
221 errMsg = factory.buildPcepErrorMsg().setPcepErrorInfo(errInfo).build();
222 return errMsg;
223 }
224
225 /**
226 * Implementation of an Pcep Agent which is responsible for
227 * keeping track of connected clients and the state in which
228 * they are.
229 */
230 public class PcepClientAgent implements PcepAgent {
231
232 @Override
233 public boolean addConnectedClient(PccId pccId, PcepClient pc) {
234
235 if (connectedClients.get(pccId) != null) {
236 return false;
237 } else {
238 connectedClients.put(pccId, pc);
239 for (PcepClientListener l : pcepClientListener) {
240 l.clientConnected(pccId);
241 }
242 return true;
243 }
244 }
245
246 @Override
247 public boolean validActivation(PccId pccId) {
248 if (connectedClients.get(pccId) == null) {
249 //log.error("Trying to activate client but is not in "
250 // + "connected switches: pccIp {}. Aborting ..", pccIpAddress.toString());
251 return false;
252 }
253
254 return true;
255 }
256
257 @Override
258 public void removeConnectedClient(PccId pccId) {
259 connectedClients.remove(pccId);
260 for (PcepClientListener l : pcepClientListener) {
261 //log.warn("removal for {}", pccIpAddress.toString());
262 l.clientDisconnected(pccId);
263 }
264 }
265
266 @Override
267 public void processPcepMessage(PccId pccId, PcepMessage m) {
268 processClientMessage(pccId, m);
269 }
270
271 @Override
272 public void addNode(PcepClient pc) {
273 for (PcepNodeListener l : pcepNodeListener) {
274 l.addNode(pc);
275 }
276 }
277
278 @Override
279 public void deleteNode(PccId pccId) {
280 for (PcepNodeListener l : pcepNodeListener) {
281 l.deleteNode(pccId);
282 }
283 }
Avantika-Huaweid1e36bd2016-05-26 12:47:16 +0530284
285 @Override
286 public boolean analyzeSyncMsgList(PccId pccId) {
287 // TODO Auto-generated method stub
288 return false;
289 }
290 }
291
292 @Override
293 public void addPacketListener(PcepPacketListener listener) {
294 // TODO Auto-generated method stub
295
296 }
297
298 @Override
299 public void removePacketListener(PcepPacketListener listener) {
300 // TODO Auto-generated method stub
301
Priyanka B94395bf2016-05-21 18:39:46 +0530302 }
303}