blob: 58b61b8ccf53055184ba956aeaf8e796ad92b685 [file] [log] [blame]
Jonathan Hart2aad7792018-07-31 15:09:17 -04001/*
2 * Copyright 2018-present Open Networking Foundation
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 */
16
17package org.opencord.kafka.integrations;
18
19import com.fasterxml.jackson.databind.JsonNode;
20import com.fasterxml.jackson.databind.ObjectMapper;
21import com.fasterxml.jackson.databind.node.ObjectNode;
Matteo Scandolo580fb7f2019-04-17 15:33:15 -070022import org.onosproject.net.AnnotationKeys;
23import org.onosproject.net.device.DeviceService;
Jonathan Hart2aad7792018-07-31 15:09:17 -040024import org.opencord.dhcpl2relay.DhcpAllocationInfo;
25import org.opencord.dhcpl2relay.DhcpL2RelayEvent;
26import org.opencord.dhcpl2relay.DhcpL2RelayListener;
27import org.opencord.dhcpl2relay.DhcpL2RelayService;
28import org.opencord.kafka.EventBusService;
Carmelo Cascone7e73fa12019-07-15 18:29:01 -070029import org.osgi.service.component.annotations.Activate;
30import org.osgi.service.component.annotations.Component;
31import org.osgi.service.component.annotations.Deactivate;
32import org.osgi.service.component.annotations.Reference;
33import org.osgi.service.component.annotations.ReferenceCardinality;
34import org.osgi.service.component.annotations.ReferencePolicy;
Jonathan Hart2aad7792018-07-31 15:09:17 -040035
36import java.time.Instant;
Carmelo Cascone7e73fa12019-07-15 18:29:01 -070037import java.util.concurrent.atomic.AtomicReference;
Jonathan Hart2aad7792018-07-31 15:09:17 -040038
39/**
40 * Listens for DHCP L2 relay events and pushes them on a Kafka bus.
41 */
42@Component(immediate = true)
Carmelo Cascone7e73fa12019-07-15 18:29:01 -070043public class DhcpL2RelayKafkaIntegration extends AbstractKafkaIntegration {
Jonathan Hart2aad7792018-07-31 15:09:17 -040044
Carmelo Cascone7e73fa12019-07-15 18:29:01 -070045 @Reference(cardinality = ReferenceCardinality.MANDATORY)
Jonathan Hart2aad7792018-07-31 15:09:17 -040046 protected EventBusService eventBusService;
47
Carmelo Cascone7e73fa12019-07-15 18:29:01 -070048 @Reference(cardinality = ReferenceCardinality.MANDATORY)
Matteo Scandolo580fb7f2019-04-17 15:33:15 -070049 protected DeviceService deviceService;
50
Carmelo Cascone7e73fa12019-07-15 18:29:01 -070051 @Reference(cardinality = ReferenceCardinality.OPTIONAL,
Matteo Scandolod50a4d32019-04-24 12:10:21 -070052 policy = ReferencePolicy.DYNAMIC,
Matteo Scandolo03f13c12019-03-20 14:38:12 -070053 bind = "bindDhcpL2RelayService",
54 unbind = "unbindDhcpL2RelayService")
Carmelo Cascone69eec922019-11-15 21:34:02 -080055 protected volatile DhcpL2RelayService ignore;
Carmelo Cascone7e73fa12019-07-15 18:29:01 -070056 private final AtomicReference<DhcpL2RelayService> dhcpL2RelayServiceRef = new AtomicReference<>();
Jonathan Hart2aad7792018-07-31 15:09:17 -040057
58 private final DhcpL2RelayListener listener = new InternalDhcpL2RelayListener();
59
60 private static final String TOPIC = "dhcp.events";
61
62 private static final String TIMESTAMP = "timestamp";
63 private static final String DEVICE_ID = "deviceId";
Matteo Scandolo580fb7f2019-04-17 15:33:15 -070064 private static final String PORT_NUMBER = "portNumber";
65 private static final String SERIAL_NUMBER = "serialNumber";
Jonathan Hart2aad7792018-07-31 15:09:17 -040066 private static final String TYPE = "type";
67 private static final String MESSAGE_TYPE = "messageType";
Jonathan Hart2aad7792018-07-31 15:09:17 -040068 private static final String MAC_ADDRESS = "macAddress";
69 private static final String IP_ADDRESS = "ipAddress";
70
Carmelo Cascone7e73fa12019-07-15 18:29:01 -070071 protected void bindDhcpL2RelayService(DhcpL2RelayService incomingService) {
72 bindAndAddListener(incomingService, dhcpL2RelayServiceRef, listener);
Matteo Scandolo03f13c12019-03-20 14:38:12 -070073 }
74
Carmelo Cascone7e73fa12019-07-15 18:29:01 -070075 protected void unbindDhcpL2RelayService(DhcpL2RelayService outgoingService) {
76 unbindAndRemoveListener(outgoingService, dhcpL2RelayServiceRef, listener);
Matteo Scandolo03f13c12019-03-20 14:38:12 -070077 }
78
Jonathan Hart2aad7792018-07-31 15:09:17 -040079 @Activate
80 public void activate() {
Matteo Scandolod50a4d32019-04-24 12:10:21 -070081 log.info("Started DhcpL2RelayKafkaIntegration");
Jonathan Hart2aad7792018-07-31 15:09:17 -040082 }
83
84 @Deactivate
85 public void deactivate() {
Carmelo Cascone7e73fa12019-07-15 18:29:01 -070086 unbindDhcpL2RelayService(dhcpL2RelayServiceRef.get());
Matteo Scandolod50a4d32019-04-24 12:10:21 -070087 log.info("Stopped DhcpL2RelayKafkaIntegration");
Jonathan Hart2aad7792018-07-31 15:09:17 -040088 }
89
90 private void handle(DhcpL2RelayEvent event) {
91 eventBusService.send(TOPIC, serialize(event));
92 }
93
94 private JsonNode serialize(DhcpL2RelayEvent event) {
Matteo Scandolo580fb7f2019-04-17 15:33:15 -070095
96 String sn = deviceService.getPort(event.subject().location()).annotations().value(AnnotationKeys.PORT_NAME);
97
Jonathan Hart2aad7792018-07-31 15:09:17 -040098 ObjectMapper mapper = new ObjectMapper();
99 ObjectNode dhcpEvent = mapper.createObjectNode();
100 DhcpAllocationInfo allocationInfo = event.subject();
101 dhcpEvent.put(TYPE, event.type().toString());
102 dhcpEvent.put(TIMESTAMP, Instant.now().toString());
103 dhcpEvent.put(DEVICE_ID, event.connectPoint().deviceId().toString());
Jonathan Hart2aad7792018-07-31 15:09:17 -0400104 dhcpEvent.put(PORT_NUMBER, event.connectPoint().port().toString());
Matteo Scandolo580fb7f2019-04-17 15:33:15 -0700105 dhcpEvent.put(SERIAL_NUMBER, sn);
106 dhcpEvent.put(MESSAGE_TYPE, allocationInfo.type().toString());
Jonathan Hart2aad7792018-07-31 15:09:17 -0400107 dhcpEvent.put(MAC_ADDRESS, allocationInfo.macAddress().toString());
108 dhcpEvent.put(IP_ADDRESS, allocationInfo.ipAddress().toString());
109 return dhcpEvent;
110 }
111
112 private class InternalDhcpL2RelayListener implements
113 DhcpL2RelayListener {
114
115 @Override
116 public void event(DhcpL2RelayEvent dhcpL2RelayEvent) {
117 handle(dhcpL2RelayEvent);
118 }
119 }
120}