blob: 09bf3e646371749b1dd328347e650e851aff2ab9 [file] [log] [blame]
Jian Li7d361572017-01-13 11:39:37 +09001/*
2 * Copyright 2017-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.lisp.mapping.impl;
17
18import org.apache.felix.scr.annotations.Activate;
19import org.apache.felix.scr.annotations.Component;
20import org.apache.felix.scr.annotations.Deactivate;
21import org.apache.felix.scr.annotations.Reference;
22import org.apache.felix.scr.annotations.ReferenceCardinality;
23import org.onosproject.lisp.ctl.LispController;
24import org.onosproject.lisp.ctl.LispMessageListener;
25import org.onosproject.lisp.ctl.LispRouterId;
26import org.onosproject.lisp.ctl.LispRouterListener;
Jian Li77d6e752017-01-29 23:24:18 +090027import org.onosproject.lisp.msg.protocols.LispMapNotify;
28import org.onosproject.lisp.msg.protocols.LispMapReply;
Jian Li7d361572017-01-13 11:39:37 +090029import org.onosproject.lisp.msg.protocols.LispMessage;
Jian Li77d6e752017-01-29 23:24:18 +090030import org.onosproject.mapping.MappingEntry;
31import org.onosproject.mapping.MappingProvider;
32import org.onosproject.mapping.MappingProviderRegistry;
33import org.onosproject.mapping.MappingProviderService;
34import org.onosproject.net.DeviceId;
Jian Li7d361572017-01-13 11:39:37 +090035import org.onosproject.net.provider.AbstractProvider;
36import org.onosproject.net.provider.ProviderId;
Jian Li77d6e752017-01-29 23:24:18 +090037import org.onosproject.provider.lisp.mapping.util.MappingEntryBuilder;
Jian Li7d361572017-01-13 11:39:37 +090038import org.slf4j.Logger;
39import org.slf4j.LoggerFactory;
40
41/**
42 * Provider which uses a LISP controller to manage EID-RLOC mapping.
43 */
44@Component(immediate = true)
Jian Li77d6e752017-01-29 23:24:18 +090045public class LispMappingProvider extends AbstractProvider implements MappingProvider {
Jian Li7d361572017-01-13 11:39:37 +090046
47 private static final Logger log = LoggerFactory.getLogger(LispMappingProvider.class);
48
49 @Reference(cardinality = ReferenceCardinality.MANDATORY_UNARY)
50 protected LispController controller;
51
Jian Li77d6e752017-01-29 23:24:18 +090052 @Reference(cardinality = ReferenceCardinality.MANDATORY_UNARY)
53 protected MappingProviderRegistry providerRegistry;
54
55 protected MappingProviderService providerService;
56
Jian Li7d361572017-01-13 11:39:37 +090057 private static final String SCHEME_NAME = "lisp";
58 private static final String MAPPING_PROVIDER_PACKAGE =
59 "org.onosproject.lisp.provider.mapping";
60
61 private final InternalMappingProvider listener = new InternalMappingProvider();
62
63 /**
64 * Creates a LISP mapping provider with the supplier identifier.
65 */
66 public LispMappingProvider() {
67 super(new ProviderId(SCHEME_NAME, MAPPING_PROVIDER_PACKAGE));
68 }
69
70 @Activate
71 public void activate() {
72
Jian Li77d6e752017-01-29 23:24:18 +090073 providerService = providerRegistry.register(this);
74
Jian Li7d361572017-01-13 11:39:37 +090075 // listens all LISP router related events
76 controller.addRouterListener(listener);
77
78 // listens all LISP control message
79 controller.addMessageListener(listener);
80
81 log.info("Started");
82 }
83
84 @Deactivate
85 public void deactivate() {
86
Jian Li77d6e752017-01-29 23:24:18 +090087 providerRegistry.unregister(this);
88
Jian Li7d361572017-01-13 11:39:37 +090089 // stops listening all LISP router related events
90 controller.removeRouterListener(listener);
91
92 // stops listening all LISP control messages
93 controller.removeMessageListener(listener);
94
Jian Li77d6e752017-01-29 23:24:18 +090095 providerService = null;
96
Jian Li7d361572017-01-13 11:39:37 +090097 log.info("Stopped");
98 }
99
100 /**
101 * A listener for LISP router events and control messages.
102 */
103 private class InternalMappingProvider implements LispRouterListener,
104 LispMessageListener {
105
106 @Override
107 public void routerAdded(LispRouterId routerId) {
108
109 }
110
111 @Override
112 public void routerRemoved(LispRouterId routerId) {
113
114 }
115
116 @Override
117 public void routerChanged(LispRouterId routerId) {
118
119 }
120
121 @Override
122 public void handleIncomingMessage(LispRouterId routerId, LispMessage msg) {
123
124 }
125
126 @Override
127 public void handleOutgoingMessage(LispRouterId routerId, LispMessage msg) {
Jian Li77d6e752017-01-29 23:24:18 +0900128 if (providerService == null) {
129 // We are shutting down, nothing to be done
130 return;
131 }
Jian Li7d361572017-01-13 11:39:37 +0900132
Jian Li77d6e752017-01-29 23:24:18 +0900133 DeviceId deviceId = DeviceId.deviceId(routerId.toString());
134 switch (msg.getType()) {
135
136 case LISP_MAP_REPLY:
137 LispMapReply reply = (LispMapReply) msg;
138
139 MappingEntry replyMe = new MappingEntryBuilder(deviceId, reply).build();
140 providerService.mappingAdded(replyMe, false);
141 break;
142
143 case LISP_MAP_NOTIFY:
144 LispMapNotify notify = (LispMapNotify) msg;
145
146 MappingEntry notifyMe = new MappingEntryBuilder(deviceId, notify).build();
147 providerService.mappingAdded(notifyMe, true);
148 break;
149
150 default:
151 log.warn("Unhandled message type: {}", msg.getType());
152 }
Jian Li7d361572017-01-13 11:39:37 +0900153 }
154 }
155}