blob: 05e5dd79b5a5ac1680b6c7a435110892bccad720 [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
Jian Lic7badf92017-02-02 19:43:46 +090041import static org.onosproject.mapping.MappingStore.Type.MAP_CACHE;
42import static org.onosproject.mapping.MappingStore.Type.MAP_DATABASE;
43
Jian Li7d361572017-01-13 11:39:37 +090044/**
45 * Provider which uses a LISP controller to manage EID-RLOC mapping.
46 */
47@Component(immediate = true)
Jian Li77d6e752017-01-29 23:24:18 +090048public class LispMappingProvider extends AbstractProvider implements MappingProvider {
Jian Li7d361572017-01-13 11:39:37 +090049
50 private static final Logger log = LoggerFactory.getLogger(LispMappingProvider.class);
51
52 @Reference(cardinality = ReferenceCardinality.MANDATORY_UNARY)
53 protected LispController controller;
54
Jian Li77d6e752017-01-29 23:24:18 +090055 @Reference(cardinality = ReferenceCardinality.MANDATORY_UNARY)
56 protected MappingProviderRegistry providerRegistry;
57
58 protected MappingProviderService providerService;
59
Jian Li7d361572017-01-13 11:39:37 +090060 private static final String SCHEME_NAME = "lisp";
61 private static final String MAPPING_PROVIDER_PACKAGE =
62 "org.onosproject.lisp.provider.mapping";
63
64 private final InternalMappingProvider listener = new InternalMappingProvider();
65
66 /**
67 * Creates a LISP mapping provider with the supplier identifier.
68 */
69 public LispMappingProvider() {
70 super(new ProviderId(SCHEME_NAME, MAPPING_PROVIDER_PACKAGE));
71 }
72
73 @Activate
74 public void activate() {
75
Jian Li77d6e752017-01-29 23:24:18 +090076 providerService = providerRegistry.register(this);
77
Jian Li7d361572017-01-13 11:39:37 +090078 // listens all LISP router related events
79 controller.addRouterListener(listener);
80
81 // listens all LISP control message
82 controller.addMessageListener(listener);
83
84 log.info("Started");
85 }
86
87 @Deactivate
88 public void deactivate() {
89
Jian Li77d6e752017-01-29 23:24:18 +090090 providerRegistry.unregister(this);
91
Jian Li7d361572017-01-13 11:39:37 +090092 // stops listening all LISP router related events
93 controller.removeRouterListener(listener);
94
95 // stops listening all LISP control messages
96 controller.removeMessageListener(listener);
97
Jian Li77d6e752017-01-29 23:24:18 +090098 providerService = null;
99
Jian Li7d361572017-01-13 11:39:37 +0900100 log.info("Stopped");
101 }
102
103 /**
104 * A listener for LISP router events and control messages.
105 */
106 private class InternalMappingProvider implements LispRouterListener,
107 LispMessageListener {
108
109 @Override
110 public void routerAdded(LispRouterId routerId) {
111
112 }
113
114 @Override
115 public void routerRemoved(LispRouterId routerId) {
116
117 }
118
119 @Override
120 public void routerChanged(LispRouterId routerId) {
121
122 }
123
124 @Override
125 public void handleIncomingMessage(LispRouterId routerId, LispMessage msg) {
126
127 }
128
129 @Override
130 public void handleOutgoingMessage(LispRouterId routerId, LispMessage msg) {
Jian Li77d6e752017-01-29 23:24:18 +0900131 if (providerService == null) {
132 // We are shutting down, nothing to be done
133 return;
134 }
Jian Li7d361572017-01-13 11:39:37 +0900135
Jian Li77d6e752017-01-29 23:24:18 +0900136 DeviceId deviceId = DeviceId.deviceId(routerId.toString());
137 switch (msg.getType()) {
138
139 case LISP_MAP_REPLY:
140 LispMapReply reply = (LispMapReply) msg;
141
142 MappingEntry replyMe = new MappingEntryBuilder(deviceId, reply).build();
Jian Lic7badf92017-02-02 19:43:46 +0900143 providerService.mappingAdded(replyMe, MAP_CACHE);
Jian Li77d6e752017-01-29 23:24:18 +0900144 break;
145
146 case LISP_MAP_NOTIFY:
147 LispMapNotify notify = (LispMapNotify) msg;
148
149 MappingEntry notifyMe = new MappingEntryBuilder(deviceId, notify).build();
Jian Lic7badf92017-02-02 19:43:46 +0900150 providerService.mappingAdded(notifyMe, 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 }
157 }
158}