blob: 3cf1e3b2053a08f8933a8aeae64e783ea9a938d6 [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;
Jian Lib8436bb2017-02-23 03:39:08 +090028import org.onosproject.lisp.msg.protocols.LispMapRecord;
Jian Li77d6e752017-01-29 23:24:18 +090029import org.onosproject.lisp.msg.protocols.LispMapReply;
Jian Li7d361572017-01-13 11:39:37 +090030import org.onosproject.lisp.msg.protocols.LispMessage;
Jian Li77d6e752017-01-29 23:24:18 +090031import org.onosproject.mapping.MappingEntry;
32import org.onosproject.mapping.MappingProvider;
33import org.onosproject.mapping.MappingProviderRegistry;
34import org.onosproject.mapping.MappingProviderService;
Jian Lib8436bb2017-02-23 03:39:08 +090035import org.onosproject.mapping.MappingStore;
Jian Li77d6e752017-01-29 23:24:18 +090036import org.onosproject.net.DeviceId;
Jian Li7d361572017-01-13 11:39:37 +090037import org.onosproject.net.provider.AbstractProvider;
38import org.onosproject.net.provider.ProviderId;
Jian Li77d6e752017-01-29 23:24:18 +090039import org.onosproject.provider.lisp.mapping.util.MappingEntryBuilder;
Jian Li7d361572017-01-13 11:39:37 +090040import org.slf4j.Logger;
41import org.slf4j.LoggerFactory;
42
Jian Lib8436bb2017-02-23 03:39:08 +090043import java.util.List;
44
Jian Lic7badf92017-02-02 19:43:46 +090045import static org.onosproject.mapping.MappingStore.Type.MAP_CACHE;
46import static org.onosproject.mapping.MappingStore.Type.MAP_DATABASE;
47
Jian Li7d361572017-01-13 11:39:37 +090048/**
49 * Provider which uses a LISP controller to manage EID-RLOC mapping.
50 */
51@Component(immediate = true)
Jian Li77d6e752017-01-29 23:24:18 +090052public class LispMappingProvider extends AbstractProvider implements MappingProvider {
Jian Li7d361572017-01-13 11:39:37 +090053
54 private static final Logger log = LoggerFactory.getLogger(LispMappingProvider.class);
55
56 @Reference(cardinality = ReferenceCardinality.MANDATORY_UNARY)
57 protected LispController controller;
58
Jian Li77d6e752017-01-29 23:24:18 +090059 @Reference(cardinality = ReferenceCardinality.MANDATORY_UNARY)
60 protected MappingProviderRegistry providerRegistry;
61
62 protected MappingProviderService providerService;
63
Jian Li7d361572017-01-13 11:39:37 +090064 private static final String SCHEME_NAME = "lisp";
65 private static final String MAPPING_PROVIDER_PACKAGE =
66 "org.onosproject.lisp.provider.mapping";
67
68 private final InternalMappingProvider listener = new InternalMappingProvider();
69
70 /**
71 * Creates a LISP mapping provider with the supplier identifier.
72 */
73 public LispMappingProvider() {
74 super(new ProviderId(SCHEME_NAME, MAPPING_PROVIDER_PACKAGE));
75 }
76
77 @Activate
78 public void activate() {
79
Jian Li77d6e752017-01-29 23:24:18 +090080 providerService = providerRegistry.register(this);
81
Jian Li7d361572017-01-13 11:39:37 +090082 // listens all LISP router related events
83 controller.addRouterListener(listener);
84
85 // listens all LISP control message
86 controller.addMessageListener(listener);
87
88 log.info("Started");
89 }
90
91 @Deactivate
92 public void deactivate() {
93
Jian Li77d6e752017-01-29 23:24:18 +090094 providerRegistry.unregister(this);
95
Jian Li7d361572017-01-13 11:39:37 +090096 // stops listening all LISP router related events
97 controller.removeRouterListener(listener);
98
99 // stops listening all LISP control messages
100 controller.removeMessageListener(listener);
101
Jian Li77d6e752017-01-29 23:24:18 +0900102 providerService = null;
103
Jian Li7d361572017-01-13 11:39:37 +0900104 log.info("Stopped");
105 }
106
107 /**
108 * A listener for LISP router events and control messages.
109 */
110 private class InternalMappingProvider implements LispRouterListener,
111 LispMessageListener {
112
113 @Override
114 public void routerAdded(LispRouterId routerId) {
115
116 }
117
118 @Override
119 public void routerRemoved(LispRouterId routerId) {
120
121 }
122
123 @Override
124 public void routerChanged(LispRouterId routerId) {
125
126 }
127
128 @Override
129 public void handleIncomingMessage(LispRouterId routerId, LispMessage msg) {
130
131 }
132
133 @Override
134 public void handleOutgoingMessage(LispRouterId routerId, LispMessage msg) {
Jian Li77d6e752017-01-29 23:24:18 +0900135 if (providerService == null) {
136 // We are shutting down, nothing to be done
137 return;
138 }
Jian Li7d361572017-01-13 11:39:37 +0900139
Jian Li77d6e752017-01-29 23:24:18 +0900140 DeviceId deviceId = DeviceId.deviceId(routerId.toString());
141 switch (msg.getType()) {
142
143 case LISP_MAP_REPLY:
144 LispMapReply reply = (LispMapReply) msg;
Jian Lib8436bb2017-02-23 03:39:08 +0900145 processMappings(deviceId, reply.getMapRecords(), MAP_CACHE);
Jian Li77d6e752017-01-29 23:24:18 +0900146 break;
147
148 case LISP_MAP_NOTIFY:
149 LispMapNotify notify = (LispMapNotify) msg;
Jian Lib8436bb2017-02-23 03:39:08 +0900150 processMappings(deviceId, notify.getMapRecords(), MAP_DATABASE);
Jian Li77d6e752017-01-29 23:24:18 +0900151 break;
152
153 default:
154 log.warn("Unhandled message type: {}", msg.getType());
155 }
Jian Li7d361572017-01-13 11:39:37 +0900156 }
Jian Lib8436bb2017-02-23 03:39:08 +0900157
158 /**
159 * Converts map records into mapping, notifies to provider.
160 *
161 * @param deviceId device identifier
162 * @param records a collection of map records
163 * @param type MappingStore type
164 */
165 private void processMappings(DeviceId deviceId,
166 List<LispMapRecord> records,
167 MappingStore.Type type) {
168 records.forEach(r -> {
169 MappingEntry me = new MappingEntryBuilder(deviceId, r).build();
170 providerService.mappingAdded(me, type);
171 });
172 }
Jian Li7d361572017-01-13 11:39:37 +0900173 }
174}