mirror of
https://github.com/Telecominfraproject/wlan-cloud-opensync-controller.git
synced 2025-11-01 02:57:49 +00:00
Compare commits
52 Commits
release/v1
...
hotfix/net
| Author | SHA1 | Date | |
|---|---|---|---|
|
|
18698fc188 | ||
|
|
34a6baf956 | ||
|
|
2e3b0c277a | ||
|
|
4370753206 | ||
|
|
aaa584ca3c | ||
|
|
210976887f | ||
|
|
43f53ee0be | ||
|
|
1381451989 | ||
|
|
6124309dbb | ||
|
|
f2e30505e5 | ||
|
|
bda589e65e | ||
|
|
5a98d4bd83 | ||
|
|
a772cbe7fa | ||
|
|
11adb02fd2 | ||
|
|
9aa4a102a5 | ||
|
|
d482b4062f | ||
|
|
ee49415b0a | ||
|
|
cc035e7fe1 | ||
|
|
d617efbcc1 | ||
|
|
53f19028dc | ||
|
|
f2b4b616ad | ||
|
|
9802ed2a3f | ||
|
|
cfc5caee64 | ||
|
|
b0abd3847a | ||
|
|
71c947427b | ||
|
|
0dc72a6fe4 | ||
|
|
5540d83dd3 | ||
|
|
572f48445c | ||
|
|
4df8bda2b3 | ||
|
|
047ce7f07a | ||
|
|
1264640c33 | ||
|
|
eef372cf0d | ||
|
|
fcccf418dd | ||
|
|
c098cd72b6 | ||
|
|
42ecccee5e | ||
|
|
663340e749 | ||
|
|
01c7f270ad | ||
|
|
91c17a6271 | ||
|
|
92235affee | ||
|
|
bbe36d4a9f | ||
|
|
3c9ee65742 | ||
|
|
53022b5813 | ||
|
|
b59a40afc0 | ||
|
|
3447df19ef | ||
|
|
de671722f7 | ||
|
|
6b7c418ccd | ||
|
|
e6472cf80b | ||
|
|
07489c2550 | ||
|
|
f39f148706 | ||
|
|
e0c26b66e0 | ||
|
|
ee1350fbe9 | ||
|
|
b7a3564153 |
@@ -4,7 +4,7 @@
|
|||||||
<parent>
|
<parent>
|
||||||
<groupId>com.telecominfraproject.wlan</groupId>
|
<groupId>com.telecominfraproject.wlan</groupId>
|
||||||
<artifactId>tip-wlan-cloud-root-pom</artifactId>
|
<artifactId>tip-wlan-cloud-root-pom</artifactId>
|
||||||
<version>1.1.0-SNAPSHOT</version>
|
<version>1.2.0-SNAPSHOT</version>
|
||||||
<relativePath>../../wlan-cloud-root</relativePath>
|
<relativePath>../../wlan-cloud-root</relativePath>
|
||||||
</parent>
|
</parent>
|
||||||
<artifactId>opensync-ext-cloud</artifactId>
|
<artifactId>opensync-ext-cloud</artifactId>
|
||||||
@@ -19,121 +19,121 @@
|
|||||||
<dependency>
|
<dependency>
|
||||||
<groupId>com.telecominfraproject.wlan</groupId>
|
<groupId>com.telecominfraproject.wlan</groupId>
|
||||||
<artifactId>opensync-gateway</artifactId>
|
<artifactId>opensync-gateway</artifactId>
|
||||||
<version>1.1.0-SNAPSHOT</version>
|
<version>1.2.0-SNAPSHOT</version>
|
||||||
</dependency>
|
</dependency>
|
||||||
|
|
||||||
<dependency>
|
<dependency>
|
||||||
<artifactId>base-client</artifactId>
|
<artifactId>base-client</artifactId>
|
||||||
<groupId>com.telecominfraproject.wlan</groupId>
|
<groupId>com.telecominfraproject.wlan</groupId>
|
||||||
<version>1.1.0-SNAPSHOT</version>
|
<version>1.2.0-SNAPSHOT</version>
|
||||||
</dependency>
|
</dependency>
|
||||||
|
|
||||||
<dependency>
|
<dependency>
|
||||||
<artifactId>equipment-gateway-models</artifactId>
|
<artifactId>equipment-gateway-models</artifactId>
|
||||||
<groupId>com.telecominfraproject.wlan</groupId>
|
<groupId>com.telecominfraproject.wlan</groupId>
|
||||||
<version>1.1.0-SNAPSHOT</version>
|
<version>1.2.0-SNAPSHOT</version>
|
||||||
</dependency>
|
</dependency>
|
||||||
|
|
||||||
<dependency>
|
<dependency>
|
||||||
<artifactId>customer-service-interface</artifactId>
|
<artifactId>customer-service-interface</artifactId>
|
||||||
<groupId>com.telecominfraproject.wlan</groupId>
|
<groupId>com.telecominfraproject.wlan</groupId>
|
||||||
<version>1.1.0-SNAPSHOT</version>
|
<version>1.2.0-SNAPSHOT</version>
|
||||||
</dependency>
|
</dependency>
|
||||||
|
|
||||||
<dependency>
|
<dependency>
|
||||||
<artifactId>location-service-interface</artifactId>
|
<artifactId>location-service-interface</artifactId>
|
||||||
<groupId>com.telecominfraproject.wlan</groupId>
|
<groupId>com.telecominfraproject.wlan</groupId>
|
||||||
<version>1.1.0-SNAPSHOT</version>
|
<version>1.2.0-SNAPSHOT</version>
|
||||||
</dependency>
|
</dependency>
|
||||||
|
|
||||||
<dependency>
|
<dependency>
|
||||||
<artifactId>equipment-service-interface</artifactId>
|
<artifactId>equipment-service-interface</artifactId>
|
||||||
<groupId>com.telecominfraproject.wlan</groupId>
|
<groupId>com.telecominfraproject.wlan</groupId>
|
||||||
<version>1.1.0-SNAPSHOT</version>
|
<version>1.2.0-SNAPSHOT</version>
|
||||||
</dependency>
|
</dependency>
|
||||||
|
|
||||||
<dependency>
|
<dependency>
|
||||||
<artifactId>profile-service-interface</artifactId>
|
<artifactId>profile-service-interface</artifactId>
|
||||||
<groupId>com.telecominfraproject.wlan</groupId>
|
<groupId>com.telecominfraproject.wlan</groupId>
|
||||||
<version>1.1.0-SNAPSHOT</version>
|
<version>1.2.0-SNAPSHOT</version>
|
||||||
</dependency>
|
</dependency>
|
||||||
|
|
||||||
<dependency>
|
<dependency>
|
||||||
<artifactId>portal-user-service-interface</artifactId>
|
<artifactId>portal-user-service-interface</artifactId>
|
||||||
<groupId>com.telecominfraproject.wlan</groupId>
|
<groupId>com.telecominfraproject.wlan</groupId>
|
||||||
<version>1.1.0-SNAPSHOT</version>
|
<version>1.2.0-SNAPSHOT</version>
|
||||||
</dependency>
|
</dependency>
|
||||||
|
|
||||||
<dependency>
|
<dependency>
|
||||||
<artifactId>service-metric-service-interface</artifactId>
|
<artifactId>service-metric-service-interface</artifactId>
|
||||||
<groupId>com.telecominfraproject.wlan</groupId>
|
<groupId>com.telecominfraproject.wlan</groupId>
|
||||||
<version>1.1.0-SNAPSHOT</version>
|
<version>1.2.0-SNAPSHOT</version>
|
||||||
</dependency>
|
</dependency>
|
||||||
|
|
||||||
<dependency>
|
<dependency>
|
||||||
<artifactId>service-metric-models</artifactId>
|
<artifactId>service-metric-models</artifactId>
|
||||||
<groupId>com.telecominfraproject.wlan</groupId>
|
<groupId>com.telecominfraproject.wlan</groupId>
|
||||||
<version>1.1.0-SNAPSHOT</version>
|
<version>1.2.0-SNAPSHOT</version>
|
||||||
</dependency>
|
</dependency>
|
||||||
|
|
||||||
<dependency>
|
<dependency>
|
||||||
<artifactId>system-event-service-interface</artifactId>
|
<artifactId>system-event-service-interface</artifactId>
|
||||||
<groupId>com.telecominfraproject.wlan</groupId>
|
<groupId>com.telecominfraproject.wlan</groupId>
|
||||||
<version>1.1.0-SNAPSHOT</version>
|
<version>1.2.0-SNAPSHOT</version>
|
||||||
</dependency>
|
</dependency>
|
||||||
|
|
||||||
<dependency>
|
<dependency>
|
||||||
<artifactId>system-event-models</artifactId>
|
<artifactId>system-event-models</artifactId>
|
||||||
<groupId>com.telecominfraproject.wlan</groupId>
|
<groupId>com.telecominfraproject.wlan</groupId>
|
||||||
<version>1.1.0-SNAPSHOT</version>
|
<version>1.2.0-SNAPSHOT</version>
|
||||||
</dependency>
|
</dependency>
|
||||||
|
|
||||||
<dependency>
|
<dependency>
|
||||||
<artifactId>alarm-service-interface</artifactId>
|
<artifactId>alarm-service-interface</artifactId>
|
||||||
<groupId>com.telecominfraproject.wlan</groupId>
|
<groupId>com.telecominfraproject.wlan</groupId>
|
||||||
<version>1.1.0-SNAPSHOT</version>
|
<version>1.2.0-SNAPSHOT</version>
|
||||||
</dependency>
|
</dependency>
|
||||||
|
|
||||||
<dependency>
|
<dependency>
|
||||||
<artifactId>status-service-interface</artifactId>
|
<artifactId>status-service-interface</artifactId>
|
||||||
<groupId>com.telecominfraproject.wlan</groupId>
|
<groupId>com.telecominfraproject.wlan</groupId>
|
||||||
<version>1.1.0-SNAPSHOT</version>
|
<version>1.2.0-SNAPSHOT</version>
|
||||||
</dependency>
|
</dependency>
|
||||||
|
|
||||||
<dependency>
|
<dependency>
|
||||||
<artifactId>client-service-interface</artifactId>
|
<artifactId>client-service-interface</artifactId>
|
||||||
<groupId>com.telecominfraproject.wlan</groupId>
|
<groupId>com.telecominfraproject.wlan</groupId>
|
||||||
<version>1.1.0-SNAPSHOT</version>
|
<version>1.2.0-SNAPSHOT</version>
|
||||||
</dependency>
|
</dependency>
|
||||||
|
|
||||||
<dependency>
|
<dependency>
|
||||||
<artifactId>client-models</artifactId>
|
<artifactId>client-models</artifactId>
|
||||||
<groupId>com.telecominfraproject.wlan</groupId>
|
<groupId>com.telecominfraproject.wlan</groupId>
|
||||||
<version>1.1.0-SNAPSHOT</version>
|
<version>1.2.0-SNAPSHOT</version>
|
||||||
</dependency>
|
</dependency>
|
||||||
|
|
||||||
<dependency>
|
<dependency>
|
||||||
<artifactId>routing-service-interface</artifactId>
|
<artifactId>routing-service-interface</artifactId>
|
||||||
<groupId>com.telecominfraproject.wlan</groupId>
|
<groupId>com.telecominfraproject.wlan</groupId>
|
||||||
<version>1.1.0-SNAPSHOT</version>
|
<version>1.2.0-SNAPSHOT</version>
|
||||||
</dependency>
|
</dependency>
|
||||||
|
|
||||||
<dependency>
|
<dependency>
|
||||||
<artifactId>firmware-service-interface</artifactId>
|
<artifactId>firmware-service-interface</artifactId>
|
||||||
<groupId>com.telecominfraproject.wlan</groupId>
|
<groupId>com.telecominfraproject.wlan</groupId>
|
||||||
<version>1.1.0-SNAPSHOT</version>
|
<version>1.2.0-SNAPSHOT</version>
|
||||||
</dependency>
|
</dependency>
|
||||||
|
|
||||||
<dependency>
|
<dependency>
|
||||||
<artifactId>manufacturer-service-interface</artifactId>
|
<artifactId>manufacturer-service-interface</artifactId>
|
||||||
<groupId>com.telecominfraproject.wlan</groupId>
|
<groupId>com.telecominfraproject.wlan</groupId>
|
||||||
<version>1.1.0-SNAPSHOT</version>
|
<version>1.2.0-SNAPSHOT</version>
|
||||||
</dependency>
|
</dependency>
|
||||||
|
|
||||||
<dependency>
|
<dependency>
|
||||||
<artifactId>cloud-event-dispatcher-interface</artifactId>
|
<artifactId>cloud-event-dispatcher-interface</artifactId>
|
||||||
<groupId>com.telecominfraproject.wlan</groupId>
|
<groupId>com.telecominfraproject.wlan</groupId>
|
||||||
<version>1.1.0-SNAPSHOT</version>
|
<version>1.2.0-SNAPSHOT</version>
|
||||||
</dependency>
|
</dependency>
|
||||||
|
|
||||||
</dependencies>
|
</dependencies>
|
||||||
|
|||||||
@@ -25,6 +25,10 @@ import org.springframework.stereotype.Component;
|
|||||||
|
|
||||||
import com.google.common.collect.ImmutableSet;
|
import com.google.common.collect.ImmutableSet;
|
||||||
import com.google.common.collect.Lists;
|
import com.google.common.collect.Lists;
|
||||||
|
import com.telecominfraproject.wlan.alarm.AlarmServiceInterface;
|
||||||
|
import com.telecominfraproject.wlan.alarm.models.Alarm;
|
||||||
|
import com.telecominfraproject.wlan.alarm.models.AlarmCode;
|
||||||
|
import com.telecominfraproject.wlan.alarm.models.AlarmDetails;
|
||||||
import com.telecominfraproject.wlan.client.ClientServiceInterface;
|
import com.telecominfraproject.wlan.client.ClientServiceInterface;
|
||||||
import com.telecominfraproject.wlan.client.info.models.ClientInfoDetails;
|
import com.telecominfraproject.wlan.client.info.models.ClientInfoDetails;
|
||||||
import com.telecominfraproject.wlan.client.models.Client;
|
import com.telecominfraproject.wlan.client.models.Client;
|
||||||
@@ -112,6 +116,7 @@ import com.telecominfraproject.wlan.status.models.StatusDataType;
|
|||||||
import com.telecominfraproject.wlan.status.network.models.NetworkAdminStatusData;
|
import com.telecominfraproject.wlan.status.network.models.NetworkAdminStatusData;
|
||||||
import com.telecominfraproject.wlan.systemevent.equipment.realtime.ApcElectionEvent;
|
import com.telecominfraproject.wlan.systemevent.equipment.realtime.ApcElectionEvent;
|
||||||
import com.telecominfraproject.wlan.systemevent.equipment.realtime.RealTimeEventType;
|
import com.telecominfraproject.wlan.systemevent.equipment.realtime.RealTimeEventType;
|
||||||
|
import com.telecominfraproject.wlan.systemevent.equipment.realtime.ApcElectionEvent.ApcMode;
|
||||||
|
|
||||||
import sts.OpensyncStats.Report;
|
import sts.OpensyncStats.Report;
|
||||||
import traffic.NetworkMetadata.FlowReport;
|
import traffic.NetworkMetadata.FlowReport;
|
||||||
@@ -143,6 +148,8 @@ public class OpensyncExternalIntegrationCloud implements OpensyncExternalIntegra
|
|||||||
private FirmwareServiceInterface firmwareServiceInterface;
|
private FirmwareServiceInterface firmwareServiceInterface;
|
||||||
@Autowired
|
@Autowired
|
||||||
private MqttStatsPublisher mqttMessageProcessor;
|
private MqttStatsPublisher mqttMessageProcessor;
|
||||||
|
@Autowired
|
||||||
|
private AlarmServiceInterface alarmServiceInterface;
|
||||||
|
|
||||||
@Autowired
|
@Autowired
|
||||||
private OpensyncCloudGatewayController gatewayController;
|
private OpensyncCloudGatewayController gatewayController;
|
||||||
@@ -175,7 +182,7 @@ public class OpensyncExternalIntegrationCloud implements OpensyncExternalIntegra
|
|||||||
|
|
||||||
@Override
|
@Override
|
||||||
public void apConnected(String apId, ConnectNodeInfo connectNodeInfo) {
|
public void apConnected(String apId, ConnectNodeInfo connectNodeInfo) {
|
||||||
|
|
||||||
Equipment ce = equipmentServiceInterface.getByInventoryIdOrNull(apId);
|
Equipment ce = equipmentServiceInterface.getByInventoryIdOrNull(apId);
|
||||||
|
|
||||||
try {
|
try {
|
||||||
@@ -287,6 +294,7 @@ public class OpensyncExternalIntegrationCloud implements OpensyncExternalIntegra
|
|||||||
// equipment already exists
|
// equipment already exists
|
||||||
boolean needToUpdateEquipment = false;
|
boolean needToUpdateEquipment = false;
|
||||||
MacAddress reportedMacAddress = null;
|
MacAddress reportedMacAddress = null;
|
||||||
|
alarmServiceInterface.delete(ce.getCustomerId(), ce.getId());
|
||||||
try {
|
try {
|
||||||
reportedMacAddress = MacAddress.valueOf(connectNodeInfo.macAddress);
|
reportedMacAddress = MacAddress.valueOf(connectNodeInfo.macAddress);
|
||||||
} catch (RuntimeException e) {
|
} catch (RuntimeException e) {
|
||||||
@@ -542,8 +550,11 @@ public class OpensyncExternalIntegrationCloud implements OpensyncExternalIntegra
|
|||||||
protocolStatusData.setBaseMacAddress(MacAddress.valueOf(connectNodeInfo.macAddress));
|
protocolStatusData.setBaseMacAddress(MacAddress.valueOf(connectNodeInfo.macAddress));
|
||||||
protocolStatusData.setCloudCfgDataVersion(42L);
|
protocolStatusData.setCloudCfgDataVersion(42L);
|
||||||
protocolStatusData.setReportedCfgDataVersion(42L);
|
protocolStatusData.setReportedCfgDataVersion(42L);
|
||||||
protocolStatusData.setCountryCode("CA");
|
CountryCode countryCode = Location.getCountryCode(locationServiceInterface.get(ce.getLocationId()));
|
||||||
protocolStatusData.setReportedCC(CountryCode.CA);
|
protocolStatusData.setCountryCode(countryCode.getName());
|
||||||
|
if (connectNodeInfo.country != null) {
|
||||||
|
protocolStatusData.setReportedCC(CountryCode.getByName(connectNodeInfo.country));
|
||||||
|
}
|
||||||
protocolStatusData.setReportedHwVersion(connectNodeInfo.platformVersion);
|
protocolStatusData.setReportedHwVersion(connectNodeInfo.platformVersion);
|
||||||
if (connectNodeInfo.versionMatrix.containsKey(OvsdbStringConstants.FW_IMAGE_ACTIVE_KEY)) {
|
if (connectNodeInfo.versionMatrix.containsKey(OvsdbStringConstants.FW_IMAGE_ACTIVE_KEY)) {
|
||||||
protocolStatusData.setReportedSwVersion(connectNodeInfo.versionMatrix.get(OvsdbStringConstants.FW_IMAGE_ACTIVE_KEY));
|
protocolStatusData.setReportedSwVersion(connectNodeInfo.versionMatrix.get(OvsdbStringConstants.FW_IMAGE_ACTIVE_KEY));
|
||||||
@@ -880,6 +891,20 @@ public class OpensyncExternalIntegrationCloud implements OpensyncExternalIntegra
|
|||||||
private void updateApDisconnectedStatus(String apId, Equipment ce) {
|
private void updateApDisconnectedStatus(String apId, Equipment ce) {
|
||||||
LOG.info("updateApDisconnectedStatus disconnected AP {}", apId);
|
LOG.info("updateApDisconnectedStatus disconnected AP {}", apId);
|
||||||
try {
|
try {
|
||||||
|
Alarm disconnectedAlarm = new Alarm();
|
||||||
|
disconnectedAlarm.setCustomerId(ce.getCustomerId());
|
||||||
|
disconnectedAlarm.setEquipmentId(ce.getId());
|
||||||
|
disconnectedAlarm.setAlarmCode(AlarmCode.Disconnected);
|
||||||
|
|
||||||
|
AlarmDetails alarmDetails = new AlarmDetails();
|
||||||
|
alarmDetails.setMessage(AlarmCode.Disconnected.getDescription());
|
||||||
|
alarmDetails.setAffectedEquipmentIds(List.of(ce.getId()));
|
||||||
|
alarmDetails.setGeneratedBy(apId);
|
||||||
|
|
||||||
|
disconnectedAlarm.setDetails(alarmDetails);
|
||||||
|
|
||||||
|
alarmServiceInterface.create(disconnectedAlarm);
|
||||||
|
|
||||||
Status statusRecord = new Status();
|
Status statusRecord = new Status();
|
||||||
statusRecord.setCustomerId(ce.getCustomerId());
|
statusRecord.setCustomerId(ce.getCustomerId());
|
||||||
statusRecord.setEquipmentId(ce.getId());
|
statusRecord.setEquipmentId(ce.getId());
|
||||||
@@ -1024,7 +1049,7 @@ public class OpensyncExternalIntegrationCloud implements OpensyncExternalIntegra
|
|||||||
if ((blockedClients != null) && !blockedClients.isEmpty()) {
|
if ((blockedClients != null) && !blockedClients.isEmpty()) {
|
||||||
blockedClients.forEach(client -> blockList.add(client.getMacAddress()));
|
blockedClients.forEach(client -> blockList.add(client.getMacAddress()));
|
||||||
}
|
}
|
||||||
|
|
||||||
ret.setBlockedClients(blockList);
|
ret.setBlockedClients(blockList);
|
||||||
ret.setRadiusProfiles(new ArrayList<>(radiusSet));
|
ret.setRadiusProfiles(new ArrayList<>(radiusSet));
|
||||||
|
|
||||||
@@ -1042,16 +1067,6 @@ public class OpensyncExternalIntegrationCloud implements OpensyncExternalIntegra
|
|||||||
mqttMessageProcessor.processMqttMessage(topic, report);
|
mqttMessageProcessor.processMqttMessage(topic, report);
|
||||||
}
|
}
|
||||||
|
|
||||||
@Override
|
|
||||||
public void processMqttMessage(String topic, FlowReport flowReport) {
|
|
||||||
mqttMessageProcessor.processMqttMessage(topic, flowReport);
|
|
||||||
}
|
|
||||||
|
|
||||||
@Override
|
|
||||||
public void processMqttMessage(String topic, WCStatsReport wcStatsReport) {
|
|
||||||
mqttMessageProcessor.processMqttMessage(topic, wcStatsReport);
|
|
||||||
}
|
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
public void wifiVIFStateDbTableUpdate(List<OpensyncAPVIFState> vifStateTables, String apId) {
|
public void wifiVIFStateDbTableUpdate(List<OpensyncAPVIFState> vifStateTables, String apId) {
|
||||||
LOG.debug("Received Wifi_VIF_State table update for AP {}", apId);
|
LOG.debug("Received Wifi_VIF_State table update for AP {}", apId);
|
||||||
@@ -1287,6 +1302,7 @@ public class OpensyncExternalIntegrationCloud implements OpensyncExternalIntegra
|
|||||||
LOG.debug("Protocol Status reportedCC {} radioStatus.getCountry {} radioStatus CountryCode fromName {}", protocolStatusData.getReportedCC(),
|
LOG.debug("Protocol Status reportedCC {} radioStatus.getCountry {} radioStatus CountryCode fromName {}", protocolStatusData.getReportedCC(),
|
||||||
radioState.getCountry(), CountryCode.getByName((radioState.getCountry())));
|
radioState.getCountry(), CountryCode.getByName((radioState.getCountry())));
|
||||||
protocolStatusData.setReportedCC(CountryCode.getByName((radioState.getCountry())));
|
protocolStatusData.setReportedCC(CountryCode.getByName((radioState.getCountry())));
|
||||||
|
protocolStatusData.setCountryCode(radioState.getCountry());
|
||||||
protocolStatus.setDetails(protocolStatusData);
|
protocolStatus.setDetails(protocolStatusData);
|
||||||
|
|
||||||
} else {
|
} else {
|
||||||
@@ -1307,6 +1323,7 @@ public class OpensyncExternalIntegrationCloud implements OpensyncExternalIntegra
|
|||||||
channelStatus.setDetails(channelStatusData);
|
channelStatus.setDetails(channelStatusData);
|
||||||
}
|
}
|
||||||
((EquipmentChannelStatusData) channelStatus.getDetails()).getChannelNumberStatusDataMap().put(radioState.getFreqBand(), radioState.getChannel());
|
((EquipmentChannelStatusData) channelStatus.getDetails()).getChannelNumberStatusDataMap().put(radioState.getFreqBand(), radioState.getChannel());
|
||||||
|
((EquipmentChannelStatusData) channelStatus.getDetails()).getTxPowerDataMap().put(radioState.getFreqBand(), radioState.getTxPower());
|
||||||
return channelStatus;
|
return channelStatus;
|
||||||
}
|
}
|
||||||
|
|
||||||
@@ -1738,7 +1755,7 @@ public class OpensyncExternalIntegrationCloud implements OpensyncExternalIntegra
|
|||||||
if (node.qrCode != null) {
|
if (node.qrCode != null) {
|
||||||
if (node.qrCode.containsKey("DT")) {
|
if (node.qrCode.containsKey("DT")) {
|
||||||
qrCode.setDeviceType(EquipmentType.getByName(node.qrCode.get("DT")));
|
qrCode.setDeviceType(EquipmentType.getByName(node.qrCode.get("DT")));
|
||||||
}
|
}
|
||||||
qrCode.setVendorName(node.qrCode.get("VN"));
|
qrCode.setVendorName(node.qrCode.get("VN"));
|
||||||
if (isValidMACAddress(node.qrCode.get("DM"))) {
|
if (isValidMACAddress(node.qrCode.get("DM"))) {
|
||||||
qrCode.setDeviceMac(MacAddress.valueOf(node.qrCode.get("DM")));
|
qrCode.setDeviceMac(MacAddress.valueOf(node.qrCode.get("DM")));
|
||||||
@@ -2029,31 +2046,8 @@ public class OpensyncExternalIntegrationCloud implements OpensyncExternalIntegra
|
|||||||
// Create or update
|
// Create or update
|
||||||
Client client = clientServiceInterface.getOrNull(customerId, clientMacAddress);
|
Client client = clientServiceInterface.getOrNull(customerId, clientMacAddress);
|
||||||
if (client == null) {
|
if (client == null) {
|
||||||
LOG.info("Cannot find client instance for {}", clientMacAddress);
|
LOG.info("No client present for {}", clientMacAddress);
|
||||||
if (rowUpdateOperation.equals(RowUpdateOperation.INSERT)) {
|
continue;
|
||||||
client = new Client();
|
|
||||||
client.setCustomerId(customerId);
|
|
||||||
client.setMacAddress(clientMacAddress);
|
|
||||||
client.setDetails(new ClientInfoDetails());
|
|
||||||
if (dhcpLeasedIps.containsKey("hostname")) {
|
|
||||||
((ClientInfoDetails) client.getDetails()).setHostName(dhcpLeasedIps.get("hostname"));
|
|
||||||
}
|
|
||||||
if (dhcpLeasedIps.containsKey("fingerprint")) {
|
|
||||||
((ClientInfoDetails) client.getDetails()).setApFingerprint(dhcpLeasedIps.get("fingerprint"));
|
|
||||||
}
|
|
||||||
if (dhcpLeasedIps.containsKey("device_type")) {
|
|
||||||
DhcpFpDeviceType dhcpFpDeviceType = DhcpFpDeviceType.getByName(dhcpLeasedIps.get("device_type"));
|
|
||||||
ClientType clientType = OvsdbToWlanCloudTypeMappingUtility.getClientTypeForDhcpFpDeviceType(dhcpFpDeviceType);
|
|
||||||
LOG.debug("Translate from ovsdb {} to cloud {}", dhcpFpDeviceType, clientType);
|
|
||||||
((ClientInfoDetails) client.getDetails()).setClientType(clientType.getId());
|
|
||||||
}
|
|
||||||
client = clientServiceInterface.create(client);
|
|
||||||
LOG.info("Created client from DHCP_Leased_IP event {}.", client);
|
|
||||||
ClientSession session = updateClientSession(customerId, equipmentId, locationId, dhcpLeasedIps, clientMacAddress);
|
|
||||||
if (session != null) {
|
|
||||||
clientSessionList.add(session);
|
|
||||||
}
|
|
||||||
}
|
|
||||||
} else {
|
} else {
|
||||||
LOG.info("Client {} already exists on the cloud, update client values", dhcpLeasedIps);
|
LOG.info("Client {} already exists on the cloud, update client values", dhcpLeasedIps);
|
||||||
if (dhcpLeasedIps.containsKey("hostname")) {
|
if (dhcpLeasedIps.containsKey("hostname")) {
|
||||||
@@ -2133,19 +2127,8 @@ public class OpensyncExternalIntegrationCloud implements OpensyncExternalIntegra
|
|||||||
|
|
||||||
ClientSession session = clientServiceInterface.getSessionOrNull(customerId, equipmentId, clientMacAddress);
|
ClientSession session = clientServiceInterface.getSessionOrNull(customerId, equipmentId, clientMacAddress);
|
||||||
if (session == null) {
|
if (session == null) {
|
||||||
session = new ClientSession();
|
LOG.info("No session for client {} with for customer {} equipment {}", clientMacAddress, customerId, equipmentId);
|
||||||
session.setCustomerId(customerId);
|
return null;
|
||||||
session.setEquipmentId(equipmentId);
|
|
||||||
session.setLocationId(locationId);
|
|
||||||
session.setMacAddress(clientMacAddress);
|
|
||||||
session.setDetails(new ClientSessionDetails());
|
|
||||||
session.getDetails().setSessionId(clientMacAddress.getAddressAsLong());
|
|
||||||
session.getDetails().setDhcpDetails(new ClientDhcpDetails(clientMacAddress.getAddressAsLong()));
|
|
||||||
session.getDetails().getDhcpDetails().setLeaseStartTimestamp(timestamp);
|
|
||||||
session.getDetails().setMetricDetails(new ClientSessionMetricDetails());
|
|
||||||
session.getDetails().setLastEventTimestamp(timestamp);
|
|
||||||
session.getDetails().setAssociationState(AssociationState._802_11_Associated);
|
|
||||||
session.getDetails().setAssocTimestamp(timestamp);
|
|
||||||
} else {
|
} else {
|
||||||
if (session.getDetails().getPriorEquipmentId() == null) {
|
if (session.getDetails().getPriorEquipmentId() == null) {
|
||||||
session.getDetails().setPriorEquipmentId(session.getEquipmentId());
|
session.getDetails().setPriorEquipmentId(session.getEquipmentId());
|
||||||
@@ -2437,6 +2420,7 @@ public class OpensyncExternalIntegrationCloud implements OpensyncExternalIntegra
|
|||||||
LOG.error("UnknownHost for designatedRouterIp", e);
|
LOG.error("UnknownHost for designatedRouterIp", e);
|
||||||
}
|
}
|
||||||
Status protocolStatus = statusServiceInterface.getOrNull(customerId, equipmentId, StatusDataType.PROTOCOL);
|
Status protocolStatus = statusServiceInterface.getOrNull(customerId, equipmentId, StatusDataType.PROTOCOL);
|
||||||
|
String mode = apcStateAttributes.get("mode");
|
||||||
|
|
||||||
InetAddress localIpV4Addr = null;
|
InetAddress localIpV4Addr = null;
|
||||||
if (protocolStatus != null) {
|
if (protocolStatus != null) {
|
||||||
@@ -2445,10 +2429,13 @@ public class OpensyncExternalIntegrationCloud implements OpensyncExternalIntegra
|
|||||||
((EquipmentProtocolStatusData) protocolStatus.getDetails()).setLastApcUpdate(System.currentTimeMillis());
|
((EquipmentProtocolStatusData) protocolStatus.getDetails()).setLastApcUpdate(System.currentTimeMillis());
|
||||||
((EquipmentProtocolStatusData) protocolStatus.getDetails()).setReportedApcAddress(drIpAddr);
|
((EquipmentProtocolStatusData) protocolStatus.getDetails()).setReportedApcAddress(drIpAddr);
|
||||||
((EquipmentProtocolStatusData) protocolStatus.getDetails()).setRadiusProxyAddress(drIpAddr);
|
((EquipmentProtocolStatusData) protocolStatus.getDetails()).setRadiusProxyAddress(drIpAddr);
|
||||||
|
((EquipmentProtocolStatusData) protocolStatus.getDetails()).setApcMode(ApcMode.valueOf(mode));
|
||||||
|
((EquipmentProtocolStatusData) protocolStatus.getDetails()).setApcBackupDesignatedRouterIpAddress(bdrIpAddr);
|
||||||
|
((EquipmentProtocolStatusData) protocolStatus.getDetails()).setApcDesignatedRouterIpAddress(drIpAddr);
|
||||||
|
|
||||||
protocolStatus = statusServiceInterface.update(protocolStatus);
|
protocolStatus = statusServiceInterface.update(protocolStatus);
|
||||||
LOG.info("Protocol Status updated for APC_State table monitor change {}", protocolStatus);
|
LOG.info("Protocol Status updated for APC_State table monitor change {}", protocolStatus);
|
||||||
}
|
}
|
||||||
String mode = apcStateAttributes.get("mode");
|
|
||||||
ApcElectionEvent electionEvent =
|
ApcElectionEvent electionEvent =
|
||||||
new ApcElectionEvent(drIpAddr, bdrIpAddr, localIpV4Addr, drIpAddr, mode, Boolean.valueOf(apcStateAttributes.get("enabled")),
|
new ApcElectionEvent(drIpAddr, bdrIpAddr, localIpV4Addr, drIpAddr, mode, Boolean.valueOf(apcStateAttributes.get("enabled")),
|
||||||
RealTimeEventType.APC_Election_event, customerId, ce.getLocationId(), equipmentId, System.currentTimeMillis());
|
RealTimeEventType.APC_Election_event, customerId, ce.getLocationId(), equipmentId, System.currentTimeMillis());
|
||||||
|
|||||||
@@ -1,3 +1,4 @@
|
|||||||
|
|
||||||
package com.telecominfraproject.wlan.opensync.external.integration.controller;
|
package com.telecominfraproject.wlan.opensync.external.integration.controller;
|
||||||
|
|
||||||
import java.util.ArrayList;
|
import java.util.ArrayList;
|
||||||
@@ -149,19 +150,16 @@ public class OpensyncCloudGatewayController {
|
|||||||
String inventoryId = command.getInventoryId();
|
String inventoryId = command.getInventoryId();
|
||||||
|
|
||||||
if (com.telecominfraproject.wlan.core.model.json.BaseJsonModel.hasUnsupportedValue(command)) {
|
if (com.telecominfraproject.wlan.core.model.json.BaseJsonModel.hasUnsupportedValue(command)) {
|
||||||
LOG.error("[{}] Failed to deliver command {}, command contains unsupported value", inventoryId,
|
LOG.error("[{}] Failed to deliver command {}, command contains unsupported value", inventoryId, command);
|
||||||
command);
|
ret.add(new EquipmentCommandResponse(CEGWCommandResultCode.UnsupportedCommand, "Unsupported value in command for " + inventoryId, command,
|
||||||
ret.add(new EquipmentCommandResponse(CEGWCommandResultCode.UnsupportedCommand,
|
registeredGateway == null ? null : registeredGateway.getHostname(), registeredGateway == null ? -1 : registeredGateway.getPort()));
|
||||||
"Unsupported value in command for " + inventoryId, command, registeredGateway.getHostname(),
|
|
||||||
registeredGateway.getPort()));
|
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
OvsdbSession session = ovsdbSessionMapInterface.getSession(inventoryId);
|
OvsdbSession session = ovsdbSessionMapInterface.getSession(inventoryId);
|
||||||
if (session == null) {
|
if (session == null) {
|
||||||
LOG.warn("[{}] Failed to deliver command {}, equipment session not found", inventoryId, command);
|
LOG.warn("[{}] Failed to deliver command {}, equipment session not found", inventoryId, command);
|
||||||
ret.add(new EquipmentCommandResponse(CEGWCommandResultCode.NoRouteToCE,
|
ret.add(new EquipmentCommandResponse(CEGWCommandResultCode.NoRouteToCE, "No session found for " + inventoryId, command,
|
||||||
"No session found for " + inventoryId, command, registeredGateway.getHostname(),
|
registeredGateway == null ? null : registeredGateway.getHostname(), registeredGateway == null ? -1 : registeredGateway.getPort()));
|
||||||
registeredGateway.getPort()));
|
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
|
|
||||||
@@ -201,8 +199,7 @@ public class OpensyncCloudGatewayController {
|
|||||||
ret.add(processRadioReboot(session, (CEGWRebootRequest) command));
|
ret.add(processRadioReboot(session, (CEGWRebootRequest) command));
|
||||||
break;
|
break;
|
||||||
case ClientBlocklistChangeNotification:
|
case ClientBlocklistChangeNotification:
|
||||||
ret.add(sendClientBlocklistChangeNotification(session,
|
ret.add(sendClientBlocklistChangeNotification(session, (CEGWClientBlocklistChangeNotification) command));
|
||||||
(CEGWClientBlocklistChangeNotification) command));
|
|
||||||
break;
|
break;
|
||||||
case NewChannelRequest:
|
case NewChannelRequest:
|
||||||
ret.add(sendNewChannelRequest(session, (CEGWNewChannelRequest) command));
|
ret.add(sendNewChannelRequest(session, (CEGWNewChannelRequest) command));
|
||||||
@@ -212,22 +209,20 @@ public class OpensyncCloudGatewayController {
|
|||||||
break;
|
break;
|
||||||
default:
|
default:
|
||||||
LOG.warn("[{}] Failed to deliver command {}, unsupported command type", inventoryId, command);
|
LOG.warn("[{}] Failed to deliver command {}, unsupported command type", inventoryId, command);
|
||||||
ret.add(new EquipmentCommandResponse(
|
ret.add(new EquipmentCommandResponse(CEGWCommandResultCode.UnsupportedCommand,
|
||||||
CEGWCommandResultCode.UnsupportedCommand, "Invalid command type ("
|
"Invalid command type (" + command.getCommandType() + ") for equipment (" + inventoryId + ")", command,
|
||||||
+ command.getCommandType() + ") for equipment (" + inventoryId + ")",
|
registeredGateway == null ? null : registeredGateway.getHostname(),
|
||||||
command, registeredGateway.getHostname(), registeredGateway.getPort()));
|
registeredGateway == null ? -1 : registeredGateway.getPort()));
|
||||||
}
|
}
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
});
|
});
|
||||||
|
|
||||||
return ret;
|
return ret;
|
||||||
}
|
}
|
||||||
|
|
||||||
private EquipmentCommandResponse processFirmwareDownload(OvsdbSession session,
|
private EquipmentCommandResponse processFirmwareDownload(OvsdbSession session, CEGWFirmwareDownloadRequest command) {
|
||||||
CEGWFirmwareDownloadRequest command) {
|
|
||||||
return sendMessage(session, command.getInventoryId(), command);
|
return sendMessage(session, command.getInventoryId(), command);
|
||||||
}
|
}
|
||||||
|
|
||||||
@@ -259,19 +254,18 @@ public class OpensyncCloudGatewayController {
|
|||||||
if (null != command.getRoutingId()) {
|
if (null != command.getRoutingId()) {
|
||||||
if (!command.getRoutingId().equals(session.getRoutingId())) {
|
if (!command.getRoutingId().equals(session.getRoutingId())) {
|
||||||
|
|
||||||
LOG.info("[C:{} E:{} R:{}] Stale routing entry ({}) detected", session.getCustomerId(),
|
LOG.info("[C:{} E:{} R:{}] Stale routing entry ({}) detected", session.getCustomerId(), command.getInventoryId(), session.getRoutingId(),
|
||||||
command.getInventoryId(), session.getRoutingId(), command.getRoutingId());
|
command.getRoutingId());
|
||||||
|
|
||||||
return new EquipmentCommandResponse(CEGWCommandResultCode.NoRouteToCE, "Inactive Route Identifer",
|
return new EquipmentCommandResponse(CEGWCommandResultCode.NoRouteToCE, "Inactive Route Identifer", command,
|
||||||
command, registeredGateway.getHostname(), registeredGateway.getPort());
|
registeredGateway == null ? null : registeredGateway.getHostname(), registeredGateway == null ? -1 : registeredGateway.getPort());
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
return new EquipmentCommandResponse(CEGWCommandResultCode.Success, "Route active", command,
|
return new EquipmentCommandResponse(CEGWCommandResultCode.Success, "Route active", command,
|
||||||
registeredGateway.getHostname(), registeredGateway.getPort());
|
registeredGateway == null ? null : registeredGateway.getHostname(), registeredGateway == null ? -1 : registeredGateway.getPort());
|
||||||
}
|
}
|
||||||
|
|
||||||
private EquipmentCommandResponse sendConfigChangeNotification(OvsdbSession session,
|
private EquipmentCommandResponse sendConfigChangeNotification(OvsdbSession session, CEGWConfigChangeNotification command) {
|
||||||
CEGWConfigChangeNotification command) {
|
|
||||||
|
|
||||||
return sendMessage(session, command.getInventoryId(), command);
|
return sendMessage(session, command.getInventoryId(), command);
|
||||||
}
|
}
|
||||||
@@ -281,27 +275,24 @@ public class OpensyncCloudGatewayController {
|
|||||||
session.getOvsdbClient().shutdown();
|
session.getOvsdbClient().shutdown();
|
||||||
} catch (Exception e) {
|
} catch (Exception e) {
|
||||||
LOG.error("[{}] Failed to close session on CE: {}", command.getInventoryId(), e.getLocalizedMessage());
|
LOG.error("[{}] Failed to close session on CE: {}", command.getInventoryId(), e.getLocalizedMessage());
|
||||||
return new EquipmentCommandResponse(
|
return new EquipmentCommandResponse(CEGWCommandResultCode.FailedToSend,
|
||||||
CEGWCommandResultCode.FailedToSend, "Failed to send command " + command.getCommandType() + " to "
|
"Failed to send command " + command.getCommandType() + " to " + command.getInventoryId() + ": " + e.getMessage(), command,
|
||||||
+ command.getInventoryId() + ": " + e.getMessage(),
|
registeredGateway == null ? null : registeredGateway.getHostname(), registeredGateway == null ? -1 : registeredGateway.getPort());
|
||||||
command, registeredGateway.getHostname(), registeredGateway.getPort());
|
|
||||||
}
|
}
|
||||||
LOG.debug("[{}] Closed session to CE", command.getInventoryId());
|
LOG.debug("[{}] Closed session to CE", command.getInventoryId());
|
||||||
return new EquipmentCommandResponse(CEGWCommandResultCode.Success,
|
return new EquipmentCommandResponse(CEGWCommandResultCode.Success, "Closed session to " + command.getInventoryId(), command,
|
||||||
"Closed session to " + command.getInventoryId(), command, registeredGateway.getHostname(),
|
registeredGateway == null ? null : registeredGateway.getHostname(), registeredGateway == null ? -1 : registeredGateway.getPort());
|
||||||
registeredGateway.getPort());
|
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|
||||||
private EquipmentCommandResponse sendClientBlocklistChangeNotification(OvsdbSession session,
|
private EquipmentCommandResponse sendClientBlocklistChangeNotification(OvsdbSession session, CEGWClientBlocklistChangeNotification command) {
|
||||||
CEGWClientBlocklistChangeNotification command) {
|
|
||||||
return sendMessage(session, command.getInventoryId(), command);
|
return sendMessage(session, command.getInventoryId(), command);
|
||||||
}
|
}
|
||||||
|
|
||||||
private EquipmentCommandResponse sendNewChannelRequest(OvsdbSession session, CEGWNewChannelRequest command) {
|
private EquipmentCommandResponse sendNewChannelRequest(OvsdbSession session, CEGWNewChannelRequest command) {
|
||||||
return sendMessage(session, command.getInventoryId(), command);
|
return sendMessage(session, command.getInventoryId(), command);
|
||||||
}
|
}
|
||||||
|
|
||||||
private EquipmentCommandResponse sendCellSizeRequest(OvsdbSession session, CEGWCellSizeAttributesRequest command) {
|
private EquipmentCommandResponse sendCellSizeRequest(OvsdbSession session, CEGWCellSizeAttributesRequest command) {
|
||||||
return sendMessage(session, command.getInventoryId(), command);
|
return sendMessage(session, command.getInventoryId(), command);
|
||||||
}
|
}
|
||||||
@@ -317,15 +308,17 @@ public class OpensyncCloudGatewayController {
|
|||||||
private EquipmentCommandResponse sendMessage(OvsdbSession session, String inventoryId, EquipmentCommand command) {
|
private EquipmentCommandResponse sendMessage(OvsdbSession session, String inventoryId, EquipmentCommand command) {
|
||||||
|
|
||||||
LOG.debug("Received command {} for {}", command.getCommandType(), inventoryId);
|
LOG.debug("Received command {} for {}", command.getCommandType(), inventoryId);
|
||||||
EquipmentCommandResponse response = new EquipmentCommandResponse(CEGWCommandResultCode.Success,
|
EquipmentCommandResponse response =
|
||||||
"Received Command " + command.getCommandType() + " for " + inventoryId, command,
|
new EquipmentCommandResponse(CEGWCommandResultCode.Success, "Received Command " + command.getCommandType() + " for " + inventoryId, command,
|
||||||
registeredGateway.getHostname(), registeredGateway.getPort());
|
registeredGateway == null ? null : registeredGateway.getHostname(), registeredGateway == null ? -1 : registeredGateway.getPort());
|
||||||
|
|
||||||
if (command instanceof CEGWConfigChangeNotification) {
|
if (command instanceof CEGWBlinkRequest) {
|
||||||
|
String resultDetails = tipwlanOvsdbClient.processBlinkRequest(inventoryId, ((CEGWBlinkRequest)command).getBlinkAllLEDs());
|
||||||
|
response.setResultDetail(resultDetails);
|
||||||
|
} else if (command instanceof CEGWConfigChangeNotification) {
|
||||||
tipwlanOvsdbClient.processConfigChanged(inventoryId);
|
tipwlanOvsdbClient.processConfigChanged(inventoryId);
|
||||||
} else if (command instanceof CEGWClientBlocklistChangeNotification) {
|
} else if (command instanceof CEGWClientBlocklistChangeNotification) {
|
||||||
tipwlanOvsdbClient.processClientBlocklistChange(inventoryId,
|
tipwlanOvsdbClient.processClientBlocklistChange(inventoryId, ((CEGWClientBlocklistChangeNotification) command).getBlockList());
|
||||||
((CEGWClientBlocklistChangeNotification) command).getBlockList());
|
|
||||||
} else if (command instanceof CEGWChangeRedirectorHost) {
|
} else if (command instanceof CEGWChangeRedirectorHost) {
|
||||||
String newRedirectorAddress = ((CEGWChangeRedirectorHost) command).getRedirectorHost();
|
String newRedirectorAddress = ((CEGWChangeRedirectorHost) command).getRedirectorHost();
|
||||||
tipwlanOvsdbClient.changeRedirectorHost(inventoryId, newRedirectorAddress);
|
tipwlanOvsdbClient.changeRedirectorHost(inventoryId, newRedirectorAddress);
|
||||||
@@ -340,7 +333,7 @@ public class OpensyncCloudGatewayController {
|
|||||||
Map<RadioType, Integer> newBackupChannels = request.getNewBackupChannels();
|
Map<RadioType, Integer> newBackupChannels = request.getNewBackupChannels();
|
||||||
Map<RadioType, Integer> newPrimaryChannels = request.getNewPrimaryChannels();
|
Map<RadioType, Integer> newPrimaryChannels = request.getNewPrimaryChannels();
|
||||||
|
|
||||||
String resultDetails = tipwlanOvsdbClient.processNewChannelsRequest(inventoryId, newBackupChannels,newPrimaryChannels);
|
String resultDetails = tipwlanOvsdbClient.processNewChannelsRequest(inventoryId, newBackupChannels, newPrimaryChannels);
|
||||||
response.setResultDetail(resultDetails);
|
response.setResultDetail(resultDetails);
|
||||||
} else if (command instanceof CEGWCellSizeAttributesRequest) {
|
} else if (command instanceof CEGWCellSizeAttributesRequest) {
|
||||||
CEGWCellSizeAttributesRequest request = (CEGWCellSizeAttributesRequest) command;
|
CEGWCellSizeAttributesRequest request = (CEGWCellSizeAttributesRequest) command;
|
||||||
@@ -357,8 +350,7 @@ public class OpensyncCloudGatewayController {
|
|||||||
String firmwareVersion = dlRequest.getFirmwareVersion();
|
String firmwareVersion = dlRequest.getFirmwareVersion();
|
||||||
String username = dlRequest.getUsername();
|
String username = dlRequest.getUsername();
|
||||||
|
|
||||||
String resultDetails = tipwlanOvsdbClient.processFirmwareDownload(inventoryId, filepath, firmwareVersion,
|
String resultDetails = tipwlanOvsdbClient.processFirmwareDownload(inventoryId, filepath, firmwareVersion, username);
|
||||||
username);
|
|
||||||
|
|
||||||
response.setResultDetail(resultDetails);
|
response.setResultDetail(resultDetails);
|
||||||
|
|
||||||
@@ -370,15 +362,15 @@ public class OpensyncCloudGatewayController {
|
|||||||
flashRequest.getInventoryId();
|
flashRequest.getInventoryId();
|
||||||
flashRequest.getUsername();
|
flashRequest.getUsername();
|
||||||
|
|
||||||
String resultDetails = tipwlanOvsdbClient.processFirmwareFlash(flashRequest.getInventoryId(),
|
String resultDetails =
|
||||||
flashRequest.getFirmwareVersion(), flashRequest.getUsername());
|
tipwlanOvsdbClient.processFirmwareFlash(flashRequest.getInventoryId(), flashRequest.getFirmwareVersion(), flashRequest.getUsername());
|
||||||
|
|
||||||
response.setResultDetail(resultDetails);
|
response.setResultDetail(resultDetails);
|
||||||
|
|
||||||
} else if (command instanceof CEGWRadioResetRequest) {
|
} else if (command instanceof CEGWRadioResetRequest) {
|
||||||
response = new EquipmentCommandResponse(CEGWCommandResultCode.UnsupportedCommand,
|
response = new EquipmentCommandResponse(CEGWCommandResultCode.UnsupportedCommand,
|
||||||
"Received Command " + command.getCommandType() + " for " + inventoryId, command,
|
"Received Command " + command.getCommandType() + " for " + inventoryId, command,
|
||||||
registeredGateway.getHostname(), registeredGateway.getPort());
|
registeredGateway == null ? null : registeredGateway.getHostname(), registeredGateway == null ? -1 : registeredGateway.getPort());
|
||||||
} else if (command instanceof CEGWRebootRequest) {
|
} else if (command instanceof CEGWRebootRequest) {
|
||||||
|
|
||||||
CEGWRebootRequest rebootRequest = (CEGWRebootRequest) command;
|
CEGWRebootRequest rebootRequest = (CEGWRebootRequest) command;
|
||||||
@@ -402,10 +394,9 @@ public class OpensyncCloudGatewayController {
|
|||||||
default:
|
default:
|
||||||
response = new EquipmentCommandResponse(CEGWCommandResultCode.UnsupportedCommand,
|
response = new EquipmentCommandResponse(CEGWCommandResultCode.UnsupportedCommand,
|
||||||
"Received Command " + command.getCommandType() + " for " + inventoryId, command,
|
"Received Command " + command.getCommandType() + " for " + inventoryId, command,
|
||||||
registeredGateway.getHostname(), registeredGateway.getPort());
|
registeredGateway == null ? null : registeredGateway.getHostname(), registeredGateway == null ? -1 : registeredGateway.getPort());
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|
||||||
return response;
|
return response;
|
||||||
@@ -423,15 +414,14 @@ public class OpensyncCloudGatewayController {
|
|||||||
return sendMessage(session, command.getInventoryId(), command);
|
return sendMessage(session, command.getInventoryId(), command);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
private EquipmentCommandResponse processBlinkRequest(OvsdbSession session, CEGWBlinkRequest command) {
|
private EquipmentCommandResponse processBlinkRequest(OvsdbSession session, CEGWBlinkRequest command) {
|
||||||
|
|
||||||
return sendMessage(session, command.getInventoryId(), command);
|
return sendMessage(session, command.getInventoryId(), command);
|
||||||
}
|
}
|
||||||
|
|
||||||
@RequestMapping(value = "/commandWithUser", method = RequestMethod.POST)
|
@RequestMapping(value = "/commandWithUser", method = RequestMethod.POST)
|
||||||
public EquipmentCommandResponse sendCommandWithAuthUser(@RequestBody EquipmentCommand command,
|
public EquipmentCommandResponse sendCommandWithAuthUser(@RequestBody EquipmentCommand command, @AuthenticationPrincipal Object requestUser,
|
||||||
@AuthenticationPrincipal Object requestUser, HttpServletRequest httpServletRequest) {
|
HttpServletRequest httpServletRequest) {
|
||||||
|
|
||||||
// use these properties to get address and port where request has
|
// use these properties to get address and port where request has
|
||||||
// arrived
|
// arrived
|
||||||
@@ -464,8 +454,7 @@ public class OpensyncCloudGatewayController {
|
|||||||
}
|
}
|
||||||
|
|
||||||
if (eqRoutingSvc == null) {
|
if (eqRoutingSvc == null) {
|
||||||
throw new ConfigurationException(
|
throw new ConfigurationException("Unable to register gateway with routing service: routing service interface not initialized");
|
||||||
"Unable to register gateway with routing service: routing service interface not initialized");
|
|
||||||
}
|
}
|
||||||
|
|
||||||
cleanupStaleGwRecord();
|
cleanupStaleGwRecord();
|
||||||
@@ -481,13 +470,11 @@ public class OpensyncCloudGatewayController {
|
|||||||
EquipmentGatewayRecord result = eqRoutingSvc.registerGateway(gwRecord);
|
EquipmentGatewayRecord result = eqRoutingSvc.registerGateway(gwRecord);
|
||||||
registeredGwId = result.getId();
|
registeredGwId = result.getId();
|
||||||
registeredGateway = result;
|
registeredGateway = result;
|
||||||
LOG.info("Successfully registered (name={}, id={}) with Routing Service", result.getHostname(),
|
LOG.info("Successfully registered (name={}, id={}) with Routing Service", result.getHostname(), registeredGwId);
|
||||||
registeredGwId);
|
|
||||||
registeredWithRoutingService = true;
|
registeredWithRoutingService = true;
|
||||||
} catch (RuntimeException e) {
|
} catch (RuntimeException e) {
|
||||||
// failed
|
// failed
|
||||||
LOG.error("Failed to register Customer Equipment Gateway (name={}) with Routing Service : {}",
|
LOG.error("Failed to register Customer Equipment Gateway (name={}) with Routing Service : {}", getGatewayName(), e.getLocalizedMessage());
|
||||||
getGatewayName(), e.getLocalizedMessage());
|
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
@@ -512,8 +499,7 @@ public class OpensyncCloudGatewayController {
|
|||||||
eqRoutingSvc.deleteGateway(eqpRec.getId());
|
eqRoutingSvc.deleteGateway(eqpRec.getId());
|
||||||
} catch (RuntimeException e) {
|
} catch (RuntimeException e) {
|
||||||
// failed
|
// failed
|
||||||
LOG.error("Failed to delete Equipment Gateway (name={}) from Routing Service: {}",
|
LOG.error("Failed to delete Equipment Gateway (name={}) from Routing Service: {}", eqpRec.getHostname(), e.getLocalizedMessage());
|
||||||
eqpRec.getHostname(), e.getLocalizedMessage());
|
|
||||||
}
|
}
|
||||||
} else {
|
} else {
|
||||||
LOG.debug("Gateway {} is reachable.", eqpRec.getHostname());
|
LOG.debug("Gateway {} is reachable.", eqpRec.getHostname());
|
||||||
@@ -524,9 +510,8 @@ public class OpensyncCloudGatewayController {
|
|||||||
}
|
}
|
||||||
} catch (Exception ex) { // Catching Exception to prevent crashing the
|
} catch (Exception ex) { // Catching Exception to prevent crashing the
|
||||||
// register thread
|
// register thread
|
||||||
LOG.debug("Generic Exception encountered when trying to cleanup "
|
LOG.debug("Generic Exception encountered when trying to cleanup " + "the stale not-reachable GateWays. Continuing to register the new Gateway."
|
||||||
+ "the stale not-reachable GateWays. Continuing to register the new Gateway." + " Error: {} ",
|
+ " Error: {} ", ex.getMessage());
|
||||||
ex.getMessage());
|
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
@@ -550,14 +535,13 @@ public class OpensyncCloudGatewayController {
|
|||||||
if (registeredWithRoutingService) {
|
if (registeredWithRoutingService) {
|
||||||
try {
|
try {
|
||||||
eqRoutingSvc.deleteGateway(registeredGwId);
|
eqRoutingSvc.deleteGateway(registeredGwId);
|
||||||
LOG.info("Deregistered Customer Equipment Gateway (name={},id={}) with Routing Service",
|
LOG.info("Deregistered Customer Equipment Gateway (name={},id={}) with Routing Service", getGatewayName(), registeredGwId);
|
||||||
getGatewayName(), registeredGwId);
|
|
||||||
registeredGwId = -1;
|
registeredGwId = -1;
|
||||||
registeredGateway = null;
|
registeredGateway = null;
|
||||||
} catch (Exception e) {
|
} catch (Exception e) {
|
||||||
// failed
|
// failed
|
||||||
LOG.error("Failed to deregister Customer Equipment Gateway (name={},id={}) with Routing Service: {}",
|
LOG.error("Failed to deregister Customer Equipment Gateway (name={},id={}) with Routing Service: {}", getGatewayName(), registeredGwId,
|
||||||
getGatewayName(), registeredGwId, e.getLocalizedMessage());
|
e.getLocalizedMessage());
|
||||||
}
|
}
|
||||||
registeredWithRoutingService = false;
|
registeredWithRoutingService = false;
|
||||||
}
|
}
|
||||||
@@ -575,12 +559,10 @@ public class OpensyncCloudGatewayController {
|
|||||||
* @param equipmentId
|
* @param equipmentId
|
||||||
* @return associationId
|
* @return associationId
|
||||||
*/
|
*/
|
||||||
public EquipmentRoutingRecord registerCustomerEquipment(String equipmentName, Integer customerId,
|
public EquipmentRoutingRecord registerCustomerEquipment(String equipmentName, Integer customerId, Long equipmentId) {
|
||||||
Long equipmentId) {
|
|
||||||
registerWithRoutingService();
|
registerWithRoutingService();
|
||||||
if (!registeredWithRoutingService) {
|
if (!registeredWithRoutingService) {
|
||||||
LOG.error("Unable to register customer equipement (name={},id={}): gateway not registered.", equipmentName,
|
LOG.error("Unable to register customer equipement (name={},id={}): gateway not registered.", equipmentName, equipmentId);
|
||||||
equipmentId);
|
|
||||||
return null;
|
return null;
|
||||||
}
|
}
|
||||||
// Clean up stale records
|
// Clean up stale records
|
||||||
@@ -592,13 +574,11 @@ public class OpensyncCloudGatewayController {
|
|||||||
try {
|
try {
|
||||||
routingRecord = eqRoutingSvc.create(routingRecord);
|
routingRecord = eqRoutingSvc.create(routingRecord);
|
||||||
|
|
||||||
LOG.debug("Registered customer equipment (name={},id={}) with route id={}", equipmentName, equipmentId,
|
LOG.debug("Registered customer equipment (name={},id={}) with route id={}", equipmentName, equipmentId, routingRecord.getId());
|
||||||
routingRecord.getId());
|
|
||||||
return routingRecord;
|
return routingRecord;
|
||||||
|
|
||||||
} catch (Exception e) {
|
} catch (Exception e) {
|
||||||
LOG.error("Failed to register customer equipement (name={},id={}): {}", equipmentName, equipmentId,
|
LOG.error("Failed to register customer equipement (name={},id={}): {}", equipmentName, equipmentId, e.getLocalizedMessage());
|
||||||
e.getLocalizedMessage());
|
|
||||||
}
|
}
|
||||||
return null;
|
return null;
|
||||||
}
|
}
|
||||||
@@ -611,7 +591,7 @@ public class OpensyncCloudGatewayController {
|
|||||||
* Gateway does not exist, delete the equipmentRouting entry.
|
* Gateway does not exist, delete the equipmentRouting entry.
|
||||||
*
|
*
|
||||||
* @param equipmentId:
|
* @param equipmentId:
|
||||||
* Equipment's ID
|
* Equipment's ID
|
||||||
*/
|
*/
|
||||||
protected void cleanupStaleEqptRoutingRecord(Long equipmentId) {
|
protected void cleanupStaleEqptRoutingRecord(Long equipmentId) {
|
||||||
LOG.debug("In Clean Up stale Equipment Routing record for Equipment ID {}", equipmentId);
|
LOG.debug("In Clean Up stale Equipment Routing record for Equipment ID {}", equipmentId);
|
||||||
@@ -624,20 +604,17 @@ public class OpensyncCloudGatewayController {
|
|||||||
if (gwRec != null) {
|
if (gwRec != null) {
|
||||||
if (!isGwReachable(gwRec.getIpAddr(), gwRec.getPort())) {
|
if (!isGwReachable(gwRec.getIpAddr(), gwRec.getPort())) {
|
||||||
// GW isn't reachable --> invoke unregister
|
// GW isn't reachable --> invoke unregister
|
||||||
LOG.debug("Gateway {} is not-reachable... Deleting the equipment routing entry",
|
LOG.debug("Gateway {} is not-reachable... Deleting the equipment routing entry", gwRec.getHostname());
|
||||||
gwRec.getHostname());
|
|
||||||
deleteUnresponiveGwRoutingRecord(eqRouting.getId(), equipmentId);
|
deleteUnresponiveGwRoutingRecord(eqRouting.getId(), equipmentId);
|
||||||
} else {
|
} else {
|
||||||
LOG.debug("Gateway {} is reachable.", gwRec.getHostname());
|
LOG.debug("Gateway {} is reachable.", gwRec.getHostname());
|
||||||
}
|
}
|
||||||
} else {
|
} else {
|
||||||
LOG.debug("Gateway with ID {} not found. Deleting the equipment routing entry ",
|
LOG.debug("Gateway with ID {} not found. Deleting the equipment routing entry ", eqRouting.getGatewayId());
|
||||||
eqRouting.getGatewayId());
|
|
||||||
deleteUnresponiveGwRoutingRecord(eqRouting.getId(), equipmentId);
|
deleteUnresponiveGwRoutingRecord(eqRouting.getId(), equipmentId);
|
||||||
}
|
}
|
||||||
} catch (DsEntityNotFoundException entityNotFoundException) {
|
} catch (DsEntityNotFoundException entityNotFoundException) {
|
||||||
LOG.debug("Gateway ID: {} not found... Deleting the equipment routing entry",
|
LOG.debug("Gateway ID: {} not found... Deleting the equipment routing entry", eqRouting.getGatewayId());
|
||||||
eqRouting.getGatewayId());
|
|
||||||
deleteUnresponiveGwRoutingRecord(eqRouting.getId(), equipmentId);
|
deleteUnresponiveGwRoutingRecord(eqRouting.getId(), equipmentId);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
@@ -646,9 +623,10 @@ public class OpensyncCloudGatewayController {
|
|||||||
}
|
}
|
||||||
} catch (Exception genericException) { // Catching Exception to prevent
|
} catch (Exception genericException) { // Catching Exception to prevent
|
||||||
// crashing the register thread
|
// crashing the register thread
|
||||||
LOG.debug("Generic Exception encountered when trying to cleanup "
|
LOG.debug(
|
||||||
+ "the stale routing records for equipment ID: {}. Continuing to register the new RoutingRecord."
|
"Generic Exception encountered when trying to cleanup "
|
||||||
+ " Error: {} ", equipmentId, genericException.getMessage());
|
+ "the stale routing records for equipment ID: {}. Continuing to register the new RoutingRecord." + " Error: {} ",
|
||||||
|
equipmentId, genericException.getMessage());
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
@@ -657,8 +635,7 @@ public class OpensyncCloudGatewayController {
|
|||||||
eqRoutingSvc.delete(routingId);
|
eqRoutingSvc.delete(routingId);
|
||||||
} catch (RuntimeException e) {
|
} catch (RuntimeException e) {
|
||||||
// failed
|
// failed
|
||||||
LOG.error("Failed to delete Equipment routing record (ID={}) from Routing Service: {}", eqptId,
|
LOG.error("Failed to delete Equipment routing record (ID={}) from Routing Service: {}", eqptId, e.getLocalizedMessage());
|
||||||
e.getLocalizedMessage());
|
|
||||||
return false;
|
return false;
|
||||||
}
|
}
|
||||||
return true;
|
return true;
|
||||||
@@ -666,18 +643,16 @@ public class OpensyncCloudGatewayController {
|
|||||||
|
|
||||||
public void deregisterCustomerEquipment(Long routingId, String equipmentName, Long equipmentId) {
|
public void deregisterCustomerEquipment(Long routingId, String equipmentName, Long equipmentId) {
|
||||||
if (!registeredWithRoutingService) {
|
if (!registeredWithRoutingService) {
|
||||||
LOG.error("Unable to deregister customer equipement (name={},id={}): gateway not registered", equipmentName,
|
LOG.error("Unable to deregister customer equipement (name={},id={}): gateway not registered", equipmentName, equipmentId);
|
||||||
equipmentId);
|
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
try {
|
try {
|
||||||
LOG.debug("Deregistering customer equipment (name={},id={}) with route id={}", equipmentName, equipmentId,
|
LOG.debug("Deregistering customer equipment (name={},id={}) with route id={}", equipmentName, equipmentId, routingId);
|
||||||
routingId);
|
|
||||||
|
|
||||||
eqRoutingSvc.delete(routingId);
|
eqRoutingSvc.delete(routingId);
|
||||||
} catch (Exception e) {
|
} catch (Exception e) {
|
||||||
LOG.error("Failed to deregister customer equipement (name={},id={}) with route id={}: {}", equipmentName,
|
LOG.error("Failed to deregister customer equipement (name={},id={}) with route id={}: {}", equipmentName, equipmentId, routingId,
|
||||||
equipmentId, routingId, e.getLocalizedMessage());
|
e.getLocalizedMessage());
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|||||||
@@ -6,6 +6,7 @@ import java.net.Inet6Address;
|
|||||||
import java.net.InetAddress;
|
import java.net.InetAddress;
|
||||||
import java.net.UnknownHostException;
|
import java.net.UnknownHostException;
|
||||||
import java.util.ArrayList;
|
import java.util.ArrayList;
|
||||||
|
import java.util.Collections;
|
||||||
import java.util.Date;
|
import java.util.Date;
|
||||||
import java.util.HashMap;
|
import java.util.HashMap;
|
||||||
import java.util.HashSet;
|
import java.util.HashSet;
|
||||||
@@ -16,6 +17,7 @@ import java.util.Set;
|
|||||||
import org.slf4j.Logger;
|
import org.slf4j.Logger;
|
||||||
import org.slf4j.LoggerFactory;
|
import org.slf4j.LoggerFactory;
|
||||||
import org.springframework.beans.factory.annotation.Autowired;
|
import org.springframework.beans.factory.annotation.Autowired;
|
||||||
|
import org.springframework.beans.factory.annotation.Value;
|
||||||
import org.springframework.stereotype.Component;
|
import org.springframework.stereotype.Component;
|
||||||
|
|
||||||
import com.google.protobuf.ByteString;
|
import com.google.protobuf.ByteString;
|
||||||
@@ -23,6 +25,12 @@ import com.google.protobuf.Descriptors;
|
|||||||
import com.google.protobuf.InvalidProtocolBufferException;
|
import com.google.protobuf.InvalidProtocolBufferException;
|
||||||
import com.google.protobuf.util.JsonFormat;
|
import com.google.protobuf.util.JsonFormat;
|
||||||
import com.google.protobuf.util.JsonFormat.TypeRegistry;
|
import com.google.protobuf.util.JsonFormat.TypeRegistry;
|
||||||
|
import com.telecominfraproject.wlan.alarm.AlarmServiceInterface;
|
||||||
|
import com.telecominfraproject.wlan.alarm.models.Alarm;
|
||||||
|
import com.telecominfraproject.wlan.alarm.models.AlarmCode;
|
||||||
|
import com.telecominfraproject.wlan.alarm.models.AlarmDetails;
|
||||||
|
import com.telecominfraproject.wlan.alarm.models.AlarmScopeType;
|
||||||
|
import com.telecominfraproject.wlan.alarm.models.OriginatorType;
|
||||||
import com.telecominfraproject.wlan.client.ClientServiceInterface;
|
import com.telecominfraproject.wlan.client.ClientServiceInterface;
|
||||||
import com.telecominfraproject.wlan.client.info.models.ClientInfoDetails;
|
import com.telecominfraproject.wlan.client.info.models.ClientInfoDetails;
|
||||||
import com.telecominfraproject.wlan.client.session.models.AssociationState;
|
import com.telecominfraproject.wlan.client.session.models.AssociationState;
|
||||||
@@ -68,6 +76,7 @@ import com.telecominfraproject.wlan.servicemetric.models.ServiceMetric;
|
|||||||
import com.telecominfraproject.wlan.servicemetric.neighbourscan.models.NeighbourReport;
|
import com.telecominfraproject.wlan.servicemetric.neighbourscan.models.NeighbourReport;
|
||||||
import com.telecominfraproject.wlan.servicemetric.neighbourscan.models.NeighbourScanReports;
|
import com.telecominfraproject.wlan.servicemetric.neighbourscan.models.NeighbourScanReports;
|
||||||
import com.telecominfraproject.wlan.status.StatusServiceInterface;
|
import com.telecominfraproject.wlan.status.StatusServiceInterface;
|
||||||
|
import com.telecominfraproject.wlan.status.equipment.models.EquipmentAdminStatusData;
|
||||||
import com.telecominfraproject.wlan.status.equipment.report.models.ActiveBSSID;
|
import com.telecominfraproject.wlan.status.equipment.report.models.ActiveBSSID;
|
||||||
import com.telecominfraproject.wlan.status.equipment.report.models.ActiveBSSIDs;
|
import com.telecominfraproject.wlan.status.equipment.report.models.ActiveBSSIDs;
|
||||||
import com.telecominfraproject.wlan.status.equipment.report.models.EquipmentCapacityDetails;
|
import com.telecominfraproject.wlan.status.equipment.report.models.EquipmentCapacityDetails;
|
||||||
@@ -133,43 +142,17 @@ public class MqttStatsPublisher {
|
|||||||
private CloudEventDispatcherInterface cloudEventDispatcherInterface;
|
private CloudEventDispatcherInterface cloudEventDispatcherInterface;
|
||||||
@Autowired
|
@Autowired
|
||||||
private RealtimeEventPublisher realtimeEventPublisher;
|
private RealtimeEventPublisher realtimeEventPublisher;
|
||||||
|
@Autowired
|
||||||
|
private AlarmServiceInterface alarmServiceInterface;
|
||||||
|
|
||||||
public void processMqttMessage(String topic, WCStatsReport wcStatsReport) {
|
@Value("${tip.wlan.mqttStatsPublisher.temperatureThresholdInC:80}")
|
||||||
LOG.info("Received WCStatsReport {}", wcStatsReport.toString());
|
private int temperatureThresholdInC;
|
||||||
|
|
||||||
LOG.debug("Received report on topic {}", topic);
|
@Value("${tip.wlan.mqttStatsPublisher.cpuUtilThresholdPct:80}")
|
||||||
int customerId = extractCustomerIdFromTopic(topic);
|
private int cpuUtilThresholdPct;
|
||||||
|
|
||||||
long equipmentId = extractEquipmentIdFromTopic(topic);
|
@Value("${tip.wlan.mqttStatsPublisher.memoryUtilThresholdPct:70}")
|
||||||
if ((equipmentId <= 0) || (customerId <= 0)) {
|
private int memoryUtilThresholdPct;
|
||||||
LOG.warn("Cannot determine equipment ids from topic {} - customerId {} equipmentId {}", topic, customerId, equipmentId);
|
|
||||||
return;
|
|
||||||
}
|
|
||||||
|
|
||||||
String apId = extractApIdFromTopic(topic);
|
|
||||||
|
|
||||||
if (apId == null) {
|
|
||||||
LOG.warn("Cannot determine AP id from topic {} - customerId {} equipmentId {} apId {}", topic, customerId, equipmentId, apId);
|
|
||||||
return;
|
|
||||||
}
|
|
||||||
|
|
||||||
if (LOG.isTraceEnabled()) {
|
|
||||||
// prepare a JSONPrinter to format protobuf messages as
|
|
||||||
// json
|
|
||||||
List<Descriptors.Descriptor> protobufDescriptors = new ArrayList<>();
|
|
||||||
protobufDescriptors.addAll(IpDnsTelemetry.getDescriptor().getMessageTypes());
|
|
||||||
TypeRegistry oldRegistry = TypeRegistry.newBuilder().add(protobufDescriptors).build();
|
|
||||||
JsonFormat.Printer jsonPrinter = JsonFormat.printer().preservingProtoFieldNames().includingDefaultValueFields().usingTypeRegistry(oldRegistry);
|
|
||||||
|
|
||||||
try {
|
|
||||||
LOG.trace("MQTT IpDnsTelemetry.wcStatsReport = {}", jsonPrinter.print(wcStatsReport));
|
|
||||||
|
|
||||||
} catch (InvalidProtocolBufferException e1) {
|
|
||||||
LOG.error("Couldn't parse IpDnsTelemetry.wcStatsReport.", e1);
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
}
|
|
||||||
|
|
||||||
public void processMqttMessage(String topic, Report report) {
|
public void processMqttMessage(String topic, Report report) {
|
||||||
LOG.info("Received report on topic {} for ap {}", topic, report.getNodeID());
|
LOG.info("Received report on topic {} for ap {}", topic, report.getNodeID());
|
||||||
@@ -180,9 +163,6 @@ public class MqttStatsPublisher {
|
|||||||
LOG.warn("Cannot determine equipment ids from topic {} - customerId {} equipmentId {}", topic, customerId, equipmentId);
|
LOG.warn("Cannot determine equipment ids from topic {} - customerId {} equipmentId {}", topic, customerId, equipmentId);
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
|
|
||||||
// gatewayController.updateActiveCustomer(customerId);
|
|
||||||
|
|
||||||
Equipment ce = equipmentServiceInterface.getOrNull(equipmentId);
|
Equipment ce = equipmentServiceInterface.getOrNull(equipmentId);
|
||||||
if (ce == null) {
|
if (ce == null) {
|
||||||
LOG.warn("Cannot read equipment {}", apId);
|
LOG.warn("Cannot read equipment {}", apId);
|
||||||
@@ -192,21 +172,6 @@ public class MqttStatsPublisher {
|
|||||||
long locationId = ce.getLocationId();
|
long locationId = ce.getLocationId();
|
||||||
long profileId = ce.getProfileId();
|
long profileId = ce.getProfileId();
|
||||||
|
|
||||||
// prepare a JSONPrinter to format protobuf messages as
|
|
||||||
// json
|
|
||||||
// List<Descriptors.Descriptor> protobufDescriptors = new ArrayList<>();
|
|
||||||
// protobufDescriptors.addAll(OpensyncStats.getDescriptor().getMessageTypes());
|
|
||||||
// TypeRegistry oldRegistry = TypeRegistry.newBuilder().add(protobufDescriptors).build();
|
|
||||||
// JsonFormat.Printer jsonPrinter =
|
|
||||||
// JsonFormat.printer().preservingProtoFieldNames().includingDefaultValueFields().usingTypeRegistry(oldRegistry);
|
|
||||||
//
|
|
||||||
// try {
|
|
||||||
// LOG.trace(jsonPrinter.print(report));
|
|
||||||
//
|
|
||||||
// } catch (InvalidProtocolBufferException e1) {
|
|
||||||
// LOG.error("Couldn't parse OpensyncStats.report.", e1);
|
|
||||||
// }
|
|
||||||
|
|
||||||
List<ServiceMetric> metricRecordList = new ArrayList<>();
|
List<ServiceMetric> metricRecordList = new ArrayList<>();
|
||||||
|
|
||||||
try {
|
try {
|
||||||
@@ -222,62 +187,25 @@ public class MqttStatsPublisher {
|
|||||||
LOG.debug("Current timestamp for service metrics is {}", serviceMetricTimestamp);
|
LOG.debug("Current timestamp for service metrics is {}", serviceMetricTimestamp);
|
||||||
metricRecordList.stream().forEach(smr -> {
|
metricRecordList.stream().forEach(smr -> {
|
||||||
smr.setCreatedTimestamp(serviceMetricTimestamp);
|
smr.setCreatedTimestamp(serviceMetricTimestamp);
|
||||||
if (smr.getLocationId() == 0) smr.setLocationId(locationId);
|
if (smr.getLocationId() == 0)
|
||||||
if(smr.getCustomerId() == 0) smr.setCustomerId(customerId);
|
smr.setLocationId(locationId);
|
||||||
if (smr.getEquipmentId() == 0L) smr.setEquipmentId(equipmentId);
|
if (smr.getCustomerId() == 0)
|
||||||
|
smr.setCustomerId(customerId);
|
||||||
|
if (smr.getEquipmentId() == 0L)
|
||||||
|
smr.setEquipmentId(equipmentId);
|
||||||
});
|
});
|
||||||
metricRecordList.stream().forEach(smr -> {
|
metricRecordList.stream().forEach(smr -> {
|
||||||
LOG.debug("ServiceMetric {}", smr);
|
LOG.debug("ServiceMetric {}", smr);
|
||||||
});
|
});
|
||||||
cloudEventDispatcherInterface.publishMetrics(metricRecordList);
|
cloudEventDispatcherInterface.publishMetrics(metricRecordList);
|
||||||
}
|
}
|
||||||
|
|
||||||
publishEvents(report, customerId, equipmentId, apId, locationId);
|
publishEvents(report, customerId, equipmentId, apId, locationId);
|
||||||
// handleRssiMetrics(metricRecordList, report, customerId,
|
|
||||||
// equipmentId, locationId);
|
|
||||||
|
|
||||||
} catch (Exception e) {
|
} catch (Exception e) {
|
||||||
LOG.error("Exception when processing stats messages from AP", e);
|
LOG.error("Exception when processing stats messages from AP", e);
|
||||||
}
|
}
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|
||||||
public void processMqttMessage(String topic, FlowReport flowReport) {
|
|
||||||
|
|
||||||
LOG.info("Received report on topic {}", topic);
|
|
||||||
int customerId = extractCustomerIdFromTopic(topic);
|
|
||||||
|
|
||||||
long equipmentId = extractEquipmentIdFromTopic(topic);
|
|
||||||
if ((equipmentId <= 0) || (customerId <= 0)) {
|
|
||||||
LOG.warn("Cannot determine equipment ids from topic {} - customerId {} equipmentId {}", topic, customerId, equipmentId);
|
|
||||||
return;
|
|
||||||
}
|
|
||||||
|
|
||||||
String apId = extractApIdFromTopic(topic);
|
|
||||||
|
|
||||||
if (apId == null) {
|
|
||||||
LOG.warn("Cannot determine AP id from topic {} - customerId {} equipmentId {} apId {}", topic, customerId, equipmentId, apId);
|
|
||||||
return;
|
|
||||||
}
|
|
||||||
|
|
||||||
if (LOG.isTraceEnabled()) {
|
|
||||||
// prepare a JSONPrinter to format protobuf messages as
|
|
||||||
// json
|
|
||||||
List<Descriptors.Descriptor> protobufDescriptors = new ArrayList<>();
|
|
||||||
protobufDescriptors.addAll(NetworkMetadata.getDescriptor().getMessageTypes());
|
|
||||||
TypeRegistry oldRegistry = TypeRegistry.newBuilder().add(protobufDescriptors).build();
|
|
||||||
JsonFormat.Printer jsonPrinter = JsonFormat.printer().preservingProtoFieldNames().includingDefaultValueFields().usingTypeRegistry(oldRegistry);
|
|
||||||
|
|
||||||
try {
|
|
||||||
LOG.trace("MQTT NetworkMetadata.flowReport = {}", jsonPrinter.print(flowReport));
|
|
||||||
|
|
||||||
} catch (InvalidProtocolBufferException e1) {
|
|
||||||
LOG.error("Couldn't parse NetworkMetadata.flowReport.", e1);
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
}
|
|
||||||
|
|
||||||
public void publishSystemEventFromTableStateMonitor(SystemEvent event) {
|
public void publishSystemEventFromTableStateMonitor(SystemEvent event) {
|
||||||
LOG.info("Publishing SystemEvent received by TableStateMonitor {}", event);
|
LOG.info("Publishing SystemEvent received by TableStateMonitor {}", event);
|
||||||
cloudEventDispatcherInterface.publishEvent(event);
|
cloudEventDispatcherInterface.publishEvent(event);
|
||||||
@@ -938,22 +866,43 @@ public class MqttStatsPublisher {
|
|||||||
numSamples++;
|
numSamples++;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
if (numSamples > 0) {
|
if (numSamples > 0) {
|
||||||
avgRadioTemp = Math.round((cpuTemperature / numSamples));
|
avgRadioTemp = Math.round((cpuTemperature / numSamples));
|
||||||
apPerformance.setCpuTemperature(avgRadioTemp);
|
apPerformance.setCpuTemperature(avgRadioTemp);
|
||||||
}
|
}
|
||||||
|
if (avgRadioTemp > temperatureThresholdInC) {
|
||||||
|
raiseDeviceThresholdAlarm(customerId, equipmentId, AlarmCode.CPUTemperature, deviceReport.getTimestampMs());
|
||||||
|
} else {
|
||||||
|
// Clear any existing temperature alarms for this ap
|
||||||
|
clearDeviceThresholdAlarm(customerId, equipmentId, AlarmCode.CPUTemperature);
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
if (deviceReport.hasCpuUtil() && deviceReport.getCpuUtil().hasCpuUtil()) {
|
if (deviceReport.hasCpuUtil() && deviceReport.getCpuUtil().hasCpuUtil()) {
|
||||||
Integer cpuUtilization = deviceReport.getCpuUtil().getCpuUtil();
|
Integer cpuUtilization = deviceReport.getCpuUtil().getCpuUtil();
|
||||||
apPerformance.setCpuUtilized(new int[] {cpuUtilization});
|
apPerformance.setCpuUtilized(new int[] {cpuUtilization});
|
||||||
|
if (cpuUtilization > cpuUtilThresholdPct) {
|
||||||
|
raiseDeviceThresholdAlarm(customerId, equipmentId, AlarmCode.CPUUtilization, deviceReport.getTimestampMs());
|
||||||
|
} else {
|
||||||
|
// Clear any existing cpuUtilization alarms
|
||||||
|
clearDeviceThresholdAlarm(customerId, equipmentId, AlarmCode.CPUUtilization);
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
apPerformance.setEthLinkState(EthernetLinkState.UP1000_FULL_DUPLEX);
|
apPerformance.setEthLinkState(EthernetLinkState.UP1000_FULL_DUPLEX);
|
||||||
|
|
||||||
if (deviceReport.hasMemUtil() && deviceReport.getMemUtil().hasMemTotal() && deviceReport.getMemUtil().hasMemUsed()) {
|
if (deviceReport.hasMemUtil() && deviceReport.getMemUtil().hasMemTotal() && deviceReport.getMemUtil().hasMemUsed()) {
|
||||||
apPerformance.setFreeMemory(deviceReport.getMemUtil().getMemTotal() - deviceReport.getMemUtil().getMemUsed());
|
apPerformance.setFreeMemory(deviceReport.getMemUtil().getMemTotal() - deviceReport.getMemUtil().getMemUsed());
|
||||||
|
|
||||||
|
double usedMemory = deviceReport.getMemUtil().getMemUsed();
|
||||||
|
double totalMemory = deviceReport.getMemUtil().getMemTotal();
|
||||||
|
if (usedMemory/totalMemory * 100 > memoryUtilThresholdPct) {
|
||||||
|
raiseDeviceThresholdAlarm(customerId, equipmentId, AlarmCode.MemoryUtilization, deviceReport.getTimestampMs());
|
||||||
|
} else {
|
||||||
|
// Clear any existing cpuUtilization alarms
|
||||||
|
clearDeviceThresholdAlarm(customerId, equipmentId, AlarmCode.MemoryUtilization);
|
||||||
|
}
|
||||||
|
|
||||||
}
|
}
|
||||||
apPerformance.setUpTime((long) deviceReport.getUptime());
|
apPerformance.setUpTime((long) deviceReport.getUptime());
|
||||||
|
|
||||||
@@ -964,9 +913,11 @@ public class MqttStatsPublisher {
|
|||||||
List<PerProcessUtilization> memPerProcess = new ArrayList<>();
|
List<PerProcessUtilization> memPerProcess = new ArrayList<>();
|
||||||
deviceReport.getPsMemUtilList().stream().forEach(c -> memPerProcess.add(new PerProcessUtilization(c.getPid(), c.getCmd(), c.getUtil())));
|
deviceReport.getPsMemUtilList().stream().forEach(c -> memPerProcess.add(new PerProcessUtilization(c.getPid(), c.getCmd(), c.getUtil())));
|
||||||
apPerformance.setPsMemUtil(memPerProcess);
|
apPerformance.setPsMemUtil(memPerProcess);
|
||||||
|
apPerformance.setSourceTimestampMs(deviceReport.getTimestampMs());
|
||||||
|
// The service metric report's sourceTimestamp will be the most recent timestamp from its contributing stats
|
||||||
|
if (apNodeMetrics.getSourceTimestampMs() < deviceReport.getTimestampMs())
|
||||||
|
apNodeMetrics.setSourceTimestampMs(deviceReport.getTimestampMs());
|
||||||
updateDeviceStatusForReport(customerId, equipmentId, deviceReport, avgRadioTemp);
|
updateDeviceStatusForReport(customerId, equipmentId, deviceReport, avgRadioTemp);
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|
||||||
// statusList.add(status);
|
// statusList.add(status);
|
||||||
@@ -1063,6 +1014,11 @@ public class MqttStatsPublisher {
|
|||||||
radioStats.setNumRxDataFrames(rxFrames);
|
radioStats.setNumRxDataFrames(rxFrames);
|
||||||
radioStats.setNumRxErr(rxErrors);
|
radioStats.setNumRxErr(rxErrors);
|
||||||
radioStats.setNumRxRetry(rxRetries);
|
radioStats.setNumRxRetry(rxRetries);
|
||||||
|
radioStats.setSourceTimestampMs(clReport.getTimestampMs());
|
||||||
|
|
||||||
|
// The service metric report's sourceTimestamp will be the most recent timestamp from its contributing stats
|
||||||
|
if (apNodeMetrics.getSourceTimestampMs() < clReport.getTimestampMs())
|
||||||
|
apNodeMetrics.setSourceTimestampMs(clReport.getTimestampMs());
|
||||||
|
|
||||||
apNodeMetrics.setRadioStats(radioType, radioStats);
|
apNodeMetrics.setRadioStats(radioType, radioStats);
|
||||||
|
|
||||||
@@ -1123,6 +1079,13 @@ public class MqttStatsPublisher {
|
|||||||
if (totalDurationMs > 0) {
|
if (totalDurationMs > 0) {
|
||||||
RadioUtilization radioUtil = new RadioUtilization();
|
RadioUtilization radioUtil = new RadioUtilization();
|
||||||
radioUtil.setTimestampSeconds((int) ((survey.getTimestampMs()) / 1000));
|
radioUtil.setTimestampSeconds((int) ((survey.getTimestampMs()) / 1000));
|
||||||
|
radioUtil.setSourceTimestampMs(survey.getTimestampMs());
|
||||||
|
|
||||||
|
// The service metric report's sourceTimestamp will be the most recent timestamp from its
|
||||||
|
// contributing stats
|
||||||
|
if (apNodeMetrics.getSourceTimestampMs() < survey.getTimestampMs())
|
||||||
|
apNodeMetrics.setSourceTimestampMs(survey.getTimestampMs());
|
||||||
|
|
||||||
int pctBusyTx = busyTx / totalDurationMs;
|
int pctBusyTx = busyTx / totalDurationMs;
|
||||||
checkIfOutOfBound("pctBusyTx", pctBusyTx, survey, totalDurationMs, busyTx, busyRx, busy, busySelf);
|
checkIfOutOfBound("pctBusyTx", pctBusyTx, survey, totalDurationMs, busyTx, busyRx, busy, busySelf);
|
||||||
|
|
||||||
@@ -1137,6 +1100,10 @@ public class MqttStatsPublisher {
|
|||||||
checkIfOutOfBound("nonWifi", nonWifi, survey, totalDurationMs, busyTx, busyRx, busy, busySelf);
|
checkIfOutOfBound("nonWifi", nonWifi, survey, totalDurationMs, busyTx, busyRx, busy, busySelf);
|
||||||
radioUtil.setNonWifi(nonWifi);
|
radioUtil.setNonWifi(nonWifi);
|
||||||
|
|
||||||
|
int pctOBSSAndSelfErrors = (busyRx - busySelf) / totalDurationMs;
|
||||||
|
checkIfOutOfBound("OBSSAndSelfErrors", pctOBSSAndSelfErrors, survey, totalDurationMs, busyTx, busyRx, busy, busySelf);
|
||||||
|
radioUtil.setUnassocClientRx(pctOBSSAndSelfErrors);
|
||||||
|
|
||||||
radioType = OvsdbToWlanCloudTypeMappingUtility.getRadioTypeFromOpensyncStatsRadioBandType(survey.getBand());
|
radioType = OvsdbToWlanCloudTypeMappingUtility.getRadioTypeFromOpensyncStatsRadioBandType(survey.getBand());
|
||||||
if (radioType != RadioType.UNSUPPORTED) {
|
if (radioType != RadioType.UNSUPPORTED) {
|
||||||
if (apNodeMetrics.getRadioUtilization(radioType) == null) {
|
if (apNodeMetrics.getRadioUtilization(radioType) == null) {
|
||||||
@@ -1179,6 +1146,35 @@ public class MqttStatsPublisher {
|
|||||||
updateDeviceStatusRadioUtilizationReport(customerId, equipmentId, radioUtilizationReport);
|
updateDeviceStatusRadioUtilizationReport(customerId, equipmentId, radioUtilizationReport);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
void clearDeviceThresholdAlarm(int customerId, long equipmentId, AlarmCode alarmCode) {
|
||||||
|
alarmServiceInterface.get(customerId, Set.of(equipmentId), Set.of(alarmCode)).stream().forEach(a -> {
|
||||||
|
Alarm alarm = alarmServiceInterface.delete(customerId, equipmentId, a.getAlarmCode(), a.getCreatedTimestamp());
|
||||||
|
LOG.info("Cleared device threshold alarm {}", alarm);
|
||||||
|
});
|
||||||
|
}
|
||||||
|
|
||||||
|
void raiseDeviceThresholdAlarm(int customerId, long equipmentId, AlarmCode alarmCode, long timestampMs) {
|
||||||
|
// Raise an alarm for temperature
|
||||||
|
Alarm alarm = new Alarm();
|
||||||
|
alarm.setCustomerId(customerId);
|
||||||
|
alarm.setEquipmentId(equipmentId);
|
||||||
|
alarm.setAlarmCode(alarmCode);
|
||||||
|
alarm.setOriginatorType(OriginatorType.AP);
|
||||||
|
alarm.setSeverity(alarmCode.getSeverity());
|
||||||
|
alarm.setScopeType(AlarmScopeType.EQUIPMENT);
|
||||||
|
alarm.setScopeId("" + equipmentId);
|
||||||
|
alarm.setCreatedTimestamp(timestampMs);
|
||||||
|
AlarmDetails alarmDetails = new AlarmDetails();
|
||||||
|
alarmDetails.setMessage(alarmCode.getDescription());
|
||||||
|
alarmDetails.setAffectedEquipmentIds(Collections.singletonList(equipmentId));
|
||||||
|
alarm.setDetails(alarmDetails);
|
||||||
|
List<Alarm> alarms = alarmServiceInterface.get(customerId, Set.of(equipmentId), Set.of(alarmCode));
|
||||||
|
if (alarms.isEmpty()) {
|
||||||
|
alarm.setCreatedTimestamp(timestampMs);
|
||||||
|
alarm = alarmServiceInterface.create(alarm);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
private void checkIfOutOfBound(String checkedType, int checkedValue, Survey survey, int totalDurationMs, int busyTx, int busyRx, int busy, int busySelf) {
|
private void checkIfOutOfBound(String checkedType, int checkedValue, Survey survey, int totalDurationMs, int busyTx, int busyRx, int busy, int busySelf) {
|
||||||
if (checkedValue > 100 || checkedValue < 0) {
|
if (checkedValue > 100 || checkedValue < 0) {
|
||||||
LOG.warn(
|
LOG.warn(
|
||||||
@@ -1280,6 +1276,8 @@ public class MqttStatsPublisher {
|
|||||||
|
|
||||||
NetworkProbeMetrics networkProbeMetrics = new NetworkProbeMetrics();
|
NetworkProbeMetrics networkProbeMetrics = new NetworkProbeMetrics();
|
||||||
|
|
||||||
|
networkProbeMetrics.setSourceTimestampMs(networkProbe.getTimestampMs());
|
||||||
|
|
||||||
List<DnsProbeMetric> dnsProbeResults = new ArrayList<>();
|
List<DnsProbeMetric> dnsProbeResults = new ArrayList<>();
|
||||||
if (networkProbe.hasDnsProbe()) {
|
if (networkProbe.hasDnsProbe()) {
|
||||||
|
|
||||||
@@ -1371,6 +1369,8 @@ public class MqttStatsPublisher {
|
|||||||
LOG.debug("updated status {}", status);
|
LOG.debug("updated status {}", status);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
void populateApClientMetrics(List<ServiceMetric> metricRecordList, Report report, int customerId, long equipmentId, long locationId) {
|
void populateApClientMetrics(List<ServiceMetric> metricRecordList, Report report, int customerId, long equipmentId, long locationId) {
|
||||||
LOG.info("populateApClientMetrics for Customer {} Equipment {}", customerId, equipmentId);
|
LOG.info("populateApClientMetrics for Customer {} Equipment {}", customerId, equipmentId);
|
||||||
|
|
||||||
@@ -1393,6 +1393,7 @@ public class MqttStatsPublisher {
|
|||||||
// clReport.getChannel();
|
// clReport.getChannel();
|
||||||
ClientMetrics cMetrics = new ClientMetrics();
|
ClientMetrics cMetrics = new ClientMetrics();
|
||||||
smr.setDetails(cMetrics);
|
smr.setDetails(cMetrics);
|
||||||
|
cMetrics.setSourceTimestampMs(clReport.getTimestampMs());
|
||||||
|
|
||||||
Integer periodLengthSec = 60; // matches what's configured by
|
Integer periodLengthSec = 60; // matches what's configured by
|
||||||
// OvsdbDao.configureStats(OvsdbClient)
|
// OvsdbDao.configureStats(OvsdbClient)
|
||||||
@@ -1451,7 +1452,7 @@ public class MqttStatsPublisher {
|
|||||||
cMetrics.setNumTxDropped((int) cl.getStats().getTxErrors());
|
cMetrics.setNumTxDropped((int) cl.getStats().getTxErrors());
|
||||||
}
|
}
|
||||||
|
|
||||||
if (cl.getStats().hasRxFrames()) {
|
if (cl.getStats().hasTxFrames()) {
|
||||||
cMetrics.setNumTxFramesTransmitted(cl.getStats().getTxFrames());
|
cMetrics.setNumTxFramesTransmitted(cl.getStats().getTxFrames());
|
||||||
}
|
}
|
||||||
|
|
||||||
@@ -1475,10 +1476,10 @@ public class MqttStatsPublisher {
|
|||||||
|
|
||||||
ServiceMetric smr = new ServiceMetric(customerId, equipmentId);
|
ServiceMetric smr = new ServiceMetric(customerId, equipmentId);
|
||||||
smr.setLocationId(locationId);
|
smr.setLocationId(locationId);
|
||||||
|
|
||||||
metricRecordList.add(smr);
|
metricRecordList.add(smr);
|
||||||
NeighbourScanReports neighbourScanReports = new NeighbourScanReports();
|
NeighbourScanReports neighbourScanReports = new NeighbourScanReports();
|
||||||
smr.setDetails(neighbourScanReports);
|
smr.setDetails(neighbourScanReports);
|
||||||
|
neighbourScanReports.setSourceTimestampMs(neighbor.getTimestampMs());
|
||||||
|
|
||||||
List<NeighbourReport> neighbourReports = new ArrayList<>();
|
List<NeighbourReport> neighbourReports = new ArrayList<>();
|
||||||
neighbourScanReports.setNeighbourReports(neighbourReports);
|
neighbourScanReports.setNeighbourReports(neighbourReports);
|
||||||
@@ -1594,7 +1595,7 @@ public class MqttStatsPublisher {
|
|||||||
|
|
||||||
float rxBytesFv = Long.valueOf(client.getStats().getRxBytes()).floatValue();
|
float rxBytesFv = Long.valueOf(client.getStats().getRxBytes()).floatValue();
|
||||||
float rxBytesToMb = rxBytesFv / 125000F;
|
float rxBytesToMb = rxBytesFv / 125000F;
|
||||||
float txBytesFv = Long.valueOf(client.getStats().getRxBytes()).floatValue();
|
float txBytesFv = Long.valueOf(client.getStats().getTxBytes()).floatValue();
|
||||||
float txBytesToMb = txBytesFv / 125000F;
|
float txBytesToMb = txBytesFv / 125000F;
|
||||||
|
|
||||||
if (LOG.isDebugEnabled())
|
if (LOG.isDebugEnabled())
|
||||||
@@ -1627,6 +1628,10 @@ public class MqttStatsPublisher {
|
|||||||
|
|
||||||
LOG.debug("ClientReport for channel {} RadioBand {}", clientReport.getChannel(), clientReport.getBand());
|
LOG.debug("ClientReport for channel {} RadioBand {}", clientReport.getChannel(), clientReport.getBand());
|
||||||
|
|
||||||
|
// The service metric report's sourceTimestamp will be the most recent ClientReport timestamp
|
||||||
|
if (apSsidMetrics.getSourceTimestampMs() < clientReport.getTimestampMs())
|
||||||
|
apSsidMetrics.setSourceTimestampMs(clientReport.getTimestampMs());
|
||||||
|
|
||||||
long txBytes = 0L;
|
long txBytes = 0L;
|
||||||
long rxBytes = 0L;
|
long rxBytes = 0L;
|
||||||
long txFrames = 0L;
|
long txFrames = 0L;
|
||||||
@@ -1647,7 +1652,7 @@ public class MqttStatsPublisher {
|
|||||||
|
|
||||||
SsidStatistics ssidStatistics = new SsidStatistics();
|
SsidStatistics ssidStatistics = new SsidStatistics();
|
||||||
// GET the Radio IF MAC (BSSID) from the activeBSSIDs
|
// GET the Radio IF MAC (BSSID) from the activeBSSIDs
|
||||||
|
ssidStatistics.setSourceTimestampMs(clientReport.getTimestampMs());
|
||||||
Status activeBssidsStatus = statusServiceInterface.getOrNull(customerId, equipmentId, StatusDataType.ACTIVE_BSSIDS);
|
Status activeBssidsStatus = statusServiceInterface.getOrNull(customerId, equipmentId, StatusDataType.ACTIVE_BSSIDS);
|
||||||
if (activeBssidsStatus != null && activeBssidsStatus.getDetails() != null
|
if (activeBssidsStatus != null && activeBssidsStatus.getDetails() != null
|
||||||
&& ((ActiveBSSIDs) activeBssidsStatus.getDetails()).getActiveBSSIDs() != null) {
|
&& ((ActiveBSSIDs) activeBssidsStatus.getDetails()).getActiveBSSIDs() != null) {
|
||||||
@@ -1675,58 +1680,17 @@ public class MqttStatsPublisher {
|
|||||||
|
|
||||||
rxBytes += client.getStats().getRxBytes();
|
rxBytes += client.getStats().getRxBytes();
|
||||||
txBytes += client.getStats().getTxBytes();
|
txBytes += client.getStats().getTxBytes();
|
||||||
txFrames += client.getStats().getRxFrames();
|
rxFrames += client.getStats().getRxFrames();
|
||||||
rxFrames += client.getStats().getTxFrames();
|
txFrames += client.getStats().getTxFrames();
|
||||||
rxRetries += client.getStats().getRxRetries();
|
rxRetries += client.getStats().getRxRetries();
|
||||||
txRetries += client.getStats().getTxRetries();
|
txRetries += client.getStats().getTxRetries();
|
||||||
rxErrors += client.getStats().getRxErrors();
|
rxErrors += client.getStats().getRxErrors();
|
||||||
txErrors += client.getStats().getTxErrors();
|
txErrors += client.getStats().getTxErrors();
|
||||||
lastRssi = client.getStats().getRssi();
|
lastRssi = client.getStats().getRssi();
|
||||||
|
|
||||||
try {
|
if (client.hasConnected() && client.getConnected() && client.hasMacAddress()) {
|
||||||
|
numConnectedClients += 1;
|
||||||
if (client.hasConnected() && client.getConnected() && client.hasMacAddress()) {
|
|
||||||
// update service_metrics_collection_config for
|
|
||||||
// connected client
|
|
||||||
ClientSession session =
|
|
||||||
handleClientSessionMetricsUpdate(customerId, equipmentId, locationId, radioType, clientReport.getTimestampMs(), client);
|
|
||||||
if (session != null) {
|
|
||||||
numConnectedClients += 1;
|
|
||||||
}
|
|
||||||
} else {
|
|
||||||
// Make sure, if we have a session for this client,
|
|
||||||
// it
|
|
||||||
// shows disconnected.
|
|
||||||
// update any service_metrics_collection_config that
|
|
||||||
// need update if the
|
|
||||||
// disconnect occured during this window
|
|
||||||
if (client.hasMacAddress()) {
|
|
||||||
ClientSession session =
|
|
||||||
clientServiceInterface.getSessionOrNull(customerId, equipmentId, MacAddress.valueOf(client.getMacAddress()));
|
|
||||||
|
|
||||||
if (session != null) {
|
|
||||||
|
|
||||||
ClientSessionDetails latestSessionDetails = new ClientSessionDetails();
|
|
||||||
|
|
||||||
// could still be values from before
|
|
||||||
// disconnect occured.
|
|
||||||
latestSessionDetails.setMetricDetails(calculateClientSessionMetricDetails(client, clientReport.getTimestampMs()));
|
|
||||||
|
|
||||||
session.getDetails().mergeSession(latestSessionDetails);
|
|
||||||
|
|
||||||
clientServiceInterface.updateSession(session);
|
|
||||||
|
|
||||||
}
|
|
||||||
|
|
||||||
}
|
|
||||||
|
|
||||||
continue; // not connected
|
|
||||||
}
|
|
||||||
|
|
||||||
} catch (Exception e) {
|
|
||||||
LOG.error("Unabled to update client {}", client, e);
|
|
||||||
}
|
}
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|
||||||
}
|
}
|
||||||
@@ -1814,8 +1778,9 @@ public class MqttStatsPublisher {
|
|||||||
smr.setCustomerId(customerId);
|
smr.setCustomerId(customerId);
|
||||||
smr.setEquipmentId(equipmentId);
|
smr.setEquipmentId(equipmentId);
|
||||||
smr.setLocationId(locationId);
|
smr.setLocationId(locationId);
|
||||||
|
|
||||||
ChannelInfoReports channelInfoReports = new ChannelInfoReports();
|
ChannelInfoReports channelInfoReports = new ChannelInfoReports();
|
||||||
|
channelInfoReports.setSourceTimestampMs(survey.getTimestampMs());
|
||||||
|
|
||||||
Map<RadioType, List<ChannelInfo>> channelInfoMap = channelInfoReports.getChannelInformationReportsPerRadio();
|
Map<RadioType, List<ChannelInfo>> channelInfoMap = channelInfoReports.getChannelInformationReportsPerRadio();
|
||||||
|
|
||||||
RadioType radioType = null;
|
RadioType radioType = null;
|
||||||
|
|||||||
@@ -170,10 +170,12 @@ public class OpensyncExternalIntegrationCloudTest {
|
|||||||
Location location = new Location();
|
Location location = new Location();
|
||||||
location.setId(8L);
|
location.setId(8L);
|
||||||
location.setCustomerId(2);
|
location.setCustomerId(2);
|
||||||
location.setDetails(LocationDetails.createWithDefaults());
|
LocationDetails details = LocationDetails.createWithDefaults();
|
||||||
|
details.setCountryCode(CountryCode.CA);
|
||||||
|
location.setDetails(details);
|
||||||
location.setName("Location-UT");
|
location.setName("Location-UT");
|
||||||
location.setLocationType(LocationType.BUILDING);
|
location.setLocationType(LocationType.BUILDING);
|
||||||
|
Mockito.when(locationServiceInterface.get(8L)).thenReturn(location);
|
||||||
Customer customer = new Customer();
|
Customer customer = new Customer();
|
||||||
customer.setId(2);
|
customer.setId(2);
|
||||||
CustomerDetails customerDetails = new CustomerDetails();
|
CustomerDetails customerDetails = new CustomerDetails();
|
||||||
@@ -239,7 +241,7 @@ public class OpensyncExternalIntegrationCloudTest {
|
|||||||
|
|
||||||
|
|
||||||
Mockito.verify(firmwareServiceInterface).getDefaultCustomerTrackSetting();
|
Mockito.verify(firmwareServiceInterface).getDefaultCustomerTrackSetting();
|
||||||
Mockito.verifyNoInteractions(locationServiceInterface);
|
Mockito.verify(locationServiceInterface).get(8L);
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|
||||||
@@ -248,10 +250,11 @@ public class OpensyncExternalIntegrationCloudTest {
|
|||||||
Location location = new Location();
|
Location location = new Location();
|
||||||
location.setId(8L);
|
location.setId(8L);
|
||||||
location.setCustomerId(2);
|
location.setCustomerId(2);
|
||||||
location.setDetails(LocationDetails.createWithDefaults());
|
LocationDetails details = LocationDetails.createWithDefaults();
|
||||||
|
details.setCountryCode(CountryCode.CA);
|
||||||
|
location.setDetails(details);
|
||||||
location.setName("Location-UT");
|
location.setName("Location-UT");
|
||||||
location.setLocationType(LocationType.BUILDING);
|
location.setLocationType(LocationType.BUILDING);
|
||||||
|
|
||||||
Mockito.when(locationServiceInterface.get(8L)).thenReturn(location);
|
Mockito.when(locationServiceInterface.get(8L)).thenReturn(location);
|
||||||
|
|
||||||
Customer customer = new Customer();
|
Customer customer = new Customer();
|
||||||
@@ -339,7 +342,7 @@ public class OpensyncExternalIntegrationCloudTest {
|
|||||||
Mockito.verify(customerServiceInterface).getOrNull(ArgumentMatchers.anyInt());
|
Mockito.verify(customerServiceInterface).getOrNull(ArgumentMatchers.anyInt());
|
||||||
Mockito.verify(equipmentServiceInterface).getByInventoryIdOrNull("Test_Client_21P10C68818122");
|
Mockito.verify(equipmentServiceInterface).getByInventoryIdOrNull("Test_Client_21P10C68818122");
|
||||||
Mockito.verify(firmwareServiceInterface).getDefaultCustomerTrackSetting();
|
Mockito.verify(firmwareServiceInterface).getDefaultCustomerTrackSetting();
|
||||||
Mockito.verify(locationServiceInterface).get(ArgumentMatchers.anyLong());
|
Mockito.verify(locationServiceInterface, Mockito.times(2)).get(ArgumentMatchers.anyLong());
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|
||||||
@@ -361,9 +364,12 @@ public class OpensyncExternalIntegrationCloudTest {
|
|||||||
Location location = new Location();
|
Location location = new Location();
|
||||||
location.setId(8L);
|
location.setId(8L);
|
||||||
location.setCustomerId(2);
|
location.setCustomerId(2);
|
||||||
location.setDetails(LocationDetails.createWithDefaults());
|
LocationDetails details = LocationDetails.createWithDefaults();
|
||||||
|
details.setCountryCode(CountryCode.CA);
|
||||||
|
location.setDetails(details);
|
||||||
location.setName("Location-UT");
|
location.setName("Location-UT");
|
||||||
location.setLocationType(LocationType.BUILDING);
|
location.setLocationType(LocationType.BUILDING);
|
||||||
|
Mockito.when(locationServiceInterface.get(8L)).thenReturn(location);
|
||||||
|
|
||||||
Equipment equipment = new Equipment();
|
Equipment equipment = new Equipment();
|
||||||
equipment.setCustomerId(2);
|
equipment.setCustomerId(2);
|
||||||
|
|||||||
@@ -3,7 +3,7 @@
|
|||||||
<parent>
|
<parent>
|
||||||
<groupId>com.telecominfraproject.wlan</groupId>
|
<groupId>com.telecominfraproject.wlan</groupId>
|
||||||
<artifactId>tip-wlan-cloud-root-pom</artifactId>
|
<artifactId>tip-wlan-cloud-root-pom</artifactId>
|
||||||
<version>1.1.0-SNAPSHOT</version>
|
<version>1.2.0-SNAPSHOT</version>
|
||||||
<relativePath>../../wlan-cloud-root</relativePath>
|
<relativePath>../../wlan-cloud-root</relativePath>
|
||||||
</parent>
|
</parent>
|
||||||
<artifactId>opensync-ext-interface</artifactId>
|
<artifactId>opensync-ext-interface</artifactId>
|
||||||
@@ -13,33 +13,33 @@
|
|||||||
<dependency>
|
<dependency>
|
||||||
<groupId>com.telecominfraproject.wlan</groupId>
|
<groupId>com.telecominfraproject.wlan</groupId>
|
||||||
<artifactId>base-models</artifactId>
|
<artifactId>base-models</artifactId>
|
||||||
<version>1.1.0-SNAPSHOT</version>
|
<version>1.2.0-SNAPSHOT</version>
|
||||||
</dependency>
|
</dependency>
|
||||||
<dependency>
|
<dependency>
|
||||||
<groupId>com.telecominfraproject.wlan</groupId>
|
<groupId>com.telecominfraproject.wlan</groupId>
|
||||||
<artifactId>tip-wlan-opensync-protobuf</artifactId>
|
<artifactId>tip-wlan-opensync-protobuf</artifactId>
|
||||||
<version>1.1.0-SNAPSHOT</version>
|
<version>1.2.0-SNAPSHOT</version>
|
||||||
</dependency>
|
</dependency>
|
||||||
|
|
||||||
<dependency>
|
<dependency>
|
||||||
<artifactId>equipment-models</artifactId>
|
<artifactId>equipment-models</artifactId>
|
||||||
<groupId>com.telecominfraproject.wlan</groupId>
|
<groupId>com.telecominfraproject.wlan</groupId>
|
||||||
<version>1.1.0-SNAPSHOT</version>
|
<version>1.2.0-SNAPSHOT</version>
|
||||||
</dependency>
|
</dependency>
|
||||||
<dependency>
|
<dependency>
|
||||||
<artifactId>profile-models</artifactId>
|
<artifactId>profile-models</artifactId>
|
||||||
<groupId>com.telecominfraproject.wlan</groupId>
|
<groupId>com.telecominfraproject.wlan</groupId>
|
||||||
<version>1.1.0-SNAPSHOT</version>
|
<version>1.2.0-SNAPSHOT</version>
|
||||||
</dependency>
|
</dependency>
|
||||||
<dependency>
|
<dependency>
|
||||||
<artifactId>location-models</artifactId>
|
<artifactId>location-models</artifactId>
|
||||||
<groupId>com.telecominfraproject.wlan</groupId>
|
<groupId>com.telecominfraproject.wlan</groupId>
|
||||||
<version>1.1.0-SNAPSHOT</version>
|
<version>1.2.0-SNAPSHOT</version>
|
||||||
</dependency>
|
</dependency>
|
||||||
<dependency>
|
<dependency>
|
||||||
<artifactId>routing-models</artifactId>
|
<artifactId>routing-models</artifactId>
|
||||||
<groupId>com.telecominfraproject.wlan</groupId>
|
<groupId>com.telecominfraproject.wlan</groupId>
|
||||||
<version>1.1.0-SNAPSHOT</version>
|
<version>1.2.0-SNAPSHOT</version>
|
||||||
</dependency>
|
</dependency>
|
||||||
|
|
||||||
|
|
||||||
|
|||||||
@@ -38,10 +38,6 @@ public interface OpensyncExternalIntegrationInterface {
|
|||||||
|
|
||||||
void processMqttMessage(String topic, Report report);
|
void processMqttMessage(String topic, Report report);
|
||||||
|
|
||||||
void processMqttMessage(String topic, FlowReport flowReport);
|
|
||||||
|
|
||||||
void processMqttMessage(String topic, WCStatsReport wcStatsReport);
|
|
||||||
|
|
||||||
void wifiAssociatedClientsDbTableUpdate(List<OpensyncWifiAssociatedClients> wifiAssociatedClients, String apId);
|
void wifiAssociatedClientsDbTableUpdate(List<OpensyncWifiAssociatedClients> wifiAssociatedClients, String apId);
|
||||||
|
|
||||||
void wifiAssociatedClientsDbTableDelete(String deletedClientMac, String apId);
|
void wifiAssociatedClientsDbTableDelete(String deletedClientMac, String apId);
|
||||||
|
|||||||
@@ -17,6 +17,8 @@ public interface OvsdbClientInterface {
|
|||||||
String startDebugEngine(String apId, String gatewayHostname, Integer gatewayPort);
|
String startDebugEngine(String apId, String gatewayHostname, Integer gatewayPort);
|
||||||
|
|
||||||
String stopDebugEngine(String apId);
|
String stopDebugEngine(String apId);
|
||||||
|
|
||||||
|
String processBlinkRequest(String apId, boolean blinkAllLEDs);
|
||||||
|
|
||||||
void processConfigChanged(String apId);
|
void processConfigChanged(String apId);
|
||||||
|
|
||||||
|
|||||||
@@ -3,7 +3,7 @@
|
|||||||
<parent>
|
<parent>
|
||||||
<groupId>com.telecominfraproject.wlan</groupId>
|
<groupId>com.telecominfraproject.wlan</groupId>
|
||||||
<artifactId>tip-wlan-cloud-root-pom</artifactId>
|
<artifactId>tip-wlan-cloud-root-pom</artifactId>
|
||||||
<version>1.1.0-SNAPSHOT</version>
|
<version>1.2.0-SNAPSHOT</version>
|
||||||
<relativePath>../../wlan-cloud-root</relativePath>
|
<relativePath>../../wlan-cloud-root</relativePath>
|
||||||
</parent>
|
</parent>
|
||||||
<artifactId>opensync-ext-static</artifactId>
|
<artifactId>opensync-ext-static</artifactId>
|
||||||
@@ -13,7 +13,7 @@
|
|||||||
<dependency>
|
<dependency>
|
||||||
<groupId>com.telecominfraproject.wlan</groupId>
|
<groupId>com.telecominfraproject.wlan</groupId>
|
||||||
<artifactId>opensync-gateway</artifactId>
|
<artifactId>opensync-gateway</artifactId>
|
||||||
<version>1.1.0-SNAPSHOT</version>
|
<version>1.2.0-SNAPSHOT</version>
|
||||||
</dependency>
|
</dependency>
|
||||||
</dependencies>
|
</dependencies>
|
||||||
</project>
|
</project>
|
||||||
|
|||||||
@@ -3,7 +3,7 @@
|
|||||||
<parent>
|
<parent>
|
||||||
<groupId>com.telecominfraproject.wlan</groupId>
|
<groupId>com.telecominfraproject.wlan</groupId>
|
||||||
<artifactId>tip-wlan-cloud-root-pom</artifactId>
|
<artifactId>tip-wlan-cloud-root-pom</artifactId>
|
||||||
<version>1.1.0-SNAPSHOT</version>
|
<version>1.2.0-SNAPSHOT</version>
|
||||||
<relativePath>../../wlan-cloud-root</relativePath>
|
<relativePath>../../wlan-cloud-root</relativePath>
|
||||||
</parent>
|
</parent>
|
||||||
<artifactId>opensync-gateway-build</artifactId>
|
<artifactId>opensync-gateway-build</artifactId>
|
||||||
|
|||||||
@@ -3,7 +3,7 @@
|
|||||||
<parent>
|
<parent>
|
||||||
<groupId>com.telecominfraproject.wlan</groupId>
|
<groupId>com.telecominfraproject.wlan</groupId>
|
||||||
<artifactId>tip-wlan-cloud-root-pom</artifactId>
|
<artifactId>tip-wlan-cloud-root-pom</artifactId>
|
||||||
<version>1.1.0-SNAPSHOT</version>
|
<version>1.2.0-SNAPSHOT</version>
|
||||||
<relativePath>../../wlan-cloud-root</relativePath>
|
<relativePath>../../wlan-cloud-root</relativePath>
|
||||||
</parent>
|
</parent>
|
||||||
<artifactId>opensync-gateway-cloud-docker</artifactId>
|
<artifactId>opensync-gateway-cloud-docker</artifactId>
|
||||||
@@ -22,7 +22,7 @@
|
|||||||
<dependency>
|
<dependency>
|
||||||
<groupId>com.telecominfraproject.wlan</groupId>
|
<groupId>com.telecominfraproject.wlan</groupId>
|
||||||
<artifactId>opensync-gateway-cloud-process</artifactId>
|
<artifactId>opensync-gateway-cloud-process</artifactId>
|
||||||
<version>1.1.0-SNAPSHOT</version>
|
<version>1.2.0-SNAPSHOT</version>
|
||||||
</dependency>
|
</dependency>
|
||||||
|
|
||||||
</dependencies>
|
</dependencies>
|
||||||
|
|||||||
@@ -3,7 +3,7 @@
|
|||||||
<parent>
|
<parent>
|
||||||
<groupId>com.telecominfraproject.wlan</groupId>
|
<groupId>com.telecominfraproject.wlan</groupId>
|
||||||
<artifactId>tip-wlan-cloud-root-pom</artifactId>
|
<artifactId>tip-wlan-cloud-root-pom</artifactId>
|
||||||
<version>1.1.0-SNAPSHOT</version>
|
<version>1.2.0-SNAPSHOT</version>
|
||||||
<relativePath>../../wlan-cloud-root</relativePath>
|
<relativePath>../../wlan-cloud-root</relativePath>
|
||||||
</parent>
|
</parent>
|
||||||
<artifactId>opensync-gateway-cloud-process</artifactId>
|
<artifactId>opensync-gateway-cloud-process</artifactId>
|
||||||
@@ -20,95 +20,95 @@
|
|||||||
<dependency>
|
<dependency>
|
||||||
<groupId>com.telecominfraproject.wlan</groupId>
|
<groupId>com.telecominfraproject.wlan</groupId>
|
||||||
<artifactId>opensync-ext-cloud</artifactId>
|
<artifactId>opensync-ext-cloud</artifactId>
|
||||||
<version>1.1.0-SNAPSHOT</version>
|
<version>1.2.0-SNAPSHOT</version>
|
||||||
</dependency>
|
</dependency>
|
||||||
<dependency>
|
<dependency>
|
||||||
<artifactId>filestore-service</artifactId>
|
<artifactId>filestore-service</artifactId>
|
||||||
<groupId>com.telecominfraproject.wlan</groupId>
|
<groupId>com.telecominfraproject.wlan</groupId>
|
||||||
<version>1.1.0-SNAPSHOT</version>
|
<version>1.2.0-SNAPSHOT</version>
|
||||||
</dependency>
|
</dependency>
|
||||||
<dependency>
|
<dependency>
|
||||||
<artifactId>customer-service-remote</artifactId>
|
<artifactId>customer-service-remote</artifactId>
|
||||||
<groupId>com.telecominfraproject.wlan</groupId>
|
<groupId>com.telecominfraproject.wlan</groupId>
|
||||||
<version>1.1.0-SNAPSHOT</version>
|
<version>1.2.0-SNAPSHOT</version>
|
||||||
</dependency>
|
</dependency>
|
||||||
|
|
||||||
<dependency>
|
<dependency>
|
||||||
<artifactId>location-service-remote</artifactId>
|
<artifactId>location-service-remote</artifactId>
|
||||||
<groupId>com.telecominfraproject.wlan</groupId>
|
<groupId>com.telecominfraproject.wlan</groupId>
|
||||||
<version>1.1.0-SNAPSHOT</version>
|
<version>1.2.0-SNAPSHOT</version>
|
||||||
</dependency>
|
</dependency>
|
||||||
|
|
||||||
<dependency>
|
<dependency>
|
||||||
<artifactId>equipment-service-remote</artifactId>
|
<artifactId>equipment-service-remote</artifactId>
|
||||||
<groupId>com.telecominfraproject.wlan</groupId>
|
<groupId>com.telecominfraproject.wlan</groupId>
|
||||||
<version>1.1.0-SNAPSHOT</version>
|
<version>1.2.0-SNAPSHOT</version>
|
||||||
</dependency>
|
</dependency>
|
||||||
|
|
||||||
<dependency>
|
<dependency>
|
||||||
<artifactId>profile-service-remote</artifactId>
|
<artifactId>profile-service-remote</artifactId>
|
||||||
<groupId>com.telecominfraproject.wlan</groupId>
|
<groupId>com.telecominfraproject.wlan</groupId>
|
||||||
<version>1.1.0-SNAPSHOT</version>
|
<version>1.2.0-SNAPSHOT</version>
|
||||||
</dependency>
|
</dependency>
|
||||||
|
|
||||||
<dependency>
|
<dependency>
|
||||||
<artifactId>portal-user-service-remote</artifactId>
|
<artifactId>portal-user-service-remote</artifactId>
|
||||||
<groupId>com.telecominfraproject.wlan</groupId>
|
<groupId>com.telecominfraproject.wlan</groupId>
|
||||||
<version>1.1.0-SNAPSHOT</version>
|
<version>1.2.0-SNAPSHOT</version>
|
||||||
</dependency>
|
</dependency>
|
||||||
|
|
||||||
<dependency>
|
<dependency>
|
||||||
<artifactId>service-metric-service-remote</artifactId>
|
<artifactId>service-metric-service-remote</artifactId>
|
||||||
<groupId>com.telecominfraproject.wlan</groupId>
|
<groupId>com.telecominfraproject.wlan</groupId>
|
||||||
<version>1.1.0-SNAPSHOT</version>
|
<version>1.2.0-SNAPSHOT</version>
|
||||||
</dependency>
|
</dependency>
|
||||||
|
|
||||||
<dependency>
|
<dependency>
|
||||||
<artifactId>system-event-service-remote</artifactId>
|
<artifactId>system-event-service-remote</artifactId>
|
||||||
<groupId>com.telecominfraproject.wlan</groupId>
|
<groupId>com.telecominfraproject.wlan</groupId>
|
||||||
<version>1.1.0-SNAPSHOT</version>
|
<version>1.2.0-SNAPSHOT</version>
|
||||||
</dependency>
|
</dependency>
|
||||||
|
|
||||||
<dependency>
|
<dependency>
|
||||||
<artifactId>alarm-service-remote</artifactId>
|
<artifactId>alarm-service-remote</artifactId>
|
||||||
<groupId>com.telecominfraproject.wlan</groupId>
|
<groupId>com.telecominfraproject.wlan</groupId>
|
||||||
<version>1.1.0-SNAPSHOT</version>
|
<version>1.2.0-SNAPSHOT</version>
|
||||||
</dependency>
|
</dependency>
|
||||||
|
|
||||||
<dependency>
|
<dependency>
|
||||||
<artifactId>status-service-remote</artifactId>
|
<artifactId>status-service-remote</artifactId>
|
||||||
<groupId>com.telecominfraproject.wlan</groupId>
|
<groupId>com.telecominfraproject.wlan</groupId>
|
||||||
<version>1.1.0-SNAPSHOT</version>
|
<version>1.2.0-SNAPSHOT</version>
|
||||||
</dependency>
|
</dependency>
|
||||||
|
|
||||||
<dependency>
|
<dependency>
|
||||||
<artifactId>client-service-remote</artifactId>
|
<artifactId>client-service-remote</artifactId>
|
||||||
<groupId>com.telecominfraproject.wlan</groupId>
|
<groupId>com.telecominfraproject.wlan</groupId>
|
||||||
<version>1.1.0-SNAPSHOT</version>
|
<version>1.2.0-SNAPSHOT</version>
|
||||||
</dependency>
|
</dependency>
|
||||||
|
|
||||||
<dependency>
|
<dependency>
|
||||||
<artifactId>routing-service-remote</artifactId>
|
<artifactId>routing-service-remote</artifactId>
|
||||||
<groupId>com.telecominfraproject.wlan</groupId>
|
<groupId>com.telecominfraproject.wlan</groupId>
|
||||||
<version>1.1.0-SNAPSHOT</version>
|
<version>1.2.0-SNAPSHOT</version>
|
||||||
</dependency>
|
</dependency>
|
||||||
|
|
||||||
<dependency>
|
<dependency>
|
||||||
<artifactId>firmware-service-remote</artifactId>
|
<artifactId>firmware-service-remote</artifactId>
|
||||||
<groupId>com.telecominfraproject.wlan</groupId>
|
<groupId>com.telecominfraproject.wlan</groupId>
|
||||||
<version>1.1.0-SNAPSHOT</version>
|
<version>1.2.0-SNAPSHOT</version>
|
||||||
</dependency>
|
</dependency>
|
||||||
|
|
||||||
<dependency>
|
<dependency>
|
||||||
<artifactId>manufacturer-service-remote</artifactId>
|
<artifactId>manufacturer-service-remote</artifactId>
|
||||||
<groupId>com.telecominfraproject.wlan</groupId>
|
<groupId>com.telecominfraproject.wlan</groupId>
|
||||||
<version>1.1.0-SNAPSHOT</version>
|
<version>1.2.0-SNAPSHOT</version>
|
||||||
</dependency>
|
</dependency>
|
||||||
|
|
||||||
<dependency>
|
<dependency>
|
||||||
<artifactId>cloud-event-dispatcher-remote</artifactId>
|
<artifactId>cloud-event-dispatcher-remote</artifactId>
|
||||||
<groupId>com.telecominfraproject.wlan</groupId>
|
<groupId>com.telecominfraproject.wlan</groupId>
|
||||||
<version>1.1.0-SNAPSHOT</version>
|
<version>1.2.0-SNAPSHOT</version>
|
||||||
</dependency>
|
</dependency>
|
||||||
|
|
||||||
</dependencies>
|
</dependencies>
|
||||||
|
|||||||
@@ -3,7 +3,7 @@
|
|||||||
<parent>
|
<parent>
|
||||||
<groupId>com.telecominfraproject.wlan</groupId>
|
<groupId>com.telecominfraproject.wlan</groupId>
|
||||||
<artifactId>tip-wlan-cloud-root-pom</artifactId>
|
<artifactId>tip-wlan-cloud-root-pom</artifactId>
|
||||||
<version>1.1.0-SNAPSHOT</version>
|
<version>1.2.0-SNAPSHOT</version>
|
||||||
<relativePath>../../wlan-cloud-root</relativePath>
|
<relativePath>../../wlan-cloud-root</relativePath>
|
||||||
</parent>
|
</parent>
|
||||||
<artifactId>opensync-gateway-static-docker</artifactId>
|
<artifactId>opensync-gateway-static-docker</artifactId>
|
||||||
@@ -22,7 +22,7 @@
|
|||||||
<dependency>
|
<dependency>
|
||||||
<groupId>com.telecominfraproject.wlan</groupId>
|
<groupId>com.telecominfraproject.wlan</groupId>
|
||||||
<artifactId>opensync-gateway-static-process</artifactId>
|
<artifactId>opensync-gateway-static-process</artifactId>
|
||||||
<version>1.1.0-SNAPSHOT</version>
|
<version>1.2.0-SNAPSHOT</version>
|
||||||
</dependency>
|
</dependency>
|
||||||
|
|
||||||
</dependencies>
|
</dependencies>
|
||||||
|
|||||||
@@ -3,7 +3,7 @@
|
|||||||
<parent>
|
<parent>
|
||||||
<groupId>com.telecominfraproject.wlan</groupId>
|
<groupId>com.telecominfraproject.wlan</groupId>
|
||||||
<artifactId>tip-wlan-cloud-root-pom</artifactId>
|
<artifactId>tip-wlan-cloud-root-pom</artifactId>
|
||||||
<version>1.1.0-SNAPSHOT</version>
|
<version>1.2.0-SNAPSHOT</version>
|
||||||
<relativePath>../../wlan-cloud-root</relativePath>
|
<relativePath>../../wlan-cloud-root</relativePath>
|
||||||
</parent>
|
</parent>
|
||||||
<artifactId>opensync-gateway-static-process</artifactId>
|
<artifactId>opensync-gateway-static-process</artifactId>
|
||||||
@@ -18,7 +18,7 @@
|
|||||||
<dependency>
|
<dependency>
|
||||||
<groupId>com.telecominfraproject.wlan</groupId>
|
<groupId>com.telecominfraproject.wlan</groupId>
|
||||||
<artifactId>opensync-ext-static</artifactId>
|
<artifactId>opensync-ext-static</artifactId>
|
||||||
<version>1.1.0-SNAPSHOT</version>
|
<version>1.2.0-SNAPSHOT</version>
|
||||||
</dependency>
|
</dependency>
|
||||||
|
|
||||||
</dependencies>
|
</dependencies>
|
||||||
|
|||||||
@@ -3,7 +3,7 @@
|
|||||||
<parent>
|
<parent>
|
||||||
<groupId>com.telecominfraproject.wlan</groupId>
|
<groupId>com.telecominfraproject.wlan</groupId>
|
||||||
<artifactId>tip-wlan-cloud-root-pom</artifactId>
|
<artifactId>tip-wlan-cloud-root-pom</artifactId>
|
||||||
<version>1.1.0-SNAPSHOT</version>
|
<version>1.2.0-SNAPSHOT</version>
|
||||||
<relativePath>../../wlan-cloud-root</relativePath>
|
<relativePath>../../wlan-cloud-root</relativePath>
|
||||||
</parent>
|
</parent>
|
||||||
<artifactId>opensync-gateway</artifactId>
|
<artifactId>opensync-gateway</artifactId>
|
||||||
@@ -14,22 +14,22 @@
|
|||||||
<dependency>
|
<dependency>
|
||||||
<artifactId>base-container</artifactId>
|
<artifactId>base-container</artifactId>
|
||||||
<groupId>com.telecominfraproject.wlan</groupId>
|
<groupId>com.telecominfraproject.wlan</groupId>
|
||||||
<version>1.1.0-SNAPSHOT</version>
|
<version>1.2.0-SNAPSHOT</version>
|
||||||
</dependency>
|
</dependency>
|
||||||
<dependency>
|
<dependency>
|
||||||
<groupId>com.telecominfraproject.wlan</groupId>
|
<groupId>com.telecominfraproject.wlan</groupId>
|
||||||
<artifactId>opensync-ext-interface</artifactId>
|
<artifactId>opensync-ext-interface</artifactId>
|
||||||
<version>1.1.0-SNAPSHOT</version>
|
<version>1.2.0-SNAPSHOT</version>
|
||||||
</dependency>
|
</dependency>
|
||||||
<dependency>
|
<dependency>
|
||||||
<artifactId>client-models</artifactId>
|
<artifactId>client-models</artifactId>
|
||||||
<groupId>com.telecominfraproject.wlan</groupId>
|
<groupId>com.telecominfraproject.wlan</groupId>
|
||||||
<version>1.1.0-SNAPSHOT</version>
|
<version>1.2.0-SNAPSHOT</version>
|
||||||
</dependency>
|
</dependency>
|
||||||
<dependency>
|
<dependency>
|
||||||
<artifactId>customer-models</artifactId>
|
<artifactId>customer-models</artifactId>
|
||||||
<groupId>com.telecominfraproject.wlan</groupId>
|
<groupId>com.telecominfraproject.wlan</groupId>
|
||||||
<version>1.1.0-SNAPSHOT</version>
|
<version>1.2.0-SNAPSHOT</version>
|
||||||
</dependency>
|
</dependency>
|
||||||
<dependency>
|
<dependency>
|
||||||
<groupId>com.vmware.ovsdb</groupId>
|
<groupId>com.vmware.ovsdb</groupId>
|
||||||
@@ -47,13 +47,13 @@
|
|||||||
<dependency>
|
<dependency>
|
||||||
<artifactId>service-metric-service-interface</artifactId>
|
<artifactId>service-metric-service-interface</artifactId>
|
||||||
<groupId>com.telecominfraproject.wlan</groupId>
|
<groupId>com.telecominfraproject.wlan</groupId>
|
||||||
<version>1.1.0-SNAPSHOT</version>
|
<version>1.2.0-SNAPSHOT</version>
|
||||||
</dependency>
|
</dependency>
|
||||||
|
|
||||||
<dependency>
|
<dependency>
|
||||||
<artifactId>status-service-interface</artifactId>
|
<artifactId>status-service-interface</artifactId>
|
||||||
<groupId>com.telecominfraproject.wlan</groupId>
|
<groupId>com.telecominfraproject.wlan</groupId>
|
||||||
<version>1.1.0-SNAPSHOT</version>
|
<version>1.2.0-SNAPSHOT</version>
|
||||||
</dependency>
|
</dependency>
|
||||||
|
|
||||||
<!-- https://mvnrepository.com/artifact/com.google.protobuf/protobuf-java-util -->
|
<!-- https://mvnrepository.com/artifact/com.google.protobuf/protobuf-java-util -->
|
||||||
|
|||||||
@@ -1,3 +1,4 @@
|
|||||||
|
|
||||||
package com.telecominfraproject.wlan.opensync.mqtt;
|
package com.telecominfraproject.wlan.opensync.mqtt;
|
||||||
|
|
||||||
import java.nio.charset.Charset;
|
import java.nio.charset.Charset;
|
||||||
@@ -5,11 +6,15 @@ import java.util.ArrayList;
|
|||||||
import java.util.Arrays;
|
import java.util.Arrays;
|
||||||
import java.util.List;
|
import java.util.List;
|
||||||
|
|
||||||
import org.fusesource.mqtt.client.FutureConnection;
|
import org.fusesource.mqtt.client.BlockingConnection;
|
||||||
import org.fusesource.mqtt.client.MQTT;
|
import org.fusesource.mqtt.client.MQTT;
|
||||||
import org.fusesource.mqtt.client.Message;
|
import org.fusesource.mqtt.client.Message;
|
||||||
import org.fusesource.mqtt.client.QoS;
|
import org.fusesource.mqtt.client.QoS;
|
||||||
import org.fusesource.mqtt.client.Topic;
|
import org.fusesource.mqtt.client.Topic;
|
||||||
|
import org.fusesource.mqtt.client.Tracer;
|
||||||
|
import org.fusesource.mqtt.codec.MQTTFrame;
|
||||||
|
import org.fusesource.mqtt.codec.PINGREQ;
|
||||||
|
import org.fusesource.mqtt.codec.PINGRESP;
|
||||||
import org.slf4j.Logger;
|
import org.slf4j.Logger;
|
||||||
import org.slf4j.LoggerFactory;
|
import org.slf4j.LoggerFactory;
|
||||||
import org.springframework.beans.factory.annotation.Autowired;
|
import org.springframework.beans.factory.annotation.Autowired;
|
||||||
@@ -37,10 +42,6 @@ import com.telecominfraproject.wlan.opensync.util.ZlibUtil;
|
|||||||
|
|
||||||
import sts.OpensyncStats;
|
import sts.OpensyncStats;
|
||||||
import sts.OpensyncStats.Report;
|
import sts.OpensyncStats.Report;
|
||||||
import traffic.NetworkMetadata;
|
|
||||||
import traffic.NetworkMetadata.FlowReport;
|
|
||||||
import wc.stats.IpDnsTelemetry;
|
|
||||||
import wc.stats.IpDnsTelemetry.WCStatsReport;
|
|
||||||
|
|
||||||
@Profile("mqtt_receiver")
|
@Profile("mqtt_receiver")
|
||||||
@Component
|
@Component
|
||||||
@@ -54,15 +55,11 @@ public class OpensyncMqttClient implements ApplicationListener<ContextClosedEven
|
|||||||
|
|
||||||
private final TagList tags = CloudMetricsTags.commonTags;
|
private final TagList tags = CloudMetricsTags.commonTags;
|
||||||
|
|
||||||
private final Counter messagesReceived = new BasicCounter(
|
private final Counter messagesReceived = new BasicCounter(MonitorConfig.builder("osgw-mqtt-messagesReceived").withTags(tags).build());
|
||||||
MonitorConfig.builder("osgw-mqtt-messagesReceived").withTags(tags).build());
|
|
||||||
|
|
||||||
private final Counter messageBytesReceived = new BasicCounter(
|
private final Counter messageBytesReceived = new BasicCounter(MonitorConfig.builder("osgw-mqtt-messageBytesReceived").withTags(tags).build());
|
||||||
MonitorConfig.builder("osgw-mqtt-messageBytesReceived").withTags(tags).build());
|
|
||||||
|
|
||||||
private final Timer timerMessageProcess = new BasicTimer(
|
|
||||||
MonitorConfig.builder("osgw-mqtt-messageProcessTimer").withTags(tags).build());
|
|
||||||
|
|
||||||
|
private final Timer timerMessageProcess = new BasicTimer(MonitorConfig.builder("osgw-mqtt-messageProcessTimer").withTags(tags).build());
|
||||||
|
|
||||||
@Autowired
|
@Autowired
|
||||||
private OpensyncExternalIntegrationInterface extIntegrationInterface;
|
private OpensyncExternalIntegrationInterface extIntegrationInterface;
|
||||||
@@ -85,8 +82,7 @@ public class OpensyncMqttClient implements ApplicationListener<ContextClosedEven
|
|||||||
|
|
||||||
public OpensyncMqttClient(@Autowired io.netty.handler.ssl.SslContext sslContext,
|
public OpensyncMqttClient(@Autowired io.netty.handler.ssl.SslContext sslContext,
|
||||||
@Value("${tip.wlan.mqttBroker.address.internal:testportal.123wlan.com}") String mqttBrokerAddress,
|
@Value("${tip.wlan.mqttBroker.address.internal:testportal.123wlan.com}") String mqttBrokerAddress,
|
||||||
@Value("${tip.wlan.mqttBroker.listenPort:1883}") int mqttBrokerListenPort,
|
@Value("${tip.wlan.mqttBroker.listenPort:1883}") int mqttBrokerListenPort, @Value("${tip.wlan.mqttBroker.user:admin}") String username,
|
||||||
@Value("${tip.wlan.mqttBroker.user:admin}") String username,
|
|
||||||
@Value("${tip.wlan.mqttBroker.password:admin}") String password,
|
@Value("${tip.wlan.mqttBroker.password:admin}") String password,
|
||||||
@Value("${mqtt.javax.net.ssl.keyStore:/opt/tip-wlan/certs/client_keystore.jks}") String jdkKeyStoreLocation,
|
@Value("${mqtt.javax.net.ssl.keyStore:/opt/tip-wlan/certs/client_keystore.jks}") String jdkKeyStoreLocation,
|
||||||
@Value("${mqtt.javax.net.ssl.keyStorePassword:mypassword}") String jdkKeyStorePassword,
|
@Value("${mqtt.javax.net.ssl.keyStorePassword:mypassword}") String jdkKeyStorePassword,
|
||||||
@@ -114,7 +110,7 @@ public class OpensyncMqttClient implements ApplicationListener<ContextClosedEven
|
|||||||
@Override
|
@Override
|
||||||
public void run() {
|
public void run() {
|
||||||
while (keepReconnecting) {
|
while (keepReconnecting) {
|
||||||
FutureConnection futureConnection = null;
|
BlockingConnection blockingConnection = null;
|
||||||
try {
|
try {
|
||||||
Thread.sleep(5000);
|
Thread.sleep(5000);
|
||||||
|
|
||||||
@@ -144,24 +140,46 @@ public class OpensyncMqttClient implements ApplicationListener<ContextClosedEven
|
|||||||
*/
|
*/
|
||||||
|
|
||||||
MQTT mqtt = new MQTT();
|
MQTT mqtt = new MQTT();
|
||||||
// mqtt.setHost("tcp://192.168.0.137:61616");
|
|
||||||
mqtt.setHost("tls://" + mqttBrokerAddress + ":" + mqttBrokerListenPort);
|
mqtt.setHost("tls://" + mqttBrokerAddress + ":" + mqttBrokerListenPort);
|
||||||
LOG.info("Connecting to MQTT broker at {}", mqtt.getHost());
|
LOG.info("Connecting to MQTT broker at {}", mqtt.getHost());
|
||||||
mqtt.setClientId("opensync_mqtt");
|
mqtt.setClientId("opensync_mqtt");
|
||||||
mqtt.setUserName(username);
|
mqtt.setUserName(username);
|
||||||
mqtt.setPassword(password);
|
mqtt.setPassword(password);
|
||||||
// Note: the following does not work with the
|
mqtt.setTracer(new Tracer() {
|
||||||
// serverContext,
|
@Override
|
||||||
// it has to be the
|
public void onReceive(MQTTFrame frame) {
|
||||||
// clientContext
|
switch (frame.messageType()) {
|
||||||
// mqtt.setSslContext(((JdkSslContext)
|
case PINGREQ.TYPE:
|
||||||
// sslContext).context());
|
case PINGRESP.TYPE:
|
||||||
// For now we'll rely on regular SSLContext from the JDK
|
// PINGs don't want to fill log
|
||||||
|
LOG.trace("MQTT Client Received: {}", frame);
|
||||||
|
break;
|
||||||
|
default:
|
||||||
|
LOG.debug("MQTT Client Received: {}", frame);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
// TODO: revisit this blocking connection, change it to
|
@Override
|
||||||
// futureConnection
|
public void onSend(MQTTFrame frame) {
|
||||||
futureConnection = mqtt.futureConnection();
|
switch (frame.messageType()) {
|
||||||
futureConnection.connect();
|
case PINGREQ.TYPE:
|
||||||
|
case PINGRESP.TYPE:
|
||||||
|
// PINGs don't want to fill log
|
||||||
|
LOG.trace("MQTT Client Sent: {}", frame);
|
||||||
|
break;
|
||||||
|
default:
|
||||||
|
LOG.debug("MQTT Client Sent: {}", frame);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
@Override
|
||||||
|
public void debug(String message, Object... args) {
|
||||||
|
LOG.debug("MQTT Client debugging messages: {}", String.format(message, args));
|
||||||
|
}
|
||||||
|
});
|
||||||
|
|
||||||
|
blockingConnection = mqtt.blockingConnection();
|
||||||
|
blockingConnection.connect();
|
||||||
|
|
||||||
LOG.info("Connected to MQTT broker at {}", mqtt.getHost());
|
LOG.info("Connected to MQTT broker at {}", mqtt.getHost());
|
||||||
|
|
||||||
@@ -171,24 +189,22 @@ public class OpensyncMqttClient implements ApplicationListener<ContextClosedEven
|
|||||||
// new Topic("#", QoS.AT_LEAST_ONCE),
|
// new Topic("#", QoS.AT_LEAST_ONCE),
|
||||||
// new Topic("test/#", QoS.EXACTLY_ONCE),
|
// new Topic("test/#", QoS.EXACTLY_ONCE),
|
||||||
// new Topic("foo/+/bar", QoS.AT_LEAST_ONCE)
|
// new Topic("foo/+/bar", QoS.AT_LEAST_ONCE)
|
||||||
Topic[] topics = { new Topic("#", QoS.AT_LEAST_ONCE), };
|
Topic[] topics = {new Topic("#", QoS.AT_LEAST_ONCE),};
|
||||||
|
|
||||||
futureConnection.subscribe(topics);
|
blockingConnection.subscribe(topics);
|
||||||
LOG.info("Subscribed to mqtt topics {}", Arrays.asList(topics));
|
LOG.info("Subscribed to mqtt topics {}", Arrays.asList(topics));
|
||||||
|
|
||||||
// prepare a JSONPrinter to format protobuf messages as
|
// prepare a JSONPrinter to format protobuf messages as
|
||||||
// json
|
// json
|
||||||
List<Descriptors.Descriptor> protobufDescriptors = new ArrayList<>();
|
List<Descriptors.Descriptor> protobufDescriptors = new ArrayList<>();
|
||||||
protobufDescriptors.addAll(OpensyncStats.getDescriptor().getMessageTypes());
|
protobufDescriptors.addAll(OpensyncStats.getDescriptor().getMessageTypes());
|
||||||
protobufDescriptors.addAll(IpDnsTelemetry.getDescriptor().getMessageTypes());
|
|
||||||
protobufDescriptors.addAll(NetworkMetadata.getDescriptor().getMessageTypes());
|
|
||||||
TypeRegistry oldRegistry = TypeRegistry.newBuilder().add(protobufDescriptors).build();
|
TypeRegistry oldRegistry = TypeRegistry.newBuilder().add(protobufDescriptors).build();
|
||||||
JsonFormat.Printer jsonPrinter = JsonFormat.printer().includingDefaultValueFields()
|
JsonFormat.Printer jsonPrinter =
|
||||||
.omittingInsignificantWhitespace().usingTypeRegistry(oldRegistry);
|
JsonFormat.printer().includingDefaultValueFields().omittingInsignificantWhitespace().usingTypeRegistry(oldRegistry);
|
||||||
|
|
||||||
// main loop - receive messages
|
// main loop - receive messages
|
||||||
while (true) {
|
while (true) {
|
||||||
Message mqttMsg = futureConnection.receive().await();
|
Message mqttMsg = blockingConnection.receive();
|
||||||
|
|
||||||
if (mqttMsg == null) {
|
if (mqttMsg == null) {
|
||||||
continue;
|
continue;
|
||||||
@@ -197,23 +213,11 @@ public class OpensyncMqttClient implements ApplicationListener<ContextClosedEven
|
|||||||
LOG.debug("MQTT Topic {}", mqttMsg.getTopic());
|
LOG.debug("MQTT Topic {}", mqttMsg.getTopic());
|
||||||
|
|
||||||
byte payload[] = mqttMsg.getPayload();
|
byte payload[] = mqttMsg.getPayload();
|
||||||
// we acknowledge right after receive because:
|
|
||||||
// a. none of the stats messages are so important
|
|
||||||
// that
|
|
||||||
// we cannot skip one
|
|
||||||
// b. if there's some kind of problem with the
|
|
||||||
// message
|
|
||||||
// (decoding or processing)
|
|
||||||
// - we want to move on as quickly as possible and
|
|
||||||
// not
|
|
||||||
// let it get stuck in the
|
|
||||||
// queue
|
|
||||||
mqttMsg.ack();
|
|
||||||
|
|
||||||
messagesReceived.increment();
|
messagesReceived.increment();
|
||||||
messageBytesReceived.increment(payload.length);
|
messageBytesReceived.increment(payload.length);
|
||||||
Stopwatch stopwatchTimerMessageProcess = timerMessageProcess.start();
|
Stopwatch stopwatchTimerMessageProcess = timerMessageProcess.start();
|
||||||
|
|
||||||
LOG.trace("received message on topic {} size {}", mqttMsg.getTopic(), payload.length);
|
LOG.trace("received message on topic {} size {}", mqttMsg.getTopic(), payload.length);
|
||||||
|
|
||||||
if (payload[0] == 0x78) {
|
if (payload[0] == 0x78) {
|
||||||
@@ -223,60 +227,27 @@ public class OpensyncMqttClient implements ApplicationListener<ContextClosedEven
|
|||||||
payload = ZlibUtil.decompress(payload);
|
payload = ZlibUtil.decompress(payload);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
// attempt to parse the message as protobuf
|
// attempt to parse the message as protobuf
|
||||||
MessageOrBuilder encodedMsg = null;
|
MessageOrBuilder encodedMsg = null;
|
||||||
try {
|
try {
|
||||||
|
// Only supported protobuf on the TIP opensync APs is Report
|
||||||
encodedMsg = Report.parseFrom(payload);
|
encodedMsg = Report.parseFrom(payload);
|
||||||
|
mqttMsg.ack();
|
||||||
MQTT_LOG.info("topic = {} Report = {}", mqttMsg.getTopic(),
|
MQTT_LOG.info("topic = {}\nReport = {}", mqttMsg.getTopic(), jsonPrinter.print(encodedMsg));
|
||||||
jsonPrinter.print(encodedMsg));
|
|
||||||
|
|
||||||
extIntegrationInterface.processMqttMessage(mqttMsg.getTopic(), (Report) encodedMsg);
|
extIntegrationInterface.processMqttMessage(mqttMsg.getTopic(), (Report) encodedMsg);
|
||||||
|
|
||||||
} catch (Exception e) {
|
} catch (Exception e) {
|
||||||
try {
|
String msgStr = new String(mqttMsg.getPayload(), utf8);
|
||||||
// not a opensync_stats report, attempt to
|
LOG.warn("Could not process message topic = {}\nmessage = {}", mqttMsg.getTopic(), msgStr);
|
||||||
// deserialize as network_metadata
|
|
||||||
encodedMsg = FlowReport.parseFrom(payload);
|
|
||||||
|
|
||||||
MQTT_LOG.info("topic = {} FlowReport = {}", mqttMsg.getTopic(),
|
|
||||||
jsonPrinter.print(encodedMsg));
|
|
||||||
|
|
||||||
extIntegrationInterface.processMqttMessage(mqttMsg.getTopic(),
|
|
||||||
(FlowReport) encodedMsg);
|
|
||||||
} catch (Exception e1) {
|
|
||||||
|
|
||||||
try {
|
|
||||||
// not a opensync_stats report and not
|
|
||||||
// network_metadata report, attempt to
|
|
||||||
// deserialize as WCStatsReport
|
|
||||||
encodedMsg = WCStatsReport.parseFrom(payload);
|
|
||||||
|
|
||||||
MQTT_LOG.info("topic = {} IpDnsTelemetry = {}", mqttMsg.getTopic(),
|
|
||||||
jsonPrinter.print(encodedMsg));
|
|
||||||
|
|
||||||
|
|
||||||
extIntegrationInterface.processMqttMessage(mqttMsg.getTopic(),
|
|
||||||
(WCStatsReport) encodedMsg);
|
|
||||||
} catch (Exception e2) {
|
|
||||||
String msgStr = new String(mqttMsg.getPayload(), utf8);
|
|
||||||
MQTT_LOG.info("topic = {} message = {}", mqttMsg.getTopic(), msgStr);
|
|
||||||
}
|
|
||||||
}
|
|
||||||
} finally {
|
} finally {
|
||||||
stopwatchTimerMessageProcess.stop();
|
stopwatchTimerMessageProcess.stop();
|
||||||
}
|
}
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|
||||||
} catch (Exception e) {
|
} catch (Exception e) {
|
||||||
LOG.error("Exception in MQTT receiver", e);
|
LOG.error("Exception in MQTT receiver", e);
|
||||||
} finally {
|
} finally {
|
||||||
try {
|
try {
|
||||||
if (futureConnection != null) {
|
if (blockingConnection != null) {
|
||||||
futureConnection.disconnect();
|
blockingConnection.disconnect();
|
||||||
}
|
}
|
||||||
} catch (Exception e1) {
|
} catch (Exception e1) {
|
||||||
// do nothing
|
// do nothing
|
||||||
|
|||||||
@@ -1,3 +1,4 @@
|
|||||||
|
|
||||||
package com.telecominfraproject.wlan.opensync.ovsdb;
|
package com.telecominfraproject.wlan.opensync.ovsdb;
|
||||||
|
|
||||||
import com.google.common.collect.ImmutableMap;
|
import com.google.common.collect.ImmutableMap;
|
||||||
@@ -50,17 +51,13 @@ public class TipWlanOvsdbClient implements OvsdbClientInterface {
|
|||||||
|
|
||||||
private final TagList tags = CloudMetricsTags.commonTags;
|
private final TagList tags = CloudMetricsTags.commonTags;
|
||||||
|
|
||||||
private final Counter connectionsAttempted = new BasicCounter(
|
private final Counter connectionsAttempted = new BasicCounter(MonitorConfig.builder("osgw-connectionsAttempted").withTags(tags).build());
|
||||||
MonitorConfig.builder("osgw-connectionsAttempted").withTags(tags).build());
|
|
||||||
|
|
||||||
private final Counter connectionsFailed = new BasicCounter(
|
private final Counter connectionsFailed = new BasicCounter(MonitorConfig.builder("osgw-connectionsFailed").withTags(tags).build());
|
||||||
MonitorConfig.builder("osgw-connectionsFailed").withTags(tags).build());
|
|
||||||
|
|
||||||
private final Counter connectionsCreated = new BasicCounter(
|
private final Counter connectionsCreated = new BasicCounter(MonitorConfig.builder("osgw-connectionsCreated").withTags(tags).build());
|
||||||
MonitorConfig.builder("osgw-connectionsCreated").withTags(tags).build());
|
|
||||||
|
|
||||||
private final Counter connectionsDropped = new BasicCounter(
|
private final Counter connectionsDropped = new BasicCounter(MonitorConfig.builder("osgw-connectionsDropped").withTags(tags).build());
|
||||||
MonitorConfig.builder("osgw-connectionsDropped").withTags(tags).build());
|
|
||||||
|
|
||||||
@org.springframework.beans.factory.annotation.Value("${tip.wlan.ovsdb.listenPort:6640}")
|
@org.springframework.beans.factory.annotation.Value("${tip.wlan.ovsdb.listenPort:6640}")
|
||||||
private int ovsdbListenPort;
|
private int ovsdbListenPort;
|
||||||
@@ -127,8 +124,7 @@ public class TipWlanOvsdbClient implements OvsdbClientInterface {
|
|||||||
int localPort = ovsdbClient.getConnectionInfo().getLocalPort();
|
int localPort = ovsdbClient.getConnectionInfo().getLocalPort();
|
||||||
String subjectDn;
|
String subjectDn;
|
||||||
try {
|
try {
|
||||||
subjectDn = ((X509Certificate) ovsdbClient.getConnectionInfo().getRemoteCertificate())
|
subjectDn = ((X509Certificate) ovsdbClient.getConnectionInfo().getRemoteCertificate()).getSubjectDN().getName();
|
||||||
.getSubjectDN().getName();
|
|
||||||
|
|
||||||
String clientCn = SslUtil.extractCN(subjectDn);
|
String clientCn = SslUtil.extractCN(subjectDn);
|
||||||
LOG.info("ovsdbClient connecting from {} on port {} clientCn {}", remoteHost, localPort, clientCn);
|
LOG.info("ovsdbClient connecting from {} on port {} clientCn {}", remoteHost, localPort, clientCn);
|
||||||
@@ -189,8 +185,7 @@ public class TipWlanOvsdbClient implements OvsdbClientInterface {
|
|||||||
localPort = ovsdbClient.getConnectionInfo().getLocalPort();
|
localPort = ovsdbClient.getConnectionInfo().getLocalPort();
|
||||||
String subjectDn = null;
|
String subjectDn = null;
|
||||||
try {
|
try {
|
||||||
subjectDn = ((X509Certificate) ovsdbClient.getConnectionInfo().getRemoteCertificate())
|
subjectDn = ((X509Certificate) ovsdbClient.getConnectionInfo().getRemoteCertificate()).getSubjectDN().getName();
|
||||||
.getSubjectDN().getName();
|
|
||||||
} catch (Exception e) {
|
} catch (Exception e) {
|
||||||
// do nothing
|
// do nothing
|
||||||
}
|
}
|
||||||
@@ -204,8 +199,7 @@ public class TipWlanOvsdbClient implements OvsdbClientInterface {
|
|||||||
LOG.debug("Unable to process ap disconnect. {}", e.getMessage());
|
LOG.debug("Unable to process ap disconnect. {}", e.getMessage());
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
LOG.info("ovsdbClient disconnected from {} on port {} clientCn {} AP {} ", remoteHost, localPort,
|
LOG.info("ovsdbClient disconnected from {} on port {} clientCn {} AP {} ", remoteHost, localPort, clientCn, key);
|
||||||
clientCn, key);
|
|
||||||
LOG.info("ovsdbClient connectedClients = {}", ovsdbSessionMapInterface.getNumSessions());
|
LOG.info("ovsdbClient connectedClients = {}", ovsdbSessionMapInterface.getNumSessions());
|
||||||
} finally {
|
} finally {
|
||||||
try {
|
try {
|
||||||
@@ -228,8 +222,7 @@ public class TipWlanOvsdbClient implements OvsdbClientInterface {
|
|||||||
private void processConnectRequest(OvsdbClient ovsdbClient, String clientCn, ConnectNodeInfo connectNodeInfo) {
|
private void processConnectRequest(OvsdbClient ovsdbClient, String clientCn, ConnectNodeInfo connectNodeInfo) {
|
||||||
|
|
||||||
LOG.debug("Starting Client connect");
|
LOG.debug("Starting Client connect");
|
||||||
connectNodeInfo = ovsdbDao.updateConnectNodeInfoOnConnect(ovsdbClient, clientCn, connectNodeInfo,
|
connectNodeInfo = ovsdbDao.updateConnectNodeInfoOnConnect(ovsdbClient, clientCn, connectNodeInfo, preventClientCnAlteration);
|
||||||
preventClientCnAlteration);
|
|
||||||
|
|
||||||
// successfully connected - register it in our
|
// successfully connected - register it in our
|
||||||
// connectedClients table
|
// connectedClients table
|
||||||
@@ -294,6 +287,15 @@ public class TipWlanOvsdbClient implements OvsdbClientInterface {
|
|||||||
|
|
||||||
return ovsdbDao.changeRedirectorAddress(ovsdbSession.getOvsdbClient(), apId, newRedirectorAddress);
|
return ovsdbDao.changeRedirectorAddress(ovsdbSession.getOvsdbClient(), apId, newRedirectorAddress);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
public String processBlinkRequest(String apId, boolean blinkAllLEDs) {
|
||||||
|
OvsdbSession ovsdbSession = ovsdbSessionMapInterface.getSession(apId);
|
||||||
|
if (ovsdbSession == null) {
|
||||||
|
throw new IllegalStateException("AP with id " + apId + " is not connected");
|
||||||
|
}
|
||||||
|
|
||||||
|
return ovsdbDao.processBlinkRequest(ovsdbSession.getOvsdbClient(), apId, blinkAllLEDs);
|
||||||
|
}
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
public void processConfigChanged(String apId) {
|
public void processConfigChanged(String apId) {
|
||||||
@@ -319,7 +321,7 @@ public class TipWlanOvsdbClient implements OvsdbClientInterface {
|
|||||||
ovsdbDao.removeRadsecRadiusAndRealmConfigs(ovsdbClient);
|
ovsdbDao.removeRadsecRadiusAndRealmConfigs(ovsdbClient);
|
||||||
|
|
||||||
extIntegrationInterface.clearEquipmentStatus(apId);
|
extIntegrationInterface.clearEquipmentStatus(apId);
|
||||||
|
|
||||||
ovsdbDao.configureNode(ovsdbClient, opensyncAPConfig);
|
ovsdbDao.configureNode(ovsdbClient, opensyncAPConfig);
|
||||||
ovsdbDao.configureWifiRrm(ovsdbClient, opensyncAPConfig);
|
ovsdbDao.configureWifiRrm(ovsdbClient, opensyncAPConfig);
|
||||||
ovsdbDao.configureGreTunnels(ovsdbClient, opensyncAPConfig);
|
ovsdbDao.configureGreTunnels(ovsdbClient, opensyncAPConfig);
|
||||||
@@ -413,27 +415,24 @@ public class TipWlanOvsdbClient implements OvsdbClientInterface {
|
|||||||
} catch (OvsdbClientException e) {
|
} catch (OvsdbClientException e) {
|
||||||
LOG.debug("Could not enable monitor for Node_State table. {}", e.getMessage());
|
LOG.debug("Could not enable monitor for Node_State table. {}", e.getMessage());
|
||||||
}
|
}
|
||||||
|
|
||||||
try {
|
try {
|
||||||
if (ovsdbClient.getSchema(OvsdbDao.ovsdbName).get().getTables().containsKey("APC_State")) {
|
if (ovsdbClient.getSchema(OvsdbDao.ovsdbName).get().getTables().containsKey("APC_State")) {
|
||||||
monitorAPCStateTable(ovsdbClient, key);
|
monitorAPCStateTable(ovsdbClient, key);
|
||||||
}
|
}
|
||||||
} catch (InterruptedException | ExecutionException | OvsdbClientException e) {
|
} catch (InterruptedException | ExecutionException | OvsdbClientException e) {
|
||||||
LOG.debug("Could not enable monitor for APC_State table. {}", e);
|
LOG.debug("Could not enable monitor for APC_State table. {}", e);
|
||||||
}
|
}
|
||||||
LOG.debug("Finished (re)setting monitors for AP {}", key);
|
LOG.debug("Finished (re)setting monitors for AP {}", key);
|
||||||
}
|
}
|
||||||
|
|
||||||
private void monitorDhcpLeasedIpDbTable(OvsdbClient ovsdbClient, String key) throws OvsdbClientException {
|
private void monitorDhcpLeasedIpDbTable(OvsdbClient ovsdbClient, String key) throws OvsdbClientException {
|
||||||
|
|
||||||
CompletableFuture<TableUpdates> awCf = ovsdbClient.monitor(OvsdbDao.ovsdbName,
|
CompletableFuture<TableUpdates> awCf = ovsdbClient.monitor(OvsdbDao.ovsdbName, OvsdbDao.dhcpLeasedIpDbTable + "_" + key,
|
||||||
OvsdbDao.dhcpLeasedIpDbTable + "_" + key,
|
new MonitorRequests(ImmutableMap.of(OvsdbDao.dhcpLeasedIpDbTable, new MonitorRequest(new MonitorSelect(true, true, true, true)))),
|
||||||
new MonitorRequests(ImmutableMap.of(OvsdbDao.dhcpLeasedIpDbTable,
|
|
||||||
new MonitorRequest(new MonitorSelect(true, true, true, true)))),
|
|
||||||
tableUpdates -> {
|
tableUpdates -> {
|
||||||
try {
|
try {
|
||||||
LOG.info(OvsdbDao.dhcpLeasedIpDbTable + "_" + key + " monitor callback received {}",
|
LOG.info(OvsdbDao.dhcpLeasedIpDbTable + "_" + key + " monitor callback received {}", tableUpdates);
|
||||||
tableUpdates);
|
|
||||||
|
|
||||||
List<Map<String, String>> insert = new ArrayList<>();
|
List<Map<String, String>> insert = new ArrayList<>();
|
||||||
List<Map<String, String>> delete = new ArrayList<>();
|
List<Map<String, String>> delete = new ArrayList<>();
|
||||||
@@ -445,8 +444,7 @@ public class TipWlanOvsdbClient implements OvsdbClientInterface {
|
|||||||
if (rowUpdate.getNew() == null) {
|
if (rowUpdate.getNew() == null) {
|
||||||
Map<String, String> rowMap = new HashMap<>();
|
Map<String, String> rowMap = new HashMap<>();
|
||||||
|
|
||||||
rowUpdate.getOld().getColumns().entrySet()
|
rowUpdate.getOld().getColumns().entrySet().forEach(c -> OvsdbDao.translateDhcpFpValueToString(c, rowMap));
|
||||||
.forEach(c -> OvsdbDao.translateDhcpFpValueToString(c, rowMap));
|
|
||||||
|
|
||||||
delete.add(rowMap);
|
delete.add(rowMap);
|
||||||
// delete
|
// delete
|
||||||
@@ -454,8 +452,7 @@ public class TipWlanOvsdbClient implements OvsdbClientInterface {
|
|||||||
// insert
|
// insert
|
||||||
Map<String, String> rowMap = new HashMap<>();
|
Map<String, String> rowMap = new HashMap<>();
|
||||||
|
|
||||||
rowUpdate.getNew().getColumns().entrySet()
|
rowUpdate.getNew().getColumns().entrySet().forEach(c -> OvsdbDao.translateDhcpFpValueToString(c, rowMap));
|
||||||
.forEach(c -> OvsdbDao.translateDhcpFpValueToString(c, rowMap));
|
|
||||||
|
|
||||||
insert.add(rowMap);
|
insert.add(rowMap);
|
||||||
} else {
|
} else {
|
||||||
@@ -464,8 +461,7 @@ public class TipWlanOvsdbClient implements OvsdbClientInterface {
|
|||||||
Map<String, String> rowMap = new HashMap<>();
|
Map<String, String> rowMap = new HashMap<>();
|
||||||
|
|
||||||
rowUpdate.getOld().getColumns().putAll(rowUpdate.getNew().getColumns());
|
rowUpdate.getOld().getColumns().putAll(rowUpdate.getNew().getColumns());
|
||||||
rowUpdate.getOld().getColumns().entrySet()
|
rowUpdate.getOld().getColumns().entrySet().forEach(c -> OvsdbDao.translateDhcpFpValueToString(c, rowMap));
|
||||||
.forEach(c -> OvsdbDao.translateDhcpFpValueToString(c, rowMap));
|
|
||||||
|
|
||||||
update.add(rowMap);
|
update.add(rowMap);
|
||||||
|
|
||||||
@@ -498,13 +494,10 @@ public class TipWlanOvsdbClient implements OvsdbClientInterface {
|
|||||||
|
|
||||||
private void monitorCommandStateDbTable(OvsdbClient ovsdbClient, String key) throws OvsdbClientException {
|
private void monitorCommandStateDbTable(OvsdbClient ovsdbClient, String key) throws OvsdbClientException {
|
||||||
|
|
||||||
CompletableFuture<TableUpdates> csCf = ovsdbClient.monitor(OvsdbDao.ovsdbName,
|
CompletableFuture<TableUpdates> csCf = ovsdbClient.monitor(OvsdbDao.ovsdbName, OvsdbDao.commandStateDbTable + "_" + key,
|
||||||
OvsdbDao.commandStateDbTable + "_" + key,
|
new MonitorRequests(ImmutableMap.of(OvsdbDao.commandStateDbTable, new MonitorRequest())), tableUpdates -> {
|
||||||
new MonitorRequests(ImmutableMap.of(OvsdbDao.commandStateDbTable, new MonitorRequest())),
|
|
||||||
tableUpdates -> {
|
|
||||||
try {
|
try {
|
||||||
LOG.info(OvsdbDao.commandStateDbTable + "_" + key + " monitor callback received {}",
|
LOG.info(OvsdbDao.commandStateDbTable + "_" + key + " monitor callback received {}", tableUpdates);
|
||||||
tableUpdates);
|
|
||||||
|
|
||||||
List<Map<String, String>> insert = new ArrayList<>();
|
List<Map<String, String>> insert = new ArrayList<>();
|
||||||
List<Map<String, String>> delete = new ArrayList<>();
|
List<Map<String, String>> delete = new ArrayList<>();
|
||||||
@@ -516,8 +509,7 @@ public class TipWlanOvsdbClient implements OvsdbClientInterface {
|
|||||||
if (rowUpdate.getNew() == null) {
|
if (rowUpdate.getNew() == null) {
|
||||||
Map<String, String> rowMap = new HashMap<>();
|
Map<String, String> rowMap = new HashMap<>();
|
||||||
|
|
||||||
rowUpdate.getOld().getColumns()
|
rowUpdate.getOld().getColumns().forEach((key1, value) -> rowMap.put(key1, value.toString()));
|
||||||
.forEach((key1, value) -> rowMap.put(key1, value.toString()));
|
|
||||||
|
|
||||||
delete.add(rowMap);
|
delete.add(rowMap);
|
||||||
// delete
|
// delete
|
||||||
@@ -525,8 +517,7 @@ public class TipWlanOvsdbClient implements OvsdbClientInterface {
|
|||||||
// insert
|
// insert
|
||||||
Map<String, String> rowMap = new HashMap<>();
|
Map<String, String> rowMap = new HashMap<>();
|
||||||
|
|
||||||
rowUpdate.getNew().getColumns()
|
rowUpdate.getNew().getColumns().forEach((key1, value) -> rowMap.put(key1, value.toString()));
|
||||||
.forEach((key1, value) -> rowMap.put(key1, value.toString()));
|
|
||||||
|
|
||||||
insert.add(rowMap);
|
insert.add(rowMap);
|
||||||
} else {
|
} else {
|
||||||
@@ -535,8 +526,7 @@ public class TipWlanOvsdbClient implements OvsdbClientInterface {
|
|||||||
Map<String, String> rowMap = new HashMap<>();
|
Map<String, String> rowMap = new HashMap<>();
|
||||||
|
|
||||||
rowUpdate.getOld().getColumns().putAll(rowUpdate.getNew().getColumns());
|
rowUpdate.getOld().getColumns().putAll(rowUpdate.getNew().getColumns());
|
||||||
rowUpdate.getOld().getColumns()
|
rowUpdate.getOld().getColumns().forEach((key1, value) -> rowMap.put(key1, value.toString()));
|
||||||
.forEach((key1, value) -> rowMap.put(key1, value.toString()));
|
|
||||||
|
|
||||||
update.add(rowMap);
|
update.add(rowMap);
|
||||||
|
|
||||||
@@ -568,33 +558,27 @@ public class TipWlanOvsdbClient implements OvsdbClientInterface {
|
|||||||
}
|
}
|
||||||
|
|
||||||
private void monitorAwlanNodeDbTable(OvsdbClient ovsdbClient, String key) throws OvsdbClientException {
|
private void monitorAwlanNodeDbTable(OvsdbClient ovsdbClient, String key) throws OvsdbClientException {
|
||||||
CompletableFuture<TableUpdates> awCf = ovsdbClient.monitor(OvsdbDao.ovsdbName,
|
CompletableFuture<TableUpdates> awCf = ovsdbClient.monitor(OvsdbDao.ovsdbName, OvsdbDao.awlanNodeDbTable + "_" + key,
|
||||||
OvsdbDao.awlanNodeDbTable + "_" + key, new MonitorRequests(ImmutableMap.of(OvsdbDao.awlanNodeDbTable,
|
new MonitorRequests(ImmutableMap.of(OvsdbDao.awlanNodeDbTable, new MonitorRequest(new MonitorSelect(true, false, false, true)))),
|
||||||
new MonitorRequest(new MonitorSelect(true, false, false, true)))),
|
|
||||||
tableUpdates -> {
|
tableUpdates -> {
|
||||||
try {
|
try {
|
||||||
LOG.info(OvsdbDao.awlanNodeDbTable + "_" + key + " monitor callback received {}", tableUpdates);
|
LOG.info(OvsdbDao.awlanNodeDbTable + "_" + key + " monitor callback received {}", tableUpdates);
|
||||||
|
|
||||||
extIntegrationInterface.awlanNodeDbTableUpdate(
|
extIntegrationInterface.awlanNodeDbTableUpdate(ovsdbDao.getOpensyncAWLANNode(tableUpdates, key, ovsdbClient), key);
|
||||||
ovsdbDao.getOpensyncAWLANNode(tableUpdates, key, ovsdbClient), key);
|
|
||||||
} catch (Exception e) {
|
} catch (Exception e) {
|
||||||
LOG.error("awlanNodeDbTableUpdate failed", e);
|
LOG.error("awlanNodeDbTableUpdate failed", e);
|
||||||
}
|
}
|
||||||
});
|
});
|
||||||
|
|
||||||
extIntegrationInterface.awlanNodeDbTableUpdate(ovsdbDao.getOpensyncAWLANNode(awCf.join(), key, ovsdbClient),
|
extIntegrationInterface.awlanNodeDbTableUpdate(ovsdbDao.getOpensyncAWLANNode(awCf.join(), key, ovsdbClient), key);
|
||||||
key);
|
|
||||||
}
|
}
|
||||||
|
|
||||||
private void monitorWifiAssociatedClientsDbTable(OvsdbClient ovsdbClient, String key) throws OvsdbClientException {
|
private void monitorWifiAssociatedClientsDbTable(OvsdbClient ovsdbClient, String key) throws OvsdbClientException {
|
||||||
CompletableFuture<TableUpdates> acCf = ovsdbClient.monitor(OvsdbDao.ovsdbName,
|
CompletableFuture<TableUpdates> acCf = ovsdbClient.monitor(OvsdbDao.ovsdbName, OvsdbDao.wifiAssociatedClientsDbTable + "_" + key,
|
||||||
OvsdbDao.wifiAssociatedClientsDbTable + "_" + key,
|
new MonitorRequests(ImmutableMap.of(OvsdbDao.wifiAssociatedClientsDbTable, new MonitorRequest())), tableUpdates -> {
|
||||||
new MonitorRequests(ImmutableMap.of(OvsdbDao.wifiAssociatedClientsDbTable, new MonitorRequest())),
|
|
||||||
tableUpdates -> {
|
|
||||||
|
|
||||||
try {
|
try {
|
||||||
LOG.info(OvsdbDao.wifiAssociatedClientsDbTable + "_" + key + " monitor callback received {}",
|
LOG.info(OvsdbDao.wifiAssociatedClientsDbTable + "_" + key + " monitor callback received {}", tableUpdates);
|
||||||
tableUpdates);
|
|
||||||
|
|
||||||
List<OpensyncWifiAssociatedClients> associatedClients = new ArrayList<>();
|
List<OpensyncWifiAssociatedClients> associatedClients = new ArrayList<>();
|
||||||
|
|
||||||
@@ -611,8 +595,7 @@ public class TipWlanOvsdbClient implements OvsdbClientInterface {
|
|||||||
// adding anyway.
|
// adding anyway.
|
||||||
extIntegrationInterface.wifiAssociatedClientsDbTableDelete(deletedClientMac, key);
|
extIntegrationInterface.wifiAssociatedClientsDbTableDelete(deletedClientMac, key);
|
||||||
} else {
|
} else {
|
||||||
associatedClients.addAll(
|
associatedClients.addAll(ovsdbDao.getOpensyncWifiAssociatedClients(rowUpdate, key, ovsdbClient));
|
||||||
ovsdbDao.getOpensyncWifiAssociatedClients(rowUpdate, key, ovsdbClient));
|
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
@@ -626,20 +609,16 @@ public class TipWlanOvsdbClient implements OvsdbClientInterface {
|
|||||||
|
|
||||||
});
|
});
|
||||||
|
|
||||||
extIntegrationInterface.wifiAssociatedClientsDbTableUpdate(
|
extIntegrationInterface.wifiAssociatedClientsDbTableUpdate(ovsdbDao.getInitialOpensyncWifiAssociatedClients(acCf.join(), key, ovsdbClient), key);
|
||||||
ovsdbDao.getInitialOpensyncWifiAssociatedClients(acCf.join(), key, ovsdbClient), key);
|
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|
||||||
private void monitorWifiInetStateDbTable(OvsdbClient ovsdbClient, String key) throws OvsdbClientException {
|
private void monitorWifiInetStateDbTable(OvsdbClient ovsdbClient, String key) throws OvsdbClientException {
|
||||||
CompletableFuture<TableUpdates> isCf = ovsdbClient.monitor(OvsdbDao.ovsdbName,
|
CompletableFuture<TableUpdates> isCf = ovsdbClient.monitor(OvsdbDao.ovsdbName, OvsdbDao.wifiInetStateDbTable + "_" + key,
|
||||||
OvsdbDao.wifiInetStateDbTable + "_" + key,
|
new MonitorRequests(ImmutableMap.of(OvsdbDao.wifiInetStateDbTable, new MonitorRequest(new MonitorSelect(true, true, true, true)))),
|
||||||
new MonitorRequests(ImmutableMap.of(OvsdbDao.wifiInetStateDbTable,
|
|
||||||
new MonitorRequest(new MonitorSelect(true, true, true, true)))),
|
|
||||||
tableUpdates -> {
|
tableUpdates -> {
|
||||||
try {
|
try {
|
||||||
LOG.info(OvsdbDao.wifiInetStateDbTable + "_" + key + " monitor callback received {}",
|
LOG.info(OvsdbDao.wifiInetStateDbTable + "_" + key + " monitor callback received {}", tableUpdates);
|
||||||
tableUpdates);
|
|
||||||
|
|
||||||
List<OpensyncAPInetState> inetStateInsertOrUpdate = new ArrayList<>();
|
List<OpensyncAPInetState> inetStateInsertOrUpdate = new ArrayList<>();
|
||||||
List<OpensyncAPInetState> inetStateDelete = new ArrayList<>();
|
List<OpensyncAPInetState> inetStateDelete = new ArrayList<>();
|
||||||
@@ -649,11 +628,9 @@ public class TipWlanOvsdbClient implements OvsdbClientInterface {
|
|||||||
for (RowUpdate rowUpdate : tableUpdate.getRowUpdates().values()) {
|
for (RowUpdate rowUpdate : tableUpdate.getRowUpdates().values()) {
|
||||||
|
|
||||||
if (rowUpdate.getNew() == null) {
|
if (rowUpdate.getNew() == null) {
|
||||||
inetStateDelete.addAll(
|
inetStateDelete.addAll(ovsdbDao.getOpensyncApInetStateForRowUpdate(rowUpdate, key, ovsdbClient));
|
||||||
ovsdbDao.getOpensyncApInetStateForRowUpdate(rowUpdate, key, ovsdbClient));
|
|
||||||
} else {
|
} else {
|
||||||
inetStateInsertOrUpdate.addAll(
|
inetStateInsertOrUpdate.addAll(ovsdbDao.getOpensyncApInetStateForRowUpdate(rowUpdate, key, ovsdbClient));
|
||||||
ovsdbDao.getOpensyncApInetStateForRowUpdate(rowUpdate, key, ovsdbClient));
|
|
||||||
}
|
}
|
||||||
|
|
||||||
}
|
}
|
||||||
@@ -670,42 +647,33 @@ public class TipWlanOvsdbClient implements OvsdbClientInterface {
|
|||||||
|
|
||||||
});
|
});
|
||||||
|
|
||||||
extIntegrationInterface.wifiInetStateDbTableUpdate(
|
extIntegrationInterface.wifiInetStateDbTableUpdate(ovsdbDao.getInitialOpensyncApInetStateForRowUpdate(isCf.join(), key, ovsdbClient), key);
|
||||||
ovsdbDao.getInitialOpensyncApInetStateForRowUpdate(isCf.join(), key, ovsdbClient), key);
|
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|
||||||
private void monitorWifiRadioStateDbTable(OvsdbClient ovsdbClient, String key) throws OvsdbClientException {
|
private void monitorWifiRadioStateDbTable(OvsdbClient ovsdbClient, String key) throws OvsdbClientException {
|
||||||
|
|
||||||
CompletableFuture<TableUpdates> rsCf = ovsdbClient.monitor(OvsdbDao.ovsdbName,
|
CompletableFuture<TableUpdates> rsCf = ovsdbClient.monitor(OvsdbDao.ovsdbName, OvsdbDao.wifiRadioStateDbTable + "_" + key,
|
||||||
OvsdbDao.wifiRadioStateDbTable + "_" + key,
|
new MonitorRequests(ImmutableMap.of(OvsdbDao.wifiRadioStateDbTable, new MonitorRequest(new MonitorSelect(true, false, false, true)))),
|
||||||
new MonitorRequests(ImmutableMap.of(OvsdbDao.wifiRadioStateDbTable,
|
|
||||||
new MonitorRequest(new MonitorSelect(true, false, false, true)))),
|
|
||||||
tableUpdates -> {
|
tableUpdates -> {
|
||||||
try {
|
try {
|
||||||
LOG.info(OvsdbDao.wifiRadioStateDbTable + "_" + key + " monitor callback received {}",
|
LOG.info(OvsdbDao.wifiRadioStateDbTable + "_" + key + " monitor callback received {}", tableUpdates);
|
||||||
tableUpdates);
|
|
||||||
|
|
||||||
extIntegrationInterface.wifiRadioStatusDbTableUpdate(
|
extIntegrationInterface.wifiRadioStatusDbTableUpdate(ovsdbDao.getOpensyncAPRadioState(tableUpdates, key, ovsdbClient), key);
|
||||||
ovsdbDao.getOpensyncAPRadioState(tableUpdates, key, ovsdbClient), key);
|
|
||||||
} catch (Exception e) {
|
} catch (Exception e) {
|
||||||
LOG.error("wifiRadioStatusDbTableUpdate failed", e);
|
LOG.error("wifiRadioStatusDbTableUpdate failed", e);
|
||||||
}
|
}
|
||||||
});
|
});
|
||||||
extIntegrationInterface
|
extIntegrationInterface.wifiRadioStatusDbTableUpdate(ovsdbDao.getOpensyncAPRadioState(rsCf.join(), key, ovsdbClient), key);
|
||||||
.wifiRadioStatusDbTableUpdate(ovsdbDao.getOpensyncAPRadioState(rsCf.join(), key, ovsdbClient), key);
|
|
||||||
}
|
}
|
||||||
|
|
||||||
private void monitorWifiVifStateDbTable(OvsdbClient ovsdbClient, String key) throws OvsdbClientException {
|
private void monitorWifiVifStateDbTable(OvsdbClient ovsdbClient, String key) throws OvsdbClientException {
|
||||||
|
|
||||||
CompletableFuture<TableUpdates> vsCf = ovsdbClient.monitor(OvsdbDao.ovsdbName,
|
CompletableFuture<TableUpdates> vsCf = ovsdbClient.monitor(OvsdbDao.ovsdbName, OvsdbDao.wifiVifStateDbTable + "_" + key,
|
||||||
OvsdbDao.wifiVifStateDbTable + "_" + key,
|
new MonitorRequests(ImmutableMap.of(OvsdbDao.wifiVifStateDbTable, new MonitorRequest(new MonitorSelect(false, true, true, true)))),
|
||||||
new MonitorRequests(ImmutableMap.of(OvsdbDao.wifiVifStateDbTable,
|
|
||||||
new MonitorRequest(new MonitorSelect(false, true, true, true)))),
|
|
||||||
tableUpdates -> {
|
tableUpdates -> {
|
||||||
try {
|
try {
|
||||||
LOG.info(OvsdbDao.wifiVifStateDbTable + "_" + key + " monitor callback received {}",
|
LOG.info(OvsdbDao.wifiVifStateDbTable + "_" + key + " monitor callback received {}", tableUpdates);
|
||||||
tableUpdates);
|
|
||||||
|
|
||||||
List<OpensyncAPVIFState> vifsToDelete = new ArrayList<>();
|
List<OpensyncAPVIFState> vifsToDelete = new ArrayList<>();
|
||||||
List<OpensyncAPVIFState> vifsToInsertOrUpdate = new ArrayList<>();
|
List<OpensyncAPVIFState> vifsToInsertOrUpdate = new ArrayList<>();
|
||||||
@@ -715,14 +683,12 @@ public class TipWlanOvsdbClient implements OvsdbClientInterface {
|
|||||||
|
|
||||||
if (rowUpdate.getNew() == null) {
|
if (rowUpdate.getNew() == null) {
|
||||||
// this is a deletion
|
// this is a deletion
|
||||||
vifsToDelete.addAll(
|
vifsToDelete.addAll(ovsdbDao.getOpensyncApVifStateForRowUpdate(rowUpdate, key, ovsdbClient));
|
||||||
ovsdbDao.getOpensyncApVifStateForRowUpdate(rowUpdate, key, ovsdbClient));
|
|
||||||
|
|
||||||
} else {
|
} else {
|
||||||
// either an insert or
|
// either an insert or
|
||||||
// mutuate/update
|
// mutuate/update
|
||||||
vifsToInsertOrUpdate.addAll(
|
vifsToInsertOrUpdate.addAll(ovsdbDao.getOpensyncApVifStateForRowUpdate(rowUpdate, key, ovsdbClient));
|
||||||
ovsdbDao.getOpensyncApVifStateForRowUpdate(rowUpdate, key, ovsdbClient));
|
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|
||||||
@@ -747,10 +713,8 @@ public class TipWlanOvsdbClient implements OvsdbClientInterface {
|
|||||||
}
|
}
|
||||||
|
|
||||||
private void monitorNodeStateTable(OvsdbClient ovsdbClient, String key) throws OvsdbClientException {
|
private void monitorNodeStateTable(OvsdbClient ovsdbClient, String key) throws OvsdbClientException {
|
||||||
CompletableFuture<TableUpdates> nsCf = ovsdbClient.monitor(
|
CompletableFuture<TableUpdates> nsCf = ovsdbClient.monitor(OvsdbDao.ovsdbName, OvsdbDao.nodeStateTable + "_" + key,
|
||||||
OvsdbDao.ovsdbName, OvsdbDao.nodeStateTable + "_" + key, new MonitorRequests(ImmutableMap
|
new MonitorRequests(ImmutableMap.of(OvsdbDao.nodeStateTable, new MonitorRequest(new MonitorSelect(true, true, true, true)))), tableUpdates -> {
|
||||||
.of(OvsdbDao.nodeStateTable, new MonitorRequest(new MonitorSelect(true, true, true, true)))),
|
|
||||||
tableUpdates -> {
|
|
||||||
LOG.info(OvsdbDao.nodeStateTable + "_" + key + " monitor callback received {}");
|
LOG.info(OvsdbDao.nodeStateTable + "_" + key + " monitor callback received {}");
|
||||||
tableUpdates.getTableUpdates().forEach((key1, value) -> {
|
tableUpdates.getTableUpdates().forEach((key1, value) -> {
|
||||||
LOG.info("TableUpdate for {}", key1);
|
LOG.info("TableUpdate for {}", key1);
|
||||||
@@ -769,10 +733,8 @@ public class TipWlanOvsdbClient implements OvsdbClientInterface {
|
|||||||
}
|
}
|
||||||
|
|
||||||
private void monitorAPCStateTable(OvsdbClient ovsdbClient, String key) throws OvsdbClientException {
|
private void monitorAPCStateTable(OvsdbClient ovsdbClient, String key) throws OvsdbClientException {
|
||||||
CompletableFuture<TableUpdates> nsCf = ovsdbClient.monitor(
|
CompletableFuture<TableUpdates> nsCf = ovsdbClient.monitor(OvsdbDao.ovsdbName, OvsdbDao.apcStateDbTable + "_" + key,
|
||||||
OvsdbDao.ovsdbName, OvsdbDao.apcStateDbTable + "_" + key, new MonitorRequests(ImmutableMap
|
new MonitorRequests(ImmutableMap.of(OvsdbDao.apcStateDbTable, new MonitorRequest(new MonitorSelect(true, true, true, true)))), tableUpdates -> {
|
||||||
.of(OvsdbDao.apcStateDbTable, new MonitorRequest(new MonitorSelect(true, false, false, true)))),
|
|
||||||
tableUpdates -> {
|
|
||||||
LOG.info(OvsdbDao.apcStateDbTable + "_" + key + " monitor callback received {}");
|
LOG.info(OvsdbDao.apcStateDbTable + "_" + key + " monitor callback received {}");
|
||||||
tableUpdates.getTableUpdates().forEach((key1, value) -> {
|
tableUpdates.getTableUpdates().forEach((key1, value) -> {
|
||||||
LOG.info("TableUpdate for {}", key1);
|
LOG.info("TableUpdate for {}", key1);
|
||||||
@@ -780,14 +742,19 @@ public class TipWlanOvsdbClient implements OvsdbClientInterface {
|
|||||||
|
|
||||||
Map<String, String> apcStateAttributes = ovsdbDao.getAPCState(r, key);
|
Map<String, String> apcStateAttributes = ovsdbDao.getAPCState(r, key);
|
||||||
|
|
||||||
extIntegrationInterface.apcStateDbTableUpdate(apcStateAttributes, key,
|
extIntegrationInterface.apcStateDbTableUpdate(apcStateAttributes, key, RowUpdateOperation.MODIFY);
|
||||||
RowUpdateOperation.MODIFY);
|
|
||||||
|
|
||||||
});
|
});
|
||||||
|
|
||||||
});
|
});
|
||||||
});
|
});
|
||||||
nsCf.join();
|
try {
|
||||||
|
extIntegrationInterface.apcStateDbTableUpdate(
|
||||||
|
ovsdbDao.getAPCState(nsCf.join().getTableUpdates().entrySet().iterator().next().getValue().getRowUpdates().values().iterator().next(), key),
|
||||||
|
key, RowUpdateOperation.INIT);
|
||||||
|
} catch (Exception e) {
|
||||||
|
LOG.error("Could not get INIT state for {}", OvsdbDao.apcStateDbTable, e);
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
@@ -837,8 +804,7 @@ public class TipWlanOvsdbClient implements OvsdbClientInterface {
|
|||||||
|
|
||||||
@Override
|
@Override
|
||||||
public String startDebugEngine(String apId, String gatewayHostname, Integer gatewayPort) {
|
public String startDebugEngine(String apId, String gatewayHostname, Integer gatewayPort) {
|
||||||
LOG.debug("TipWlanOvsdbClient::startDebugEngine apId {} gatewayHostname {} gatewayPort {}", apId,
|
LOG.debug("TipWlanOvsdbClient::startDebugEngine apId {} gatewayHostname {} gatewayPort {}", apId, gatewayHostname, gatewayPort);
|
||||||
gatewayHostname, gatewayPort);
|
|
||||||
|
|
||||||
try {
|
try {
|
||||||
OvsdbSession session = ovsdbSessionMapInterface.getSession(apId);
|
OvsdbSession session = ovsdbSessionMapInterface.getSession(apId);
|
||||||
@@ -846,17 +812,14 @@ public class TipWlanOvsdbClient implements OvsdbClientInterface {
|
|||||||
Map<String, String> payload = new HashMap<>();
|
Map<String, String> payload = new HashMap<>();
|
||||||
payload.put("gateway_hostname", gatewayHostname);
|
payload.put("gateway_hostname", gatewayHostname);
|
||||||
payload.put("gateway_port", gatewayPort.toString());
|
payload.put("gateway_port", gatewayPort.toString());
|
||||||
ovsdbDao.configureCommands(ovsdbClient, OvsdbDao.StartDebugEngineApCommand, payload, 0L,
|
ovsdbDao.configureCommands(ovsdbClient, OvsdbDao.StartDebugEngineApCommand, payload, 0L, defaultCommandDurationSec);
|
||||||
defaultCommandDurationSec);
|
|
||||||
|
|
||||||
LOG.debug("Started debug engine on AP {} with gateway {} port {}", apId, gatewayHostname, gatewayPort);
|
LOG.debug("Started debug engine on AP {} with gateway {} port {}", apId, gatewayHostname, gatewayPort);
|
||||||
return "Started debug engine on AP " + apId + " with gateway " + gatewayHostname + " port " + gatewayPort;
|
return "Started debug engine on AP " + apId + " with gateway " + gatewayHostname + " port " + gatewayPort;
|
||||||
} catch (Exception e) {
|
} catch (Exception e) {
|
||||||
LOG.error(
|
LOG.error("TipWlanOvsdbClient::startDebugEngine Failed to start debug engine on AP {} with gateway {} port {}", apId, gatewayHostname, gatewayPort,
|
||||||
"TipWlanOvsdbClient::startDebugEngine Failed to start debug engine on AP {} with gateway {} port {}",
|
e);
|
||||||
apId, gatewayHostname, gatewayPort, e);
|
return "Failed to start debug engine on AP " + apId + " with gateway " + gatewayHostname + " port " + gatewayPort;
|
||||||
return "Failed to start debug engine on AP " + apId + " with gateway " + gatewayHostname + " port "
|
|
||||||
+ gatewayPort;
|
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
@@ -901,8 +864,7 @@ public class TipWlanOvsdbClient implements OvsdbClientInterface {
|
|||||||
}
|
}
|
||||||
} catch (Exception e) {
|
} catch (Exception e) {
|
||||||
if (switchBanks) {
|
if (switchBanks) {
|
||||||
LOG.debug("TipWlanOvsdbClient::processRebootRequest failed to trigger switch software bank on AP {}",
|
LOG.debug("TipWlanOvsdbClient::processRebootRequest failed to trigger switch software bank on AP {}", apId, e);
|
||||||
apId, e);
|
|
||||||
return "failed to trigger switch software bank on AP " + apId;
|
return "failed to trigger switch software bank on AP " + apId;
|
||||||
} else {
|
} else {
|
||||||
LOG.error("TipWlanOvsdbClient::processRebootRequest failed to trigger reboot of AP {}", apId, e);
|
LOG.error("TipWlanOvsdbClient::processRebootRequest failed to trigger reboot of AP {}", apId, e);
|
||||||
@@ -948,25 +910,21 @@ public class TipWlanOvsdbClient implements OvsdbClientInterface {
|
|||||||
return key;
|
return key;
|
||||||
}
|
}
|
||||||
|
|
||||||
public String processNewChannelsRequest(String apId, Map<RadioType, Integer> backupChannelMap,
|
public String processNewChannelsRequest(String apId, Map<RadioType, Integer> backupChannelMap, Map<RadioType, Integer> primaryChannelMap) {
|
||||||
Map<RadioType, Integer> primaryChannelMap) {
|
|
||||||
LOG.info("TipWlanOvsdbClient::processNewChannelsRequest for AP {}", apId);
|
LOG.info("TipWlanOvsdbClient::processNewChannelsRequest for AP {}", apId);
|
||||||
|
|
||||||
try {
|
try {
|
||||||
OvsdbSession session = ovsdbSessionMapInterface.getSession(apId);
|
OvsdbSession session = ovsdbSessionMapInterface.getSession(apId);
|
||||||
OvsdbClient ovsdbClient = session.getOvsdbClient();
|
OvsdbClient ovsdbClient = session.getOvsdbClient();
|
||||||
ovsdbDao.processNewChannelsRequest(ovsdbClient, backupChannelMap, primaryChannelMap);
|
ovsdbDao.processNewChannelsRequest(ovsdbClient, backupChannelMap, primaryChannelMap);
|
||||||
LOG.info("TipWlanOvsdbClient::processNewChannelsRequest change backup and/or primary channels for AP {}",
|
LOG.info("TipWlanOvsdbClient::processNewChannelsRequest change backup and/or primary channels for AP {}", apId);
|
||||||
apId);
|
|
||||||
return " change backup and/or primary channels for AP " + apId;
|
return " change backup and/or primary channels for AP " + apId;
|
||||||
} catch (Exception e) {
|
} catch (Exception e) {
|
||||||
LOG.error(
|
LOG.error("TipWlanOvsdbClient::processNewChannelsRequest failed to change backup and/or primary channels for AP {}", apId, e);
|
||||||
"TipWlanOvsdbClient::processNewChannelsRequest failed to change backup and/or primary channels for AP {}",
|
|
||||||
apId, e);
|
|
||||||
return "failed to change backup and/or primary channels for AP " + apId;
|
return "failed to change backup and/or primary channels for AP " + apId;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
public String processCellSizeAttributesRequest(String apId, Map<RadioType, CellSizeAttributes> cellSizeAttributeMap) {
|
public String processCellSizeAttributesRequest(String apId, Map<RadioType, CellSizeAttributes> cellSizeAttributeMap) {
|
||||||
LOG.info("TipWlanOvsdbClient::processCellSizeAttributesRequest for AP {}", apId);
|
LOG.info("TipWlanOvsdbClient::processCellSizeAttributesRequest for AP {}", apId);
|
||||||
|
|
||||||
@@ -974,13 +932,10 @@ public class TipWlanOvsdbClient implements OvsdbClientInterface {
|
|||||||
OvsdbSession session = ovsdbSessionMapInterface.getSession(apId);
|
OvsdbSession session = ovsdbSessionMapInterface.getSession(apId);
|
||||||
OvsdbClient ovsdbClient = session.getOvsdbClient();
|
OvsdbClient ovsdbClient = session.getOvsdbClient();
|
||||||
ovsdbDao.processCellSizeAttributesRequest(ovsdbClient, cellSizeAttributeMap);
|
ovsdbDao.processCellSizeAttributesRequest(ovsdbClient, cellSizeAttributeMap);
|
||||||
LOG.info("TipWlanOvsdbClient::processCellSizeAttributesRequest change cellSizeAttributes for AP {}",
|
LOG.info("TipWlanOvsdbClient::processCellSizeAttributesRequest change cellSizeAttributes for AP {}", apId);
|
||||||
apId);
|
|
||||||
return " change cell size attributes for AP " + apId;
|
return " change cell size attributes for AP " + apId;
|
||||||
} catch (Exception e) {
|
} catch (Exception e) {
|
||||||
LOG.error(
|
LOG.error("TipWlanOvsdbClient::processCellSizeAttributesRequest failed to change cell size attributes for AP {}", apId, e);
|
||||||
"TipWlanOvsdbClient::processCellSizeAttributesRequest failed to change cell size attributes for AP {}",
|
|
||||||
apId, e);
|
|
||||||
return "failed to change cell size attributes for AP " + apId;
|
return "failed to change cell size attributes for AP " + apId;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|||||||
@@ -237,4 +237,8 @@ public class OvsdbDao extends OvsdbDaoBase {
|
|||||||
ovsdbStats.updateEventReportingInterval(ovsdbClient, collectionIntervalSecEvent);
|
ovsdbStats.updateEventReportingInterval(ovsdbClient, collectionIntervalSecEvent);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
public String processBlinkRequest(OvsdbClient ovsdbClient, String apId, boolean blinkAllLEDs) {
|
||||||
|
return ovsdbNodeConfig.processBlinkRequest(ovsdbClient,apId,blinkAllLEDs);
|
||||||
|
}
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|||||||
@@ -265,7 +265,7 @@ public class OvsdbDaoBase {
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
void fillInRadioInterfaceNames(OvsdbClient ovsdbClient, ConnectNodeInfo ret) {
|
void fillInRadioInterfaceNamesAndCountry(OvsdbClient ovsdbClient, ConnectNodeInfo ret) {
|
||||||
try {
|
try {
|
||||||
List<Operation> operations = new ArrayList<>();
|
List<Operation> operations = new ArrayList<>();
|
||||||
List<Condition> conditions = new ArrayList<>();
|
List<Condition> conditions = new ArrayList<>();
|
||||||
@@ -273,6 +273,7 @@ public class OvsdbDaoBase {
|
|||||||
|
|
||||||
columns.add("freq_band");
|
columns.add("freq_band");
|
||||||
columns.add("if_name");
|
columns.add("if_name");
|
||||||
|
columns.add("country");
|
||||||
|
|
||||||
operations.add(new Select(wifiRadioStateDbTable, conditions, columns));
|
operations.add(new Select(wifiRadioStateDbTable, conditions, columns));
|
||||||
CompletableFuture<OperationResult[]> fResult = ovsdbClient.transact(ovsdbName, operations);
|
CompletableFuture<OperationResult[]> fResult = ovsdbClient.transact(ovsdbName, operations);
|
||||||
@@ -292,6 +293,7 @@ public class OvsdbDaoBase {
|
|||||||
for (Row row : ((SelectResult) result[0]).getRows()) {
|
for (Row row : ((SelectResult) result[0]).getRows()) {
|
||||||
ret.wifiRadioStates.put(getSingleValueFromSet(row, "freq_band"),
|
ret.wifiRadioStates.put(getSingleValueFromSet(row, "freq_band"),
|
||||||
getSingleValueFromSet(row, "if_name"));
|
getSingleValueFromSet(row, "if_name"));
|
||||||
|
ret.country = getSingleValueFromSet(row, "country");
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|||||||
@@ -238,7 +238,7 @@ public class OvsdbNode extends OvsdbDaoBase {
|
|||||||
}
|
}
|
||||||
fillInLanIpAddressAndMac(ovsdbClient, ret, defaultLanInterfaceType);
|
fillInLanIpAddressAndMac(ovsdbClient, ret, defaultLanInterfaceType);
|
||||||
|
|
||||||
fillInRadioInterfaceNames(ovsdbClient, ret);
|
fillInRadioInterfaceNamesAndCountry(ovsdbClient, ret);
|
||||||
|
|
||||||
} catch (OvsdbClientException | TimeoutException | ExecutionException | InterruptedException e) {
|
} catch (OvsdbClientException | TimeoutException | ExecutionException | InterruptedException e) {
|
||||||
throw new RuntimeException(e);
|
throw new RuntimeException(e);
|
||||||
|
|||||||
@@ -25,6 +25,7 @@ import com.vmware.ovsdb.protocol.operation.notation.Condition;
|
|||||||
import com.vmware.ovsdb.protocol.operation.notation.Function;
|
import com.vmware.ovsdb.protocol.operation.notation.Function;
|
||||||
import com.vmware.ovsdb.protocol.operation.notation.Row;
|
import com.vmware.ovsdb.protocol.operation.notation.Row;
|
||||||
import com.vmware.ovsdb.protocol.operation.notation.Value;
|
import com.vmware.ovsdb.protocol.operation.notation.Value;
|
||||||
|
import com.vmware.ovsdb.protocol.operation.result.InsertResult;
|
||||||
import com.vmware.ovsdb.protocol.operation.result.OperationResult;
|
import com.vmware.ovsdb.protocol.operation.result.OperationResult;
|
||||||
import com.vmware.ovsdb.protocol.operation.result.UpdateResult;
|
import com.vmware.ovsdb.protocol.operation.result.UpdateResult;
|
||||||
import com.vmware.ovsdb.service.OvsdbClient;
|
import com.vmware.ovsdb.service.OvsdbClient;
|
||||||
@@ -59,18 +60,17 @@ public class OvsdbNodeConfig extends OvsdbDaoBase {
|
|||||||
|
|
||||||
public void configureSyslog(OvsdbClient ovsdbClient, OpensyncAPConfig opensyncAPConfig) {
|
public void configureSyslog(OvsdbClient ovsdbClient, OpensyncAPConfig opensyncAPConfig) {
|
||||||
// /usr/opensync/tools/ovsh insert Node_Config module:="syslog" key:="remote" value:="udp:192.168.178.9:1000:4"
|
// /usr/opensync/tools/ovsh insert Node_Config module:="syslog" key:="remote" value:="udp:192.168.178.9:1000:4"
|
||||||
// The format is a colon delimited list. log_proto:log_ip:log_port:log_priority
|
// The format is a colon delimited list. log_proto:log_ip:log_port:log_priority
|
||||||
try {
|
try {
|
||||||
ApNetworkConfiguration apNetworkConfig = (ApNetworkConfiguration) opensyncAPConfig.getApProfile().getDetails();
|
ApNetworkConfiguration apNetworkConfig = (ApNetworkConfiguration) opensyncAPConfig.getApProfile().getDetails();
|
||||||
if (apNetworkConfig.getSyslogRelay() == null ) {
|
if (apNetworkConfig.getSyslogRelay() == null) {
|
||||||
LOG.info("Cannot configure syslog to null value. {}", apNetworkConfig);
|
LOG.info("Cannot configure syslog to null value. {}", apNetworkConfig);
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
|
|
||||||
if (apNetworkConfig.getSyslogRelay().isEnabled()) {
|
if (apNetworkConfig.getSyslogRelay().isEnabled()) {
|
||||||
|
|
||||||
if (apNetworkConfig.getSyslogRelay().getSrvHostIp() == null
|
if (apNetworkConfig.getSyslogRelay().getSrvHostIp() == null || apNetworkConfig.getSyslogRelay().getSeverity() == null) {
|
||||||
|| apNetworkConfig.getSyslogRelay().getSeverity() == null) {
|
|
||||||
LOG.info("Cannot configure syslog remote_logging without SrvHostIp and Severity values. {}", apNetworkConfig);
|
LOG.info("Cannot configure syslog remote_logging without SrvHostIp and Severity values. {}", apNetworkConfig);
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
@@ -78,8 +78,8 @@ public class OvsdbNodeConfig extends OvsdbDaoBase {
|
|||||||
Map<String, Value> columns = new HashMap<>();
|
Map<String, Value> columns = new HashMap<>();
|
||||||
columns.put("key", new Atom<>("remote"));
|
columns.put("key", new Atom<>("remote"));
|
||||||
columns.put("module", new Atom<>("syslog"));
|
columns.put("module", new Atom<>("syslog"));
|
||||||
String delimitedValue = "udp:" + apNetworkConfig.getSyslogRelay().getSrvHostIp().getHostAddress() + ":" + String
|
String delimitedValue = "udp:" + apNetworkConfig.getSyslogRelay().getSrvHostIp().getHostAddress() + ":" + String.valueOf(
|
||||||
.valueOf(apNetworkConfig.getSyslogRelay().getSrvHostPort() + ":" +String.valueOf(apNetworkConfig.getSyslogRelay().getSeverity().getId()));
|
apNetworkConfig.getSyslogRelay().getSrvHostPort() + ":" + String.valueOf(apNetworkConfig.getSyslogRelay().getSeverity().getId()));
|
||||||
columns.put("value", new Atom<>(delimitedValue));
|
columns.put("value", new Atom<>(delimitedValue));
|
||||||
List<Operation> operations = new ArrayList<>();
|
List<Operation> operations = new ArrayList<>();
|
||||||
operations.add(new Update(nodeConfigTable, List.of(new Condition("module", Function.EQUALS, new Atom<>("syslog"))), new Row(columns)));
|
operations.add(new Update(nodeConfigTable, List.of(new Condition("module", Function.EQUALS, new Atom<>("syslog"))), new Row(columns)));
|
||||||
@@ -119,4 +119,52 @@ public class OvsdbNodeConfig extends OvsdbDaoBase {
|
|||||||
}
|
}
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|
||||||
|
public String processBlinkRequest(OvsdbClient ovsdbClient, String apId, boolean blinkAllLEDs) {
|
||||||
|
|
||||||
|
String ret = null;
|
||||||
|
try {
|
||||||
|
|
||||||
|
LOG.debug("processBlinkRequest set BlinkLEDs to {}", blinkAllLEDs);
|
||||||
|
Map<String, Value> columns = new HashMap<>();
|
||||||
|
if (blinkAllLEDs) {
|
||||||
|
columns.put("module", new Atom<>("led"));
|
||||||
|
columns.put("key", new Atom<>("led_blink"));
|
||||||
|
columns.put("value", new Atom<>("on"));
|
||||||
|
} else {
|
||||||
|
columns.put("module", new Atom<>("led"));
|
||||||
|
columns.put("key", new Atom<>("led_off"));
|
||||||
|
columns.put("value", new Atom<>("off"));
|
||||||
|
}
|
||||||
|
List<Operation> operations = new ArrayList<>();
|
||||||
|
operations.add(new Update(nodeConfigTable, List.of(new Condition("module", Function.EQUALS, new Atom<>("led"))), new Row(columns)));
|
||||||
|
CompletableFuture<OperationResult[]> fResult = ovsdbClient.transact(ovsdbName, operations);
|
||||||
|
OperationResult[] result = fResult.get(ovsdbTimeoutSec, TimeUnit.SECONDS);
|
||||||
|
long numUpdates = 0;
|
||||||
|
for (OperationResult res : result) {
|
||||||
|
if (res instanceof UpdateResult) {
|
||||||
|
numUpdates += ((UpdateResult) res).getCount();
|
||||||
|
LOG.debug("processBlinkRequest update result {}", res);
|
||||||
|
ret = "processBlinkRequest update result " + res;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
if (numUpdates == 0) {
|
||||||
|
// no records existed, insert the row instead
|
||||||
|
operations.clear();
|
||||||
|
operations.add(new Insert(nodeConfigTable, new Row(columns)));
|
||||||
|
fResult = ovsdbClient.transact(ovsdbName, operations);
|
||||||
|
result = fResult.get(ovsdbTimeoutSec, TimeUnit.SECONDS);
|
||||||
|
for (OperationResult res : result) {
|
||||||
|
if (res instanceof InsertResult) {
|
||||||
|
LOG.debug("processBlinkRequest insert result {}", res);
|
||||||
|
ret = "processBlinkRequest insert result " + res;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
return ret;
|
||||||
|
} catch (OvsdbClientException | InterruptedException | ExecutionException | TimeoutException e) {
|
||||||
|
throw new RuntimeException(e);
|
||||||
|
}
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|||||||
@@ -1,8 +1,8 @@
|
|||||||
|
|
||||||
package com.telecominfraproject.wlan.opensync.ovsdb.dao;
|
package com.telecominfraproject.wlan.opensync.ovsdb.dao;
|
||||||
|
|
||||||
import com.telecominfraproject.wlan.core.model.equipment.ChannelBandwidth;
|
import com.telecominfraproject.wlan.core.model.equipment.ChannelBandwidth;
|
||||||
import com.telecominfraproject.wlan.core.model.equipment.RadioType;
|
import com.telecominfraproject.wlan.core.model.equipment.RadioType;
|
||||||
import com.telecominfraproject.wlan.core.model.equipment.SourceType;
|
|
||||||
import com.telecominfraproject.wlan.equipment.models.*;
|
import com.telecominfraproject.wlan.equipment.models.*;
|
||||||
import com.telecominfraproject.wlan.opensync.external.integration.models.OpensyncAPConfig;
|
import com.telecominfraproject.wlan.opensync.external.integration.models.OpensyncAPConfig;
|
||||||
import com.telecominfraproject.wlan.opensync.ovsdb.dao.models.WifiRadioConfigInfo;
|
import com.telecominfraproject.wlan.opensync.ovsdb.dao.models.WifiRadioConfigInfo;
|
||||||
@@ -34,8 +34,7 @@ public class OvsdbRadioConfig extends OvsdbDaoBase {
|
|||||||
|
|
||||||
void configureWifiRadios(OvsdbClient ovsdbClient, OpensyncAPConfig opensyncAPConfig) {
|
void configureWifiRadios(OvsdbClient ovsdbClient, OpensyncAPConfig opensyncAPConfig) {
|
||||||
String country = opensyncAPConfig.getCountryCode(); // should be the
|
String country = opensyncAPConfig.getCountryCode(); // should be the
|
||||||
ApElementConfiguration apElementConfiguration = (ApElementConfiguration) opensyncAPConfig.getCustomerEquipment()
|
ApElementConfiguration apElementConfiguration = (ApElementConfiguration) opensyncAPConfig.getCustomerEquipment().getDetails();
|
||||||
.getDetails();
|
|
||||||
RfConfiguration rfConfig = (RfConfiguration) opensyncAPConfig.getRfProfile().getDetails();
|
RfConfiguration rfConfig = (RfConfiguration) opensyncAPConfig.getRfProfile().getDetails();
|
||||||
Map<String, WifiRadioConfigInfo> provisionedRadioConfigs = ovsdbGet.getProvisionedWifiRadioConfigs(ovsdbClient);
|
Map<String, WifiRadioConfigInfo> provisionedRadioConfigs = ovsdbGet.getProvisionedWifiRadioConfigs(ovsdbClient);
|
||||||
Map<String, WifiVifConfigInfo> vifConfigs = ovsdbGet.getProvisionedWifiVifConfigs(ovsdbClient);
|
Map<String, WifiVifConfigInfo> vifConfigs = ovsdbGet.getProvisionedWifiVifConfigs(ovsdbClient);
|
||||||
@@ -44,20 +43,26 @@ public class OvsdbRadioConfig extends OvsdbDaoBase {
|
|||||||
Map<String, String> hwConfig = new HashMap<>();
|
Map<String, String> hwConfig = new HashMap<>();
|
||||||
ElementRadioConfiguration elementRadioConfig = apElementConfiguration.getRadioMap().get(radioType);
|
ElementRadioConfiguration elementRadioConfig = apElementConfiguration.getRadioMap().get(radioType);
|
||||||
RfElementConfiguration rfElementConfig = rfConfig.getRfConfig(radioType);
|
RfElementConfiguration rfElementConfig = rfConfig.getRfConfig(radioType);
|
||||||
|
if (elementRadioConfig == null || rfElementConfig == null) {
|
||||||
|
continue;
|
||||||
|
}
|
||||||
boolean autoChannelSelection = rfElementConfig.getAutoChannelSelection();
|
boolean autoChannelSelection = rfElementConfig.getAutoChannelSelection();
|
||||||
int channel = elementRadioConfig.getActiveChannel(autoChannelSelection);
|
int channel = elementRadioConfig.getActiveChannel(autoChannelSelection);
|
||||||
LOG.debug("configureWifiRadios autoChannelSelection {} activeChannel {} getChannelNumber {} ",
|
LOG.debug("configureWifiRadios autoChannelSelection {} activeChannel {} getChannelNumber {} ", autoChannelSelection, channel,
|
||||||
autoChannelSelection, channel, elementRadioConfig.getChannelNumber());
|
elementRadioConfig.getChannelNumber());
|
||||||
ChannelBandwidth bandwidth = rfElementConfig.getChannelBandwidth();
|
ChannelBandwidth bandwidth = rfElementConfig.getChannelBandwidth();
|
||||||
String ht_mode = getBandwidth(bandwidth);
|
String ht_mode = getBandwidth(bandwidth);
|
||||||
RadioConfiguration radioConfig = apElementConfiguration.getAdvancedRadioMap().get(radioType);
|
RadioConfiguration radioConfig = apElementConfiguration.getAdvancedRadioMap().get(radioType);
|
||||||
int beaconInterval = rfElementConfig.getBeaconInterval();
|
int beaconInterval = rfElementConfig.getBeaconInterval();
|
||||||
boolean enabled = radioConfig.getRadioAdminState().equals(StateSetting.enabled);
|
boolean enabled = radioConfig.getRadioAdminState().equals(StateSetting.enabled);
|
||||||
int txPower;
|
boolean autoCellSizeSelection = rfElementConfig.getAutoCellSizeSelection();
|
||||||
if (elementRadioConfig.getEirpTxPower().getSource() == SourceType.profile) {
|
int txPower = 0;
|
||||||
txPower = rfElementConfig.getEirpTxPower();
|
if (autoCellSizeSelection) {
|
||||||
|
if (elementRadioConfig.getEirpTxPower() != null) {
|
||||||
|
txPower = elementRadioConfig.getEirpTxPower().getValue();
|
||||||
|
}
|
||||||
} else {
|
} else {
|
||||||
txPower = elementRadioConfig.getEirpTxPower().getValue();
|
txPower = rfElementConfig.getEirpTxPower();
|
||||||
}
|
}
|
||||||
String hwMode = getHwMode(rfElementConfig);
|
String hwMode = getHwMode(rfElementConfig);
|
||||||
String freqBand = getHwConfigAndFreq(radioType, hwConfig);
|
String freqBand = getHwConfigAndFreq(radioType, hwConfig);
|
||||||
@@ -68,7 +73,8 @@ public class OvsdbRadioConfig extends OvsdbDaoBase {
|
|||||||
break;
|
break;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
if (radioName == null) continue;
|
if (radioName == null)
|
||||||
|
continue;
|
||||||
String ifName = null; // for vifConfigs
|
String ifName = null; // for vifConfigs
|
||||||
if (radioName.equals(radio0)) {
|
if (radioName.equals(radio0)) {
|
||||||
ifName = defaultRadio0;
|
ifName = defaultRadio0;
|
||||||
@@ -77,7 +83,8 @@ public class OvsdbRadioConfig extends OvsdbDaoBase {
|
|||||||
} else if (radioName.equals(radio2)) {
|
} else if (radioName.equals(radio2)) {
|
||||||
ifName = defaultRadio2;
|
ifName = defaultRadio2;
|
||||||
}
|
}
|
||||||
if (ifName == null) continue;
|
if (ifName == null)
|
||||||
|
continue;
|
||||||
Set<Uuid> vifUuidsForRadio = new HashSet<>();
|
Set<Uuid> vifUuidsForRadio = new HashSet<>();
|
||||||
for (String key : vifConfigs.keySet()) {
|
for (String key : vifConfigs.keySet()) {
|
||||||
if (key.contains(ifName))
|
if (key.contains(ifName))
|
||||||
@@ -86,14 +93,14 @@ public class OvsdbRadioConfig extends OvsdbDaoBase {
|
|||||||
int mimoMode = MimoMode.none.getId();
|
int mimoMode = MimoMode.none.getId();
|
||||||
if (rfElementConfig.getMimoMode() != null) {
|
if (rfElementConfig.getMimoMode() != null) {
|
||||||
mimoMode = rfElementConfig.getMimoMode().getId();
|
mimoMode = rfElementConfig.getMimoMode().getId();
|
||||||
}
|
}
|
||||||
int maxNumClients = 0;
|
int maxNumClients = 0;
|
||||||
if (rfElementConfig.getMaxNumClients() != null) {
|
if (rfElementConfig.getMaxNumClients() != null) {
|
||||||
maxNumClients = rfElementConfig.getMaxNumClients();
|
maxNumClients = rfElementConfig.getMaxNumClients();
|
||||||
}
|
}
|
||||||
try {
|
try {
|
||||||
configureWifiRadios(freqBand, channel, hwConfig, country.toUpperCase(), beaconInterval,
|
configureWifiRadios(freqBand, channel, hwConfig, country.toUpperCase(), beaconInterval, enabled, hwMode, ht_mode, txPower, mimoMode,
|
||||||
enabled, hwMode, ht_mode, txPower, mimoMode, vifUuidsForRadio, operations, maxNumClients);
|
vifUuidsForRadio, operations, maxNumClients);
|
||||||
} catch (OvsdbClientException e) {
|
} catch (OvsdbClientException e) {
|
||||||
LOG.error("ConfigureWifiRadios failed with OvsdbClient exception.", e);
|
LOG.error("ConfigureWifiRadios failed with OvsdbClient exception.", e);
|
||||||
throw new RuntimeException(e);
|
throw new RuntimeException(e);
|
||||||
@@ -115,73 +122,74 @@ public class OvsdbRadioConfig extends OvsdbDaoBase {
|
|||||||
LOG.debug("Op Result {}", res);
|
LOG.debug("Op Result {}", res);
|
||||||
}
|
}
|
||||||
} catch (OvsdbClientException | ExecutionException | InterruptedException | TimeoutException e) {
|
} catch (OvsdbClientException | ExecutionException | InterruptedException | TimeoutException e) {
|
||||||
LOG.error("configureWifiRadios error", e); throw new RuntimeException(e);
|
LOG.error("configureWifiRadios error", e);
|
||||||
|
throw new RuntimeException(e);
|
||||||
}
|
}
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|
||||||
String getHwConfigAndFreq(RadioType radioType, Map<String, String> hwConfig) {
|
String getHwConfigAndFreq(RadioType radioType, Map<String, String> hwConfig) {
|
||||||
switch (radioType) {
|
switch (radioType) {
|
||||||
case is2dot4GHz:
|
case is2dot4GHz:
|
||||||
return "2.4G";
|
return "2.4G";
|
||||||
case is5GHz:
|
case is5GHz:
|
||||||
// 802.11h dfs (Dynamic Frequency Selection) aka military
|
// 802.11h dfs (Dynamic Frequency Selection) aka military
|
||||||
// and
|
// and
|
||||||
// weather radar
|
// weather radar
|
||||||
// avoidance protocol
|
// avoidance protocol
|
||||||
// Must not be disabled (by law)
|
// Must not be disabled (by law)
|
||||||
// NA for 2.4GHz
|
// NA for 2.4GHz
|
||||||
hwConfig.put("dfs_enable", "1");
|
hwConfig.put("dfs_enable", "1");
|
||||||
hwConfig.put("dfs_ignorecac", "0");
|
hwConfig.put("dfs_ignorecac", "0");
|
||||||
hwConfig.put("dfs_usenol", "1");
|
hwConfig.put("dfs_usenol", "1");
|
||||||
return "5G";
|
return "5G";
|
||||||
case is5GHzL:
|
case is5GHzL:
|
||||||
// 802.11h dfs (Dynamic Frequency Selection) aka military
|
// 802.11h dfs (Dynamic Frequency Selection) aka military
|
||||||
// and
|
// and
|
||||||
// weather radar
|
// weather radar
|
||||||
// avoidance protocol
|
// avoidance protocol
|
||||||
// Must not be disabled (by law)
|
// Must not be disabled (by law)
|
||||||
// NA for 2.4GHz
|
// NA for 2.4GHz
|
||||||
hwConfig.put("dfs_enable", "1");
|
hwConfig.put("dfs_enable", "1");
|
||||||
hwConfig.put("dfs_ignorecac", "0");
|
hwConfig.put("dfs_ignorecac", "0");
|
||||||
hwConfig.put("dfs_usenol", "1");
|
hwConfig.put("dfs_usenol", "1");
|
||||||
return "5GL";
|
return "5GL";
|
||||||
case is5GHzU:
|
case is5GHzU:
|
||||||
// 802.11h dfs (Dynamic Frequency Selection) aka military
|
// 802.11h dfs (Dynamic Frequency Selection) aka military
|
||||||
// and
|
// and
|
||||||
// weather radar
|
// weather radar
|
||||||
// avoidance protocol
|
// avoidance protocol
|
||||||
// Must not be disabled (by law)
|
// Must not be disabled (by law)
|
||||||
// NA for 2.4GHz
|
// NA for 2.4GHz
|
||||||
hwConfig.put("dfs_enable", "1");
|
hwConfig.put("dfs_enable", "1");
|
||||||
hwConfig.put("dfs_ignorecac", "0");
|
hwConfig.put("dfs_ignorecac", "0");
|
||||||
hwConfig.put("dfs_usenol", "1");
|
hwConfig.put("dfs_usenol", "1");
|
||||||
return "5GU";
|
return "5GU";
|
||||||
default: // don't know this interface
|
default: // don't know this interface
|
||||||
return null;
|
return null;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
private String getBandwidth(ChannelBandwidth bandwidth) {
|
private String getBandwidth(ChannelBandwidth bandwidth) {
|
||||||
String ht_mode;
|
String ht_mode;
|
||||||
switch (bandwidth) {
|
switch (bandwidth) {
|
||||||
case is20MHz:
|
case is20MHz:
|
||||||
ht_mode = "HT20";
|
ht_mode = "HT20";
|
||||||
break;
|
break;
|
||||||
case is40MHz:
|
case is40MHz:
|
||||||
ht_mode = "HT40";
|
ht_mode = "HT40";
|
||||||
break;
|
break;
|
||||||
case is80MHz:
|
case is80MHz:
|
||||||
ht_mode = "HT80";
|
ht_mode = "HT80";
|
||||||
break;
|
break;
|
||||||
case is160MHz:
|
case is160MHz:
|
||||||
ht_mode = "HT160";
|
ht_mode = "HT160";
|
||||||
break;
|
break;
|
||||||
case auto:
|
case auto:
|
||||||
ht_mode = "0";
|
ht_mode = "0";
|
||||||
break;
|
break;
|
||||||
default:
|
default:
|
||||||
ht_mode = null;
|
ht_mode = null;
|
||||||
}
|
}
|
||||||
return ht_mode;
|
return ht_mode;
|
||||||
}
|
}
|
||||||
@@ -189,43 +197,45 @@ public class OvsdbRadioConfig extends OvsdbDaoBase {
|
|||||||
String getHwMode(RfElementConfiguration rfElementConfig) {
|
String getHwMode(RfElementConfiguration rfElementConfig) {
|
||||||
String hwMode = null;
|
String hwMode = null;
|
||||||
switch (rfElementConfig.getRadioMode()) {
|
switch (rfElementConfig.getRadioMode()) {
|
||||||
case modeA:
|
case modeA:
|
||||||
hwMode = "11a";
|
hwMode = "11a";
|
||||||
break;
|
break;
|
||||||
case modeAB:
|
case modeAB:
|
||||||
hwMode = "11ab";
|
hwMode = "11ab";
|
||||||
break;
|
break;
|
||||||
case modeAC:
|
case modeAC:
|
||||||
hwMode = "11ac";
|
hwMode = "11ac";
|
||||||
break;
|
break;
|
||||||
case modeB:
|
case modeB:
|
||||||
hwMode = "11b";
|
hwMode = "11b";
|
||||||
break;
|
break;
|
||||||
case modeG:
|
case modeG:
|
||||||
hwMode = "11g";
|
hwMode = "11g";
|
||||||
break;
|
break;
|
||||||
case modeAX:
|
case modeAX:
|
||||||
hwMode = "11ax";
|
hwMode = "11ax";
|
||||||
break;
|
break;
|
||||||
case modeN:
|
case modeN:
|
||||||
hwMode = "11n";
|
hwMode = "11n";
|
||||||
break;
|
break;
|
||||||
default:
|
case auto:
|
||||||
|
hwMode = "auto";
|
||||||
|
break;
|
||||||
|
default:
|
||||||
}
|
}
|
||||||
return hwMode;
|
return hwMode;
|
||||||
}
|
}
|
||||||
|
|
||||||
void configureWifiRadios(String freqBand, int channel, Map<String, String> hwConfig,
|
void configureWifiRadios(String freqBand, int channel, Map<String, String> hwConfig, String country, int beaconInterval, boolean enabled, String hwMode,
|
||||||
String country, int beaconInterval, boolean enabled, String hwMode, String ht_mode, int txPower,
|
String ht_mode, int txPower, int mimoMode, Set<Uuid> vifUuidsForRadio, List<Operation> operations, int maxNumClients)
|
||||||
int mimoMode, Set<Uuid> vifUuidsForRadio, List<Operation> operations, int maxNumClients) throws OvsdbClientException, TimeoutException, ExecutionException, InterruptedException {
|
throws OvsdbClientException, TimeoutException, ExecutionException, InterruptedException {
|
||||||
Map<String, Value> updateColumns = new HashMap<>();
|
Map<String, Value> updateColumns = new HashMap<>();
|
||||||
List<Condition> conditions = new ArrayList<>();
|
List<Condition> conditions = new ArrayList<>();
|
||||||
conditions.add(new Condition("freq_band", Function.EQUALS, new Atom<>(freqBand)));
|
conditions.add(new Condition("freq_band", Function.EQUALS, new Atom<>(freqBand)));
|
||||||
updateColumns.put("channel", new Atom<>(channel));
|
updateColumns.put("channel", new Atom<>(channel));
|
||||||
updateColumns.put("country", new Atom<>(country));
|
updateColumns.put("country", new Atom<>(country));
|
||||||
@SuppressWarnings("unchecked")
|
@SuppressWarnings("unchecked")
|
||||||
com.vmware.ovsdb.protocol.operation.notation.Map<String, String> hwConfigMap = com.vmware.ovsdb.protocol.operation.notation.Map
|
com.vmware.ovsdb.protocol.operation.notation.Map<String, String> hwConfigMap = com.vmware.ovsdb.protocol.operation.notation.Map.of(hwConfig);
|
||||||
.of(hwConfig);
|
|
||||||
updateColumns.put("hw_config", hwConfigMap);
|
updateColumns.put("hw_config", hwConfigMap);
|
||||||
updateColumns.put("bcn_int", new Atom<>(beaconInterval));
|
updateColumns.put("bcn_int", new Atom<>(beaconInterval));
|
||||||
updateColumns.put("enabled", new Atom<>(enabled));
|
updateColumns.put("enabled", new Atom<>(enabled));
|
||||||
@@ -245,8 +255,7 @@ public class OvsdbRadioConfig extends OvsdbDaoBase {
|
|||||||
configureCustomOptionsMap(maxNumClients, updateColumns);
|
configureCustomOptionsMap(maxNumClients, updateColumns);
|
||||||
setTxAndRxChainmask(mimoMode, updateColumns);
|
setTxAndRxChainmask(mimoMode, updateColumns);
|
||||||
if (vifUuidsForRadio.size() > 0) {
|
if (vifUuidsForRadio.size() > 0) {
|
||||||
com.vmware.ovsdb.protocol.operation.notation.Set vifConfigUuids = com.vmware.ovsdb.protocol.operation.notation.Set
|
com.vmware.ovsdb.protocol.operation.notation.Set vifConfigUuids = com.vmware.ovsdb.protocol.operation.notation.Set.of(vifUuidsForRadio);
|
||||||
.of(vifUuidsForRadio);
|
|
||||||
updateColumns.put("vif_configs", vifConfigUuids);
|
updateColumns.put("vif_configs", vifConfigUuids);
|
||||||
}
|
}
|
||||||
Row row = new Row(updateColumns);
|
Row row = new Row(updateColumns);
|
||||||
@@ -254,31 +263,58 @@ public class OvsdbRadioConfig extends OvsdbDaoBase {
|
|||||||
}
|
}
|
||||||
|
|
||||||
void configureCustomOptionsMap(int maxNumClients, Map<String, Value> updateColumns) {
|
void configureCustomOptionsMap(int maxNumClients, Map<String, Value> updateColumns) {
|
||||||
Map<String,String> customOptions = new HashMap<>();
|
Map<String, String> customOptions = new HashMap<>();
|
||||||
customOptions.put("max_clients", String.valueOf(maxNumClients));
|
customOptions.put("max_clients", String.valueOf(maxNumClients));
|
||||||
@SuppressWarnings("unchecked")
|
@SuppressWarnings("unchecked")
|
||||||
com.vmware.ovsdb.protocol.operation.notation.Map<String, String> customOptionsMap = com.vmware.ovsdb.protocol.operation.notation.Map
|
com.vmware.ovsdb.protocol.operation.notation.Map<String, String> customOptionsMap = com.vmware.ovsdb.protocol.operation.notation.Map.of(customOptions);
|
||||||
.of(customOptions);
|
updateColumns.put("custom_options", customOptionsMap);
|
||||||
updateColumns.put("custom_options", customOptionsMap);
|
|
||||||
}
|
}
|
||||||
|
|
||||||
void setTxAndRxChainmask(int mimoMode, Map<String, Value> updateColumns) {
|
void setTxAndRxChainmask(int mimoMode, Map<String, Value> updateColumns) {
|
||||||
/*
|
/*
|
||||||
* Chainmask is a bitmask, so map mimo mode values accordingly
|
* Chainmask is a bitmask, so map mimo mode values accordingly
|
||||||
* Note values 0, 1 remain unchanged
|
* Note values 0, 1 remain unchanged
|
||||||
*
|
*
|
||||||
* mimoMode bitmask
|
* mimoMode bitmask
|
||||||
* 0 0
|
* 0 0
|
||||||
* 1 1
|
* 1 1 1
|
||||||
* 2 3
|
* 2 3 2
|
||||||
* 3 7
|
* 3 7 4
|
||||||
* 4 15
|
* 4 15 8
|
||||||
|
* 5 31 16
|
||||||
|
* 6 63 32
|
||||||
|
* 7 127 64
|
||||||
|
* 8 255 128
|
||||||
*/
|
*/
|
||||||
if (mimoMode == 2) {mimoMode = 3;}
|
switch (mimoMode) {
|
||||||
else if (mimoMode == 3) {mimoMode = 7;}
|
case 0: // unchanged
|
||||||
else if (mimoMode == 4) {mimoMode = 15;}
|
break;
|
||||||
|
case 1: // unchanged
|
||||||
|
break;
|
||||||
|
case 2:
|
||||||
|
mimoMode = 3;
|
||||||
|
break;
|
||||||
|
case 3:
|
||||||
|
mimoMode = 7;
|
||||||
|
break;
|
||||||
|
case 4:
|
||||||
|
mimoMode = 15;
|
||||||
|
break;
|
||||||
|
case 5:
|
||||||
|
mimoMode = 31;
|
||||||
|
break;
|
||||||
|
case 6:
|
||||||
|
mimoMode = 63;
|
||||||
|
break;
|
||||||
|
case 7:
|
||||||
|
mimoMode = 127;
|
||||||
|
break;
|
||||||
|
case 8:
|
||||||
|
mimoMode = 255;
|
||||||
|
break;
|
||||||
|
}
|
||||||
updateColumns.put("tx_chainmask", new Atom<>(mimoMode));
|
updateColumns.put("tx_chainmask", new Atom<>(mimoMode));
|
||||||
updateColumns.put("rx_chainmask", new Atom<>(mimoMode));
|
updateColumns.put("rx_chainmask", new Atom<>(mimoMode));
|
||||||
}
|
}
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|||||||
@@ -1,3 +1,4 @@
|
|||||||
|
|
||||||
package com.telecominfraproject.wlan.opensync.ovsdb.dao;
|
package com.telecominfraproject.wlan.opensync.ovsdb.dao;
|
||||||
|
|
||||||
import java.util.ArrayList;
|
import java.util.ArrayList;
|
||||||
@@ -27,6 +28,7 @@ import com.vmware.ovsdb.protocol.operation.notation.Value;
|
|||||||
import com.vmware.ovsdb.protocol.operation.result.ErrorResult;
|
import com.vmware.ovsdb.protocol.operation.result.ErrorResult;
|
||||||
import com.vmware.ovsdb.protocol.operation.result.OperationResult;
|
import com.vmware.ovsdb.protocol.operation.result.OperationResult;
|
||||||
import com.vmware.ovsdb.protocol.operation.result.UpdateResult;
|
import com.vmware.ovsdb.protocol.operation.result.UpdateResult;
|
||||||
|
import com.vmware.ovsdb.protocol.schema.DatabaseSchema;
|
||||||
import com.vmware.ovsdb.service.OvsdbClient;
|
import com.vmware.ovsdb.service.OvsdbClient;
|
||||||
|
|
||||||
@Component
|
@Component
|
||||||
@@ -65,19 +67,78 @@ public class OvsdbRadiusProxyConfig extends OvsdbDaoBase {
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
/*
|
||||||
|
* root@OpenAp-ab1f4d:~# ovsdb-client list-columns Radius_Proxy_Config
|
||||||
|
*
|
||||||
|
* Column Type
|
||||||
|
* ------------------ ---------------------------------------------------------------
|
||||||
|
* realm {"key":{"maxLength":256,"type":"string"},"max":16,"min":0}
|
||||||
|
* radius_config_name "string"
|
||||||
|
* _uuid "uuid"
|
||||||
|
* acct_port {"key":"integer","min":0}
|
||||||
|
* client_key {"key":{"maxLength":256,"minLength":1,"type":"string"},"min":0}
|
||||||
|
* server "string"
|
||||||
|
* _version "uuid"
|
||||||
|
* port "integer"
|
||||||
|
* radsec "boolean"
|
||||||
|
* client_cert {"key":{"maxLength":256,"minLength":1,"type":"string"},"min":0}
|
||||||
|
* acct_server {"key":"string","min":0}
|
||||||
|
* passphrase {"key":{"maxLength":128,"type":"string"},"min":0}
|
||||||
|
* acct_secret {"key":"string","min":0}
|
||||||
|
* ca_cert {"key":{"maxLength":256,"minLength":1,"type":"string"},"min":0}
|
||||||
|
* auto_discover "boolean"
|
||||||
|
* secret "string"
|
||||||
|
*/
|
||||||
private void configureRadiusServers(OvsdbClient ovsdbClient, OpensyncAPConfig apConfig, List<Operation> operations)
|
private void configureRadiusServers(OvsdbClient ovsdbClient, OpensyncAPConfig apConfig, List<Operation> operations)
|
||||||
throws OvsdbClientException, InterruptedException, ExecutionException, TimeoutException {
|
throws OvsdbClientException, InterruptedException, ExecutionException, TimeoutException {
|
||||||
|
|
||||||
for (RadiusProxyConfiguration rsc : ((ApNetworkConfiguration) apConfig.getApProfile().getDetails())
|
// TODO: remove the schema check when AP load available
|
||||||
.getRadiusProxyConfigurations()) {
|
DatabaseSchema databaseSchema = ovsdbClient.getSchema(ovsdbName).get();
|
||||||
|
|
||||||
|
for (RadiusProxyConfiguration rsc : ((ApNetworkConfiguration) apConfig.getApProfile().getDetails()).getRadiusProxyConfigurations()) {
|
||||||
Map<String, Value> updateColumns = new HashMap<>();
|
Map<String, Value> updateColumns = new HashMap<>();
|
||||||
updateColumns.put("server", new Atom<>(rsc.getServer().getHostAddress()));
|
if (rsc.getServer() != null)
|
||||||
getCertificateUrls(rsc, updateColumns);
|
updateColumns.put("server", new Atom<>(rsc.getServer().getHostAddress()));
|
||||||
updateColumns.put("radius_config_name", new Atom<>(rsc.getName()));
|
if (rsc.getName() != null)
|
||||||
updateColumns.put("passphrase", new Atom<>(rsc.getPassphrase()));
|
updateColumns.put("radius_config_name", new Atom<>(rsc.getName()));
|
||||||
updateColumns.put("port", new Atom<>(rsc.getPort()));
|
if (rsc.getPort() != null)
|
||||||
updateColumns.put("realm", Set.of(rsc.getRealm()));
|
updateColumns.put("port", new Atom<>(rsc.getPort()));
|
||||||
updateColumns.put("radsec", new Atom<>(rsc.getUseRadSec()));
|
if (rsc.getRealm() != null)
|
||||||
|
updateColumns.put("realm", Set.of(rsc.getRealm()));
|
||||||
|
if (rsc.getUseRadSec() != null) {
|
||||||
|
updateColumns.put("radsec", new Atom<>(rsc.getUseRadSec()));
|
||||||
|
if (rsc.getUseRadSec()) {
|
||||||
|
getCertificateUrls(rsc, updateColumns);
|
||||||
|
updateColumns.put("passphrase", new Atom<>(rsc.getPassphrase()));
|
||||||
|
}
|
||||||
|
}
|
||||||
|
if (rsc.getSharedSecret() != null)
|
||||||
|
updateColumns.put("secret", new Atom<>(rsc.getSharedSecret()));
|
||||||
|
if (rsc.getAcctServer() != null) {
|
||||||
|
updateColumns.put("acct_server", new Atom<>(rsc.getAcctServer().getHostAddress()));
|
||||||
|
}
|
||||||
|
if (rsc.getSharedSecret() != null) {
|
||||||
|
updateColumns.put("acct_secret", new Atom<>(rsc.getSharedSecret()));
|
||||||
|
}
|
||||||
|
if (rsc.getAcctPort() != null) {
|
||||||
|
updateColumns.put("acct_port", new Atom<>(rsc.getAcctPort()));
|
||||||
|
}
|
||||||
|
if (databaseSchema.getTables().get(radiusConfigDbTable).getColumns().containsKey("auto_discover")) {
|
||||||
|
if (rsc.getUseRadSec() != null && rsc.getUseRadSec() && rsc.getDynamicDiscovery() != null && rsc.getDynamicDiscovery()) {
|
||||||
|
// if useRadSec && dynamicDiscovery enabled, do not send server information
|
||||||
|
updateColumns.put("auto_discover", new Atom<>(true));
|
||||||
|
updateColumns.remove("acct_server");
|
||||||
|
updateColumns.remove("acct_secret");
|
||||||
|
updateColumns.remove("acct_port");
|
||||||
|
updateColumns.remove("server");
|
||||||
|
updateColumns.remove("port");
|
||||||
|
updateColumns.remove("secret");
|
||||||
|
} else {
|
||||||
|
// if !useRadSec, auto_discover is false regardless of it's desired setting
|
||||||
|
// retain server information
|
||||||
|
updateColumns.put("auto_discover", new Atom<>(false));
|
||||||
|
}
|
||||||
|
}
|
||||||
Row row = new Row(updateColumns);
|
Row row = new Row(updateColumns);
|
||||||
operations.add(new Insert(radiusConfigDbTable, row));
|
operations.add(new Insert(radiusConfigDbTable, row));
|
||||||
}
|
}
|
||||||
@@ -104,7 +165,7 @@ public class OvsdbRadiusProxyConfig extends OvsdbDaoBase {
|
|||||||
}
|
}
|
||||||
if (!caCertFilestoreUrl.contains("filestore")) {
|
if (!caCertFilestoreUrl.contains("filestore")) {
|
||||||
caCertFilestoreUrl = externalFileStoreURL + "/filestore/" + rsc.getCaCert().getApExportUrl();
|
caCertFilestoreUrl = externalFileStoreURL + "/filestore/" + rsc.getCaCert().getApExportUrl();
|
||||||
}
|
}
|
||||||
updateColumns.put("client_cert", new Atom<>(clientCertFilestoreUrl));
|
updateColumns.put("client_cert", new Atom<>(clientCertFilestoreUrl));
|
||||||
updateColumns.put("client_key", new Atom<>(clientKeyFilestoreUrl));
|
updateColumns.put("client_key", new Atom<>(clientKeyFilestoreUrl));
|
||||||
updateColumns.put("ca_cert", new Atom<>(caCertFilestoreUrl));
|
updateColumns.put("ca_cert", new Atom<>(caCertFilestoreUrl));
|
||||||
@@ -124,8 +185,7 @@ public class OvsdbRadiusProxyConfig extends OvsdbDaoBase {
|
|||||||
LOG.info("removeRadiusConfigurations {}", res.toString());
|
LOG.info("removeRadiusConfigurations {}", res.toString());
|
||||||
} else if (res instanceof ErrorResult) {
|
} else if (res instanceof ErrorResult) {
|
||||||
LOG.error("removeRadiusConfigurations error {}", (res));
|
LOG.error("removeRadiusConfigurations error {}", (res));
|
||||||
throw new RuntimeException("removeRadiusConfigurations "
|
throw new RuntimeException("removeRadiusConfigurations " + ((ErrorResult) res).getError() + " " + ((ErrorResult) res).getDetails());
|
||||||
+ ((ErrorResult) res).getError() + " " + ((ErrorResult) res).getDetails());
|
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
LOG.info("Removed all radius and realm configurations");
|
LOG.info("Removed all radius and realm configurations");
|
||||||
|
|||||||
@@ -1,3 +1,4 @@
|
|||||||
|
|
||||||
package com.telecominfraproject.wlan.opensync.ovsdb.dao;
|
package com.telecominfraproject.wlan.opensync.ovsdb.dao;
|
||||||
|
|
||||||
import java.util.ArrayList;
|
import java.util.ArrayList;
|
||||||
@@ -12,6 +13,7 @@ import java.util.concurrent.TimeoutException;
|
|||||||
import org.springframework.stereotype.Component;
|
import org.springframework.stereotype.Component;
|
||||||
|
|
||||||
import com.telecominfraproject.wlan.core.model.equipment.AutoOrManualValue;
|
import com.telecominfraproject.wlan.core.model.equipment.AutoOrManualValue;
|
||||||
|
import com.telecominfraproject.wlan.core.model.equipment.OBSSHopMode;
|
||||||
import com.telecominfraproject.wlan.core.model.equipment.RadioBestApSettings;
|
import com.telecominfraproject.wlan.core.model.equipment.RadioBestApSettings;
|
||||||
import com.telecominfraproject.wlan.core.model.equipment.RadioType;
|
import com.telecominfraproject.wlan.core.model.equipment.RadioType;
|
||||||
import com.telecominfraproject.wlan.core.model.equipment.SourceType;
|
import com.telecominfraproject.wlan.core.model.equipment.SourceType;
|
||||||
@@ -45,8 +47,7 @@ import com.vmware.ovsdb.service.OvsdbClient;
|
|||||||
public class OvsdbRrmConfig extends OvsdbDaoBase {
|
public class OvsdbRrmConfig extends OvsdbDaoBase {
|
||||||
void configureWifiRrm(OvsdbClient ovsdbClient, OpensyncAPConfig opensyncApConfig) {
|
void configureWifiRrm(OvsdbClient ovsdbClient, OpensyncAPConfig opensyncApConfig) {
|
||||||
|
|
||||||
ApElementConfiguration apElementConfig = (ApElementConfiguration) opensyncApConfig.getCustomerEquipment()
|
ApElementConfiguration apElementConfig = (ApElementConfiguration) opensyncApConfig.getCustomerEquipment().getDetails();
|
||||||
.getDetails();
|
|
||||||
RfConfiguration rfConfig = (RfConfiguration) opensyncApConfig.getRfProfile().getDetails();
|
RfConfiguration rfConfig = (RfConfiguration) opensyncApConfig.getRfProfile().getDetails();
|
||||||
for (RadioType radioType : apElementConfig.getRadioMap().keySet()) {
|
for (RadioType radioType : apElementConfig.getRadioMap().keySet()) {
|
||||||
String freqBand = null;
|
String freqBand = null;
|
||||||
@@ -67,28 +68,24 @@ public class OvsdbRrmConfig extends OvsdbDaoBase {
|
|||||||
ElementRadioConfiguration elementRadioConfig = apElementConfig.getRadioMap().get(radioType);
|
ElementRadioConfiguration elementRadioConfig = apElementConfig.getRadioMap().get(radioType);
|
||||||
RfElementConfiguration rfElementConfig = rfConfig.getRfConfig(radioType);
|
RfElementConfiguration rfElementConfig = rfConfig.getRfConfig(radioType);
|
||||||
if (elementRadioConfig == null || rfElementConfig == null) {
|
if (elementRadioConfig == null || rfElementConfig == null) {
|
||||||
continue; // don't have a radio of this kind in the map
|
continue; // don't have a radio of this kind in the map
|
||||||
}
|
}
|
||||||
|
|
||||||
boolean autoChannelSelection = rfElementConfig.getAutoChannelSelection();
|
boolean autoChannelSelection = rfElementConfig.getAutoChannelSelection();
|
||||||
int backupChannel = elementRadioConfig.getActiveBackupChannel(autoChannelSelection);
|
int backupChannel = elementRadioConfig.getActiveBackupChannel(autoChannelSelection);
|
||||||
LOG.debug("configureWifiRadios autoChannelSelection {} activeBackupChannel {}",
|
|
||||||
autoChannelSelection, backupChannel);
|
boolean autoCellSizeSelection = rfElementConfig.getAutoCellSizeSelection();
|
||||||
|
Integer probeResponseThresholdDb = null;
|
||||||
AutoOrManualValue probeResponseThresholdDb = null;
|
Integer clientDisconnectThresholdDb = null;
|
||||||
AutoOrManualValue clientDisconnectThresholdDb = null;
|
|
||||||
|
|
||||||
if (elementRadioConfig.getProbeResponseThresholdDb() != null) {
|
if (elementRadioConfig.getProbeResponseThresholdDb() != null) {
|
||||||
probeResponseThresholdDb = getSourcedValue(elementRadioConfig.getProbeResponseThresholdDb().getSource(),
|
probeResponseThresholdDb = getSourcedValue(autoCellSizeSelection, rfElementConfig.getProbeResponseThresholdDb(),
|
||||||
rfElementConfig.getProbeResponseThresholdDb(),
|
elementRadioConfig.getProbeResponseThresholdDb().getValue());
|
||||||
elementRadioConfig.getProbeResponseThresholdDb().getValue());
|
|
||||||
}
|
}
|
||||||
|
|
||||||
if (elementRadioConfig.getClientDisconnectThresholdDb() != null) {
|
if (elementRadioConfig.getClientDisconnectThresholdDb() != null) {
|
||||||
clientDisconnectThresholdDb = getSourcedValue(
|
clientDisconnectThresholdDb = getSourcedValue(autoCellSizeSelection, rfElementConfig.getClientDisconnectThresholdDb(),
|
||||||
elementRadioConfig.getClientDisconnectThresholdDb().getSource(),
|
elementRadioConfig.getClientDisconnectThresholdDb().getValue());
|
||||||
rfElementConfig.getClientDisconnectThresholdDb(),
|
|
||||||
elementRadioConfig.getClientDisconnectThresholdDb().getValue());
|
|
||||||
}
|
}
|
||||||
|
|
||||||
RadioConfiguration radioConfig = apElementConfig.getAdvancedRadioMap().get(radioType);
|
RadioConfiguration radioConfig = apElementConfig.getAdvancedRadioMap().get(radioType);
|
||||||
@@ -96,29 +93,30 @@ public class OvsdbRrmConfig extends OvsdbDaoBase {
|
|||||||
ManagementRate managementRate = null;
|
ManagementRate managementRate = null;
|
||||||
RadioBestApSettings bestApSettings = null;
|
RadioBestApSettings bestApSettings = null;
|
||||||
if (radioConfig != null) {
|
if (radioConfig != null) {
|
||||||
if (radioConfig.getMulticastRate() != null) {
|
if (radioConfig.getMulticastRate() != null) {
|
||||||
multicastRate = radioConfig.getMulticastRate().getSource() == SourceType.profile
|
multicastRate = autoCellSizeSelection ? radioConfig.getMulticastRate().getValue() : rfElementConfig.getMulticastRate();
|
||||||
? rfElementConfig.getMulticastRate()
|
}
|
||||||
: radioConfig.getMulticastRate().getValue();
|
|
||||||
}
|
if (radioConfig.getManagementRate() != null) {
|
||||||
|
managementRate = autoCellSizeSelection ? radioConfig.getManagementRate().getValue() : rfElementConfig.getManagementRate();
|
||||||
if (radioConfig.getManagementRate() != null) {
|
}
|
||||||
managementRate = radioConfig.getManagementRate().getSource() == SourceType.profile
|
|
||||||
? rfElementConfig.getManagementRate()
|
if (radioConfig.getBestApSettings() != null) {
|
||||||
: radioConfig.getManagementRate().getValue();
|
bestApSettings = radioConfig.getBestApSettings().getSource() == SourceType.profile ? rfElementConfig.getBestApSettings()
|
||||||
}
|
: radioConfig.getBestApSettings().getValue();
|
||||||
|
}
|
||||||
if (radioConfig.getBestApSettings() != null) {
|
|
||||||
bestApSettings = radioConfig.getBestApSettings().getSource() == SourceType.profile
|
|
||||||
? rfElementConfig.getBestApSettings()
|
|
||||||
: radioConfig.getBestApSettings().getValue();
|
|
||||||
}
|
|
||||||
}
|
}
|
||||||
|
|
||||||
|
OBSSHopMode obssHopMode = rfElementConfig.getChannelHopSettings().getObssHopMode();
|
||||||
|
int noiseFloorThresholdInDB = rfElementConfig.getChannelHopSettings().getNoiseFloorThresholdInDB();
|
||||||
|
int noiseFloorThresholdTimeInSeconds = rfElementConfig.getChannelHopSettings().getNoiseFloorThresholdTimeInSeconds();
|
||||||
|
int nonWifiThresholdInPercentage = rfElementConfig.getChannelHopSettings().getNonWifiThresholdInPercentage();
|
||||||
|
int nonWifiThresholdTimeInSeconds = rfElementConfig.getChannelHopSettings().getNonWifiThresholdTimeInSeconds();
|
||||||
if (freqBand != null) {
|
if (freqBand != null) {
|
||||||
try {
|
try {
|
||||||
configureWifiRrm(ovsdbClient, freqBand, backupChannel, probeResponseThresholdDb,
|
configureWifiRrm(ovsdbClient, freqBand, backupChannel, probeResponseThresholdDb, clientDisconnectThresholdDb, managementRate,
|
||||||
clientDisconnectThresholdDb, managementRate, bestApSettings, multicastRate);
|
bestApSettings, multicastRate, obssHopMode, noiseFloorThresholdInDB, noiseFloorThresholdTimeInSeconds, nonWifiThresholdInPercentage,
|
||||||
|
nonWifiThresholdTimeInSeconds);
|
||||||
} catch (OvsdbClientException e) {
|
} catch (OvsdbClientException e) {
|
||||||
LOG.error("configureRrm failed with OvsdbClient exception.", e);
|
LOG.error("configureRrm failed with OvsdbClient exception.", e);
|
||||||
throw new RuntimeException(e);
|
throw new RuntimeException(e);
|
||||||
@@ -135,9 +133,9 @@ public class OvsdbRrmConfig extends OvsdbDaoBase {
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
void configureWifiRrm(OvsdbClient ovsdbClient, String freqBand, int backupChannel,
|
void configureWifiRrm(OvsdbClient ovsdbClient, String freqBand, int backupChannel, Integer probeResponseThreshold, Integer clientDisconnectThreshold,
|
||||||
AutoOrManualValue probeResponseThreshold, AutoOrManualValue clientDisconnectThreshold,
|
ManagementRate managementRate, RadioBestApSettings bestApSettings, MulticastRate multicastRate, OBSSHopMode obssHopMode,
|
||||||
ManagementRate managementRate, RadioBestApSettings bestApSettings, MulticastRate multicastRate)
|
int noiseFloorThresholdInDB, int noiseFloorThresholdTimeInSeconds, int nonWifiThresholdInPercentage, int nonWifiThresholdTimeInSeconds)
|
||||||
throws OvsdbClientException, TimeoutException, ExecutionException, InterruptedException {
|
throws OvsdbClientException, TimeoutException, ExecutionException, InterruptedException {
|
||||||
|
|
||||||
List<Operation> operations = new ArrayList<>();
|
List<Operation> operations = new ArrayList<>();
|
||||||
@@ -149,19 +147,19 @@ public class OvsdbRrmConfig extends OvsdbDaoBase {
|
|||||||
if (multicastRate == null || multicastRate == MulticastRate.auto) {
|
if (multicastRate == null || multicastRate == MulticastRate.auto) {
|
||||||
updateColumns.put("mcast_rate", new Atom<>(0));
|
updateColumns.put("mcast_rate", new Atom<>(0));
|
||||||
} else {
|
} else {
|
||||||
updateColumns.put("mcast_rate", new Atom<>(managementRate.getId()));
|
updateColumns.put("mcast_rate", new Atom<>(multicastRate.getId()));
|
||||||
}
|
}
|
||||||
|
|
||||||
if (probeResponseThreshold == null || probeResponseThreshold.isAuto()) {
|
if (probeResponseThreshold == null) {
|
||||||
updateColumns.put("probe_resp_threshold", new com.vmware.ovsdb.protocol.operation.notation.Set());
|
updateColumns.put("probe_resp_threshold", new com.vmware.ovsdb.protocol.operation.notation.Set());
|
||||||
} else {
|
} else {
|
||||||
updateColumns.put("probe_resp_threshold", new Atom<>(probeResponseThreshold.getValue()));
|
updateColumns.put("probe_resp_threshold", new Atom<>(probeResponseThreshold.intValue()));
|
||||||
}
|
}
|
||||||
|
|
||||||
if (clientDisconnectThreshold == null || clientDisconnectThreshold.isAuto()) {
|
if (clientDisconnectThreshold == null) {
|
||||||
updateColumns.put("client_disconnect_threshold", new com.vmware.ovsdb.protocol.operation.notation.Set());
|
updateColumns.put("client_disconnect_threshold", new com.vmware.ovsdb.protocol.operation.notation.Set());
|
||||||
} else {
|
} else {
|
||||||
updateColumns.put("client_disconnect_threshold", new Atom<>(clientDisconnectThreshold.getValue()));
|
updateColumns.put("client_disconnect_threshold", new Atom<>(clientDisconnectThreshold.intValue()));
|
||||||
}
|
}
|
||||||
|
|
||||||
if (managementRate == null || managementRate == ManagementRate.auto) {
|
if (managementRate == null || managementRate == ManagementRate.auto) {
|
||||||
@@ -186,12 +184,21 @@ public class OvsdbRrmConfig extends OvsdbDaoBase {
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
if (obssHopMode != null) {
|
||||||
|
updateColumns.put("obss_hop_mode", new Atom<>(obssHopMode.equals(OBSSHopMode.NON_WIFI) ? 1 : 2));
|
||||||
|
}
|
||||||
|
updateColumns.put("noise_floor_thresh", new Atom<>(noiseFloorThresholdInDB));
|
||||||
|
updateColumns.put("noise_floor_time", new Atom<>(noiseFloorThresholdTimeInSeconds));
|
||||||
|
updateColumns.put("non_wifi_thresh", new Atom<>(nonWifiThresholdInPercentage));
|
||||||
|
updateColumns.put("non_wifi_time", new Atom<>(nonWifiThresholdTimeInSeconds));
|
||||||
|
|
||||||
|
|
||||||
Row row = new Row(updateColumns);
|
Row row = new Row(updateColumns);
|
||||||
operations.add(new Insert(wifiRrmConfigDbTable, row));
|
operations.add(new Insert(wifiRrmConfigDbTable, row));
|
||||||
|
|
||||||
CompletableFuture<OperationResult[]> fResult = ovsdbClient.transact(ovsdbName, operations);
|
CompletableFuture<OperationResult[]> fResult = ovsdbClient.transact(ovsdbName, operations);
|
||||||
OperationResult[] result = fResult.get(ovsdbTimeoutSec, TimeUnit.SECONDS);
|
OperationResult[] result = fResult.get(ovsdbTimeoutSec, TimeUnit.SECONDS);
|
||||||
|
|
||||||
LOG.debug("Provisioned rrm config with multicastRate {} Mbps for {}", multicastRate, freqBand);
|
LOG.debug("Provisioned rrm config with multicastRate {} Mbps for {}", multicastRate, freqBand);
|
||||||
|
|
||||||
for (OperationResult res : result) {
|
for (OperationResult res : result) {
|
||||||
@@ -217,8 +224,17 @@ public class OvsdbRrmConfig extends OvsdbDaoBase {
|
|||||||
return AutoOrManualValue.createManualInstance(equipmentValue);
|
return AutoOrManualValue.createManualInstance(equipmentValue);
|
||||||
}
|
}
|
||||||
|
|
||||||
void processNewChannelsRequest(OvsdbClient ovsdbClient, Map<RadioType, Integer> backupChannelMap,
|
// For cell size related attributes, the “manual" mode is not supported any more,
|
||||||
Map<RadioType, Integer> primaryChannelMap) {
|
// user can create a new RF profile with desired values to achieve it
|
||||||
|
int getSourcedValue(boolean autoCellSizeSelection, int profileValue, int equipmentValue) {
|
||||||
|
if (autoCellSizeSelection) {
|
||||||
|
return equipmentValue;
|
||||||
|
} else {
|
||||||
|
return profileValue;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
void processNewChannelsRequest(OvsdbClient ovsdbClient, Map<RadioType, Integer> backupChannelMap, Map<RadioType, Integer> primaryChannelMap) {
|
||||||
|
|
||||||
LOG.info("OvsdbDao::processNewChannelsRequest backup {} primary {}", backupChannelMap, primaryChannelMap);
|
LOG.info("OvsdbDao::processNewChannelsRequest backup {} primary {}", backupChannelMap, primaryChannelMap);
|
||||||
try {
|
try {
|
||||||
@@ -260,7 +276,7 @@ public class OvsdbRrmConfig extends OvsdbDaoBase {
|
|||||||
}
|
}
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|
||||||
void processCellSizeAttributesRequest(OvsdbClient ovsdbClient, Map<RadioType, CellSizeAttributes> cellSizeAttributesMap) {
|
void processCellSizeAttributesRequest(OvsdbClient ovsdbClient, Map<RadioType, CellSizeAttributes> cellSizeAttributesMap) {
|
||||||
|
|
||||||
LOG.info("OvsdbDao::processCellSizeAttributesRequest cellSizeAttributes {}", cellSizeAttributesMap);
|
LOG.info("OvsdbDao::processCellSizeAttributesRequest cellSizeAttributes {}", cellSizeAttributesMap);
|
||||||
@@ -272,7 +288,7 @@ public class OvsdbRrmConfig extends OvsdbDaoBase {
|
|||||||
List<Condition> conditions = new ArrayList<>();
|
List<Condition> conditions = new ArrayList<>();
|
||||||
conditions.add(new Condition("freq_band", Function.EQUALS, new Atom<>(freqBand)));
|
conditions.add(new Condition("freq_band", Function.EQUALS, new Atom<>(freqBand)));
|
||||||
Map<String, Value> updateRrmColumns = new HashMap<>();
|
Map<String, Value> updateRrmColumns = new HashMap<>();
|
||||||
|
|
||||||
CellSizeAttributes cellSizeAttributes = c.getValue();
|
CellSizeAttributes cellSizeAttributes = c.getValue();
|
||||||
MulticastRate multicastRate = cellSizeAttributes.getMulticastRate();
|
MulticastRate multicastRate = cellSizeAttributes.getMulticastRate();
|
||||||
if (multicastRate == null || multicastRate == MulticastRate.auto) {
|
if (multicastRate == null || multicastRate == MulticastRate.auto) {
|
||||||
@@ -287,7 +303,7 @@ public class OvsdbRrmConfig extends OvsdbDaoBase {
|
|||||||
} else {
|
} else {
|
||||||
updateRrmColumns.put("probe_resp_threshold", new Atom<>(probeResponseThreshold.intValue()));
|
updateRrmColumns.put("probe_resp_threshold", new Atom<>(probeResponseThreshold.intValue()));
|
||||||
}
|
}
|
||||||
|
|
||||||
Integer clientDisconnectThreshold = cellSizeAttributes.getClientDisconnectThresholdDb();
|
Integer clientDisconnectThreshold = cellSizeAttributes.getClientDisconnectThresholdDb();
|
||||||
if (clientDisconnectThreshold == null) {
|
if (clientDisconnectThreshold == null) {
|
||||||
updateRrmColumns.put("client_disconnect_threshold", new com.vmware.ovsdb.protocol.operation.notation.Set());
|
updateRrmColumns.put("client_disconnect_threshold", new com.vmware.ovsdb.protocol.operation.notation.Set());
|
||||||
@@ -301,13 +317,13 @@ public class OvsdbRrmConfig extends OvsdbDaoBase {
|
|||||||
} else {
|
} else {
|
||||||
updateRrmColumns.put("beacon_rate", new Atom<>(managementRate.getId() * 10));
|
updateRrmColumns.put("beacon_rate", new Atom<>(managementRate.getId() * 10));
|
||||||
}
|
}
|
||||||
|
|
||||||
Row rowRrm = new Row(updateRrmColumns);
|
Row rowRrm = new Row(updateRrmColumns);
|
||||||
operations.add(new Update(wifiRrmConfigDbTable, conditions, rowRrm));
|
operations.add(new Update(wifiRrmConfigDbTable, conditions, rowRrm));
|
||||||
|
|
||||||
Map<String, Value> updateRadioColumns = new HashMap<>();
|
Map<String, Value> updateRadioColumns = new HashMap<>();
|
||||||
Integer txPower = cellSizeAttributes.getEirpTxPowerDb();
|
Integer txPower = cellSizeAttributes.getEirpTxPowerDb();
|
||||||
if (txPower > 0) {
|
if (txPower != null && txPower > 0) {
|
||||||
updateRadioColumns.put("tx_power", new Atom<>(txPower));
|
updateRadioColumns.put("tx_power", new Atom<>(txPower));
|
||||||
} else {
|
} else {
|
||||||
updateRadioColumns.put("tx_power", new com.vmware.ovsdb.protocol.operation.notation.Set());
|
updateRadioColumns.put("tx_power", new com.vmware.ovsdb.protocol.operation.notation.Set());
|
||||||
@@ -321,15 +337,14 @@ public class OvsdbRrmConfig extends OvsdbDaoBase {
|
|||||||
|
|
||||||
for (OperationResult res : result) {
|
for (OperationResult res : result) {
|
||||||
LOG.info("Op Result {}", res);
|
LOG.info("Op Result {}", res);
|
||||||
|
|
||||||
if (res instanceof InsertResult) {
|
if (res instanceof InsertResult) {
|
||||||
LOG.info("processCellSizeAttributesRequest insert new row result {}", (res));
|
LOG.info("processCellSizeAttributesRequest insert new row result {}", (res));
|
||||||
// for insert, make sure it is actually in the table
|
// for insert, make sure it is actually in the table
|
||||||
confirmRowExistsInTable(ovsdbClient, ((InsertResult) res).getUuid(), wifiRrmConfigDbTable);
|
confirmRowExistsInTable(ovsdbClient, ((InsertResult) res).getUuid(), wifiRrmConfigDbTable);
|
||||||
} else if (res instanceof ErrorResult) {
|
} else if (res instanceof ErrorResult) {
|
||||||
LOG.error("processCellSizeAttributesRequest error {}", (res));
|
LOG.error("processCellSizeAttributesRequest error {}", (res));
|
||||||
throw new RuntimeException("processCellSizeAttributesRequest " + ((ErrorResult) res).getError() +
|
throw new RuntimeException("processCellSizeAttributesRequest " + ((ErrorResult) res).getError() + " " + ((ErrorResult) res).getDetails());
|
||||||
" " + ((ErrorResult) res).getDetails());
|
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|||||||
@@ -227,8 +227,9 @@ public class OvsdbSsidConfig extends OvsdbDaoBase {
|
|||||||
customOptions.put("rts_threshold", String.valueOf(rtsCtsThreshold));
|
customOptions.put("rts_threshold", String.valueOf(rtsCtsThreshold));
|
||||||
}
|
}
|
||||||
|
|
||||||
void configureCustomOptionsForUseRadiusProxy(boolean useRadiusProxy, Map<String, String> customOptions) {
|
void configureCustomOptionsForUseRadiusProxyAndHotspot(boolean useRadiusProxy, boolean enableProxyArpForHotspot, Map<String, String> customOptions) {
|
||||||
customOptions.put("radproxy", useRadiusProxy ? "1" : "0");
|
customOptions.put("radproxy", useRadiusProxy ? "1" : "0");
|
||||||
|
customOptions.put("proxy_arp", enableProxyArpForHotspot ? "1" : "0");
|
||||||
}
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
@@ -251,13 +252,14 @@ public class OvsdbSsidConfig extends OvsdbDaoBase {
|
|||||||
* @param updateColumns
|
* @param updateColumns
|
||||||
* @param dynamicVlan
|
* @param dynamicVlan
|
||||||
* @param useRadiusProxy
|
* @param useRadiusProxy
|
||||||
|
* @param enableProxyArpForHotspot TODO
|
||||||
*/
|
*/
|
||||||
void configureCustomOptionsForSsid(OvsdbClient ovsdbClient, boolean enable80211k, boolean enable80211r, boolean rateLimitEnable, int ssidDlLimit,
|
void configureCustomOptionsForSsid(OvsdbClient ovsdbClient, boolean enable80211k, boolean enable80211r, boolean rateLimitEnable, int ssidDlLimit,
|
||||||
int ssidUlLimit, int clientDlLimit, int clientUlLimit, int rtsCtsThreshold, int dtimPeriod, String radiusNasId, String radiusNasIp,
|
int ssidUlLimit, int clientDlLimit, int clientUlLimit, int rtsCtsThreshold, int dtimPeriod, String radiusNasId, String radiusNasIp,
|
||||||
String radiusOperatorName, Map<String, Value> updateColumns, int dynamicVlan, Boolean useRadiusProxy) {
|
String radiusOperatorName, Map<String, Value> updateColumns, int dynamicVlan, Boolean useRadiusProxy, Boolean enableProxyArpForHotspot) {
|
||||||
Map<String, String> customOptions = new HashMap<>();
|
Map<String, String> customOptions = new HashMap<>();
|
||||||
|
|
||||||
configureCustomOptionsForUseRadiusProxy(useRadiusProxy, customOptions);
|
configureCustomOptionsForUseRadiusProxyAndHotspot(useRadiusProxy, enableProxyArpForHotspot, customOptions);
|
||||||
|
|
||||||
configureCustomOptionsForRatesAndLimits(rateLimitEnable, ssidDlLimit, ssidUlLimit, clientDlLimit, clientUlLimit, rtsCtsThreshold, customOptions);
|
configureCustomOptionsForRatesAndLimits(rateLimitEnable, ssidDlLimit, ssidUlLimit, clientDlLimit, clientUlLimit, rtsCtsThreshold, customOptions);
|
||||||
|
|
||||||
@@ -277,7 +279,7 @@ public class OvsdbSsidConfig extends OvsdbDaoBase {
|
|||||||
int keyRefresh, boolean uapsdEnabled, boolean apBridge, NetworkForwardMode networkForwardMode, List<MacAddress> macBlockList,
|
int keyRefresh, boolean uapsdEnabled, boolean apBridge, NetworkForwardMode networkForwardMode, List<MacAddress> macBlockList,
|
||||||
boolean rateLimitEnable, int ssidDlLimit, int ssidUlLimit, int clientDlLimit, int clientUlLimit, int rtsCtsThreshold, int dtimPeriod,
|
boolean rateLimitEnable, int ssidDlLimit, int ssidUlLimit, int clientDlLimit, int clientUlLimit, int rtsCtsThreshold, int dtimPeriod,
|
||||||
Map<String, String> captiveMap, List<String> walledGardenAllowlist, String radiusNasId, String radiusNasIp, String radiusOperatorName,
|
Map<String, String> captiveMap, List<String> walledGardenAllowlist, String radiusNasId, String radiusNasIp, String radiusOperatorName,
|
||||||
String greTunnelName, int dynamicVlan, Boolean useRadiusProxy, List<Operation> operations) {
|
String greTunnelName, int dynamicVlan, Boolean useRadiusProxy, List<Operation> operations, Boolean enableProxyArpForHotspot) {
|
||||||
|
|
||||||
Map<String, Value> updateColumns = new HashMap<>();
|
Map<String, Value> updateColumns = new HashMap<>();
|
||||||
// If we are doing a NAT SSID, no bridge, else yes
|
// If we are doing a NAT SSID, no bridge, else yes
|
||||||
@@ -334,7 +336,7 @@ public class OvsdbSsidConfig extends OvsdbDaoBase {
|
|||||||
com.vmware.ovsdb.protocol.operation.notation.Map<String, String> securityMap = com.vmware.ovsdb.protocol.operation.notation.Map.of(security);
|
com.vmware.ovsdb.protocol.operation.notation.Map<String, String> securityMap = com.vmware.ovsdb.protocol.operation.notation.Map.of(security);
|
||||||
updateColumns.put("security", securityMap);
|
updateColumns.put("security", securityMap);
|
||||||
configureCustomOptionsForSsid(ovsdbClient, enable80211k, enable80211r, rateLimitEnable, ssidDlLimit, ssidUlLimit, clientDlLimit, clientUlLimit,
|
configureCustomOptionsForSsid(ovsdbClient, enable80211k, enable80211r, rateLimitEnable, ssidDlLimit, ssidUlLimit, clientDlLimit, clientUlLimit,
|
||||||
rtsCtsThreshold, dtimPeriod, radiusNasId, radiusNasIp, radiusOperatorName, updateColumns, dynamicVlan, useRadiusProxy);
|
rtsCtsThreshold, dtimPeriod, radiusNasId, radiusNasIp, radiusOperatorName, updateColumns, dynamicVlan, useRadiusProxy, enableProxyArpForHotspot);
|
||||||
updateBlockList(updateColumns, macBlockList);
|
updateBlockList(updateColumns, macBlockList);
|
||||||
Row row = new Row(updateColumns);
|
Row row = new Row(updateColumns);
|
||||||
operations.add(new Insert(wifiVifConfigDbTable, row));
|
operations.add(new Insert(wifiVifConfigDbTable, row));
|
||||||
@@ -443,7 +445,7 @@ public class OvsdbSsidConfig extends OvsdbDaoBase {
|
|||||||
if (radioConfiguration != null) {
|
if (radioConfiguration != null) {
|
||||||
dtimPeriod = radioConfiguration.getDtimPeriod();
|
dtimPeriod = radioConfiguration.getDtimPeriod();
|
||||||
uapsdEnabled = radioConfiguration.getUapsdState() == StateSetting.enabled;
|
uapsdEnabled = radioConfiguration.getUapsdState() == StateSetting.enabled;
|
||||||
apBridge = radioConfiguration.getStationIsolation() == StateSetting.disabled; // stationIsolation
|
if (ssidConfig.getNoLocalSubnets()) apBridge = false; // no local access
|
||||||
}
|
}
|
||||||
|
|
||||||
String minHwMode = "11n"; // min_hw_mode is 11n
|
String minHwMode = "11n"; // min_hw_mode is 11n
|
||||||
@@ -550,11 +552,15 @@ public class OvsdbSsidConfig extends OvsdbDaoBase {
|
|||||||
if (ssidConfig.getUseRadiusProxy() != null) {
|
if (ssidConfig.getUseRadiusProxy() != null) {
|
||||||
useRadiusProxy = ssidConfig.getUseRadiusProxy();
|
useRadiusProxy = ssidConfig.getUseRadiusProxy();
|
||||||
}
|
}
|
||||||
|
boolean enableProxyArpForHotspot = false;
|
||||||
|
if (ssidConfig.getEnableProxyArpForHotspot() != null) {
|
||||||
|
enableProxyArpForHotspot = false;
|
||||||
|
}
|
||||||
try {
|
try {
|
||||||
configureSingleSsid(ovsdbClient, ifName, ssidConfig.getSsid(), ssidBroadcast, security, vlanId, rrmEnabled, enable80211r, mobilityDomain,
|
configureSingleSsid(ovsdbClient, ifName, ssidConfig.getSsid(), ssidBroadcast, security, vlanId, rrmEnabled, enable80211r, mobilityDomain,
|
||||||
enable80211v, enable80211k, minHwMode, enabled, keyRefresh, uapsdEnabled, apBridge, ssidConfig.getForwardMode(), macBlockList,
|
enable80211v, enable80211k, minHwMode, enabled, keyRefresh, uapsdEnabled, apBridge, ssidConfig.getForwardMode(), macBlockList,
|
||||||
rateLimitEnable, ssidDlLimit, ssidUlLimit, clientDlLimit, clientUlLimit, rtsCtsThreshold, dtimPeriod, captiveMap,
|
rateLimitEnable, ssidDlLimit, ssidUlLimit, clientDlLimit, clientUlLimit, rtsCtsThreshold, dtimPeriod, captiveMap,
|
||||||
walledGardenAllowlist, radiusNasId, radiusNasIp, radiusOperName, greTunnelName, dynamicVlan, useRadiusProxy, operations);
|
walledGardenAllowlist, radiusNasId, radiusNasIp, radiusOperName, greTunnelName, dynamicVlan, useRadiusProxy, operations, enableProxyArpForHotspot);
|
||||||
|
|
||||||
networkConfig.configureInetVifInterface(ovsdbClient, ifName, enabled, ssidConfig.getForwardMode(), operations);
|
networkConfig.configureInetVifInterface(ovsdbClient, ifName, enabled, ssidConfig.getForwardMode(), operations);
|
||||||
|
|
||||||
@@ -637,10 +643,8 @@ public class OvsdbSsidConfig extends OvsdbDaoBase {
|
|||||||
if ((ssidConfig.getCaptivePortalId() == profileCaptive.getId()) && (profileCaptive.getDetails() != null)) {
|
if ((ssidConfig.getCaptivePortalId() == profileCaptive.getId()) && (profileCaptive.getDetails() != null)) {
|
||||||
CaptivePortalConfiguration captiveProfileDetails = ((CaptivePortalConfiguration) profileCaptive.getDetails());
|
CaptivePortalConfiguration captiveProfileDetails = ((CaptivePortalConfiguration) profileCaptive.getDetails());
|
||||||
|
|
||||||
// +#define SCHEMA_CONSTS_PAGE_TITLE "page_title"
|
|
||||||
if (captiveProfileDetails.getBrowserTitle() != null) {
|
if (captiveProfileDetails.getBrowserTitle() != null) {
|
||||||
captiveMap.put("session_timeout", String.valueOf(captiveProfileDetails.getSessionTimeoutInMinutes()));
|
captiveMap.put("session_timeout", String.valueOf(captiveProfileDetails.getSessionTimeoutInMinutes()));
|
||||||
captiveMap.put("page_title", captiveProfileDetails.getBrowserTitle());
|
|
||||||
}
|
}
|
||||||
if (captiveProfileDetails.getAuthenticationType().equals(CaptivePortalAuthenticationType.radius)) {
|
if (captiveProfileDetails.getAuthenticationType().equals(CaptivePortalAuthenticationType.radius)) {
|
||||||
Optional<Profile> optional =
|
Optional<Profile> optional =
|
||||||
@@ -757,6 +761,9 @@ public class OvsdbSsidConfig extends OvsdbDaoBase {
|
|||||||
case "wpa3MixedEAP":
|
case "wpa3MixedEAP":
|
||||||
opensyncSecurityMode = "WPA3-EAP";
|
opensyncSecurityMode = "WPA3-EAP";
|
||||||
break;
|
break;
|
||||||
|
case "wpa3OnlyEAP192":
|
||||||
|
opensyncSecurityMode = "WPA3-EAP-192";
|
||||||
|
break;
|
||||||
}
|
}
|
||||||
return opensyncSecurityMode;
|
return opensyncSecurityMode;
|
||||||
}
|
}
|
||||||
@@ -775,15 +782,10 @@ public class OvsdbSsidConfig extends OvsdbDaoBase {
|
|||||||
RadiusProfile profileDetails = ((RadiusProfile) profileRadius.getDetails());
|
RadiusProfile profileDetails = ((RadiusProfile) profileRadius.getDetails());
|
||||||
RadiusServer rServer = profileDetails.getPrimaryRadiusAccountingServer();
|
RadiusServer rServer = profileDetails.getPrimaryRadiusAccountingServer();
|
||||||
if (rServer != null) {
|
if (rServer != null) {
|
||||||
if (ssidConfig.getUseRadiusProxy()) {
|
security.put("radius_acct_ip", rServer.getIpAddress() != null ? rServer.getIpAddress().getHostAddress() : null);
|
||||||
security.put("radius_acct_ip", "127.0.0.1");
|
security.put("radius_acct_port", rServer.getPort() != null ? String.valueOf(rServer.getPort()) : null);
|
||||||
security.put("radius_acct_port", rServer.getPort() != null ? String.valueOf(rServer.getPort()) : null);
|
security.put("radius_acct_secret", rServer.getSecret());
|
||||||
security.put("radius_acct_secret", "secret");
|
|
||||||
} else {
|
|
||||||
security.put("radius_acct_ip", rServer.getIpAddress() != null ? rServer.getIpAddress().getHostAddress() : null);
|
|
||||||
security.put("radius_acct_port", rServer.getPort() != null ? String.valueOf(rServer.getPort()) : null);
|
|
||||||
security.put("radius_acct_secret", rServer.getSecret());
|
|
||||||
}
|
|
||||||
if (ssidConfig.getRadiusAcountingServiceInterval() != null && ssidConfig.getRadiusAcountingServiceInterval() > 0) {
|
if (ssidConfig.getRadiusAcountingServiceInterval() != null && ssidConfig.getRadiusAcountingServiceInterval() > 0) {
|
||||||
// if the value is present, use the
|
// if the value is present, use the
|
||||||
// radius_acct_interval
|
// radius_acct_interval
|
||||||
@@ -816,18 +818,11 @@ public class OvsdbSsidConfig extends OvsdbDaoBase {
|
|||||||
Profile profileRadius = radiusProfileList.get(0);
|
Profile profileRadius = radiusProfileList.get(0);
|
||||||
RadiusProfile profileDetails = ((RadiusProfile) profileRadius.getDetails());
|
RadiusProfile profileDetails = ((RadiusProfile) profileRadius.getDetails());
|
||||||
RadiusServer radiusServer = profileDetails.getPrimaryRadiusAuthServer();
|
RadiusServer radiusServer = profileDetails.getPrimaryRadiusAuthServer();
|
||||||
if (ssidConfig.getUseRadiusProxy()) {
|
security.put("radius_server_ip", radiusServer.getIpAddress() != null ? radiusServer.getIpAddress().getHostAddress() : null);
|
||||||
security.put("radius_server_ip", "127.0.0.1");
|
security.put("radius_server_port", radiusServer.getPort() != null ? String.valueOf(radiusServer.getPort()) : null);
|
||||||
security.put("radius_server_port", radiusServer.getPort() != null ? String.valueOf(radiusServer.getPort()) : null);
|
security.put("radius_server_secret", radiusServer.getSecret());
|
||||||
security.put("radius_server_secret", "secret");
|
|
||||||
} else {
|
|
||||||
security.put("radius_server_ip", radiusServer.getIpAddress() != null ? radiusServer.getIpAddress().getHostAddress() : null);
|
|
||||||
security.put("radius_server_port", radiusServer.getPort() != null ? String.valueOf(radiusServer.getPort()) : null);
|
|
||||||
security.put("radius_server_secret", radiusServer.getSecret());
|
|
||||||
}
|
|
||||||
LOG.info("set Radius server attributes radius_server_ip {} radius_server_port {} radius_server_secret {}", security.get("radius_server_ip"),
|
LOG.info("set Radius server attributes radius_server_ip {} radius_server_port {} radius_server_secret {}", security.get("radius_server_ip"),
|
||||||
security.get("radius_server_port"), security.get("radius_server_secret"));
|
security.get("radius_server_port"), security.get("radius_server_secret"));
|
||||||
|
|
||||||
} else {
|
} else {
|
||||||
LOG.warn("Could not find radius profile {} in {}", ssidConfig.getRadiusServiceId(), opensyncApConfig.getRadiusProfiles());
|
LOG.warn("Could not find radius profile {} in {}", ssidConfig.getRadiusServiceId(), opensyncApConfig.getRadiusProfiles());
|
||||||
}
|
}
|
||||||
@@ -870,28 +865,41 @@ public class OvsdbSsidConfig extends OvsdbDaoBase {
|
|||||||
case "wpa2OnlyEAP":
|
case "wpa2OnlyEAP":
|
||||||
case "wpa2OnlyRadius":
|
case "wpa2OnlyRadius":
|
||||||
security.put("mode", "2");
|
security.put("mode", "2");
|
||||||
getRadiusConfiguration(opensyncApConfig, ssidConfig, security);
|
if (!ssidConfig.getUseRadiusProxy()) {
|
||||||
getRadiusAccountingConfiguration(opensyncApConfig, ssidConfig, security);
|
getRadiusConfiguration(opensyncApConfig, ssidConfig, security);
|
||||||
|
getRadiusAccountingConfiguration(opensyncApConfig, ssidConfig, security);
|
||||||
|
}
|
||||||
break;
|
break;
|
||||||
case "wpa3OnlyEAP":
|
case "wpa3OnlyEAP":
|
||||||
security.put("mode", "3");
|
security.put("mode", "3");
|
||||||
getRadiusConfiguration(opensyncApConfig, ssidConfig, security);
|
if (!ssidConfig.getUseRadiusProxy()) {
|
||||||
getRadiusAccountingConfiguration(opensyncApConfig, ssidConfig, security);
|
getRadiusConfiguration(opensyncApConfig, ssidConfig, security);
|
||||||
|
getRadiusAccountingConfiguration(opensyncApConfig, ssidConfig, security);
|
||||||
|
}
|
||||||
|
break;
|
||||||
|
case "wpa3OnlyEAP192":
|
||||||
|
security.put("mode", "3");
|
||||||
|
if (!ssidConfig.getUseRadiusProxy()) {
|
||||||
|
getRadiusConfiguration(opensyncApConfig, ssidConfig, security);
|
||||||
|
getRadiusAccountingConfiguration(opensyncApConfig, ssidConfig, security);
|
||||||
|
}
|
||||||
break;
|
break;
|
||||||
case "wpa2EAP":
|
case "wpa2EAP":
|
||||||
case "wpa2Radius":
|
case "wpa2Radius":
|
||||||
case "wpa3MixedEAP":
|
case "wpa3MixedEAP":
|
||||||
security.put("mode", "mixed");
|
security.put("mode", "mixed");
|
||||||
getRadiusConfiguration(opensyncApConfig, ssidConfig, security);
|
if (!ssidConfig.getUseRadiusProxy()) {
|
||||||
getRadiusAccountingConfiguration(opensyncApConfig, ssidConfig, security);
|
getRadiusConfiguration(opensyncApConfig, ssidConfig, security);
|
||||||
|
getRadiusAccountingConfiguration(opensyncApConfig, ssidConfig, security);
|
||||||
|
}
|
||||||
break;
|
break;
|
||||||
case "wpaEAP":
|
case "wpaEAP":
|
||||||
case "wpaRadius":
|
case "wpaRadius":
|
||||||
security.put("mode", "1");
|
security.put("mode", "1");
|
||||||
getRadiusConfiguration(opensyncApConfig, ssidConfig, security);
|
if (!ssidConfig.getUseRadiusProxy()) {
|
||||||
getRadiusAccountingConfiguration(opensyncApConfig, ssidConfig, security);
|
getRadiusConfiguration(opensyncApConfig, ssidConfig, security);
|
||||||
|
getRadiusAccountingConfiguration(opensyncApConfig, ssidConfig, security);
|
||||||
|
}
|
||||||
break;
|
break;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|||||||
Reference in New Issue
Block a user