mirror of
https://github.com/Telecominfraproject/wlan-cloud-opensync-controller.git
synced 2025-11-01 11:07:49 +00:00
Compare commits
18 Commits
WIFI-2434
...
hotfix/NET
| Author | SHA1 | Date | |
|---|---|---|---|
|
|
9802ed2a3f | ||
|
|
cfc5caee64 | ||
|
|
b0abd3847a | ||
|
|
71c947427b | ||
|
|
0dc72a6fe4 | ||
|
|
5540d83dd3 | ||
|
|
572f48445c | ||
|
|
4df8bda2b3 | ||
|
|
047ce7f07a | ||
|
|
1264640c33 | ||
|
|
eef372cf0d | ||
|
|
fcccf418dd | ||
|
|
c098cd72b6 | ||
|
|
42ecccee5e | ||
|
|
663340e749 | ||
|
|
01c7f270ad | ||
|
|
91c17a6271 | ||
|
|
92235affee |
@@ -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;
|
||||||
@@ -144,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;
|
||||||
@@ -176,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 {
|
||||||
@@ -288,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) {
|
||||||
@@ -881,6 +888,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());
|
||||||
|
|||||||
@@ -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());
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|||||||
@@ -964,7 +964,10 @@ 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);
|
||||||
|
|
||||||
}
|
}
|
||||||
@@ -1063,7 +1066,12 @@ 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);
|
||||||
|
|
||||||
apNodeMetrics.setRxBytes(radioType, rxBytes);
|
apNodeMetrics.setRxBytes(radioType, rxBytes);
|
||||||
@@ -1123,6 +1131,12 @@ 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);
|
||||||
|
|
||||||
@@ -1283,6 +1297,8 @@ public class MqttStatsPublisher {
|
|||||||
for (NetworkProbe networkProbe : report.getNetworkProbeList()) {
|
for (NetworkProbe networkProbe : report.getNetworkProbeList()) {
|
||||||
|
|
||||||
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()) {
|
||||||
@@ -1397,6 +1413,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)
|
||||||
@@ -1455,7 +1472,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());
|
||||||
}
|
}
|
||||||
|
|
||||||
@@ -1479,10 +1496,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);
|
||||||
@@ -1598,7 +1615,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())
|
||||||
@@ -1631,6 +1648,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;
|
||||||
@@ -1651,7 +1672,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) {
|
||||||
@@ -1679,58 +1700,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);
|
|
||||||
}
|
}
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|
||||||
}
|
}
|
||||||
@@ -1818,8 +1798,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;
|
||||||
|
|||||||
@@ -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);
|
||||||
|
|
||||||
|
|||||||
@@ -287,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) {
|
||||||
|
|||||||
@@ -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);
|
||||||
|
}
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|||||||
@@ -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);
|
||||||
|
}
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|||||||
@@ -218,10 +218,9 @@ public class OvsdbRadioConfig extends OvsdbDaoBase {
|
|||||||
case modeN:
|
case modeN:
|
||||||
hwMode = "11n";
|
hwMode = "11n";
|
||||||
break;
|
break;
|
||||||
// case auto:
|
case auto:
|
||||||
// TODO: enable when AP supports
|
hwMode = "auto";
|
||||||
// hwMode = "auto";
|
break;
|
||||||
// break;
|
|
||||||
default:
|
default:
|
||||||
}
|
}
|
||||||
return hwMode;
|
return hwMode;
|
||||||
|
|||||||
@@ -28,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
|
||||||
@@ -66,24 +67,34 @@ public class OvsdbRadiusProxyConfig extends OvsdbDaoBase {
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
// _version "uuid"
|
/*
|
||||||
// server "string"
|
* root@OpenAp-ab1f4d:~# ovsdb-client list-columns Radius_Proxy_Config
|
||||||
// realm {"key":{"maxLength":256,"type":"string"},"max":16,"min":0}
|
*
|
||||||
// port "integer"
|
* Column Type
|
||||||
// client_cert {"key":{"maxLength":256,"minLength":1,"type":"string"},"min":0}
|
* ------------------ ---------------------------------------------------------------
|
||||||
// radsec "boolean"
|
* realm {"key":{"maxLength":256,"type":"string"},"max":16,"min":0}
|
||||||
// acct_server {"key":"string","min":0}
|
* radius_config_name "string"
|
||||||
// radius_config_name "string"
|
* _uuid "uuid"
|
||||||
// passphrase {"key":{"maxLength":128,"type":"string"},"min":0}
|
* acct_port {"key":"integer","min":0}
|
||||||
// acct_secret {"key":"string","min":0}
|
* client_key {"key":{"maxLength":256,"minLength":1,"type":"string"},"min":0}
|
||||||
// acct_port {"key":"integer","min":0}
|
* server "string"
|
||||||
// _uuid "uuid"
|
* _version "uuid"
|
||||||
// secret "string"
|
* port "integer"
|
||||||
// ca_cert {"key":{"maxLength":256,"minLength":1,"type":"string"},"min":0}
|
* radsec "boolean"
|
||||||
// client_key {"key":{"maxLength":256,"minLength":1,"type":"string"},"min":0}
|
* 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 {
|
||||||
|
|
||||||
|
// TODO: remove the schema check when AP load available
|
||||||
|
DatabaseSchema databaseSchema = ovsdbClient.getSchema(ovsdbName).get();
|
||||||
|
|
||||||
for (RadiusProxyConfiguration rsc : ((ApNetworkConfiguration) apConfig.getApProfile().getDetails()).getRadiusProxyConfigurations()) {
|
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()));
|
updateColumns.put("server", new Atom<>(rsc.getServer().getHostAddress()));
|
||||||
@@ -93,26 +104,34 @@ public class OvsdbRadiusProxyConfig extends OvsdbDaoBase {
|
|||||||
updateColumns.put("port", new Atom<>(rsc.getPort()));
|
updateColumns.put("port", new Atom<>(rsc.getPort()));
|
||||||
updateColumns.put("realm", Set.of(rsc.getRealm()));
|
updateColumns.put("realm", Set.of(rsc.getRealm()));
|
||||||
updateColumns.put("radsec", new Atom<>(rsc.getUseRadSec()));
|
updateColumns.put("radsec", new Atom<>(rsc.getUseRadSec()));
|
||||||
|
updateColumns.put("secret", new Atom<>(rsc.getSharedSecret()));
|
||||||
java.util.Set<String> columnKeys = ovsdbClient.getSchema(ovsdbName).get().getTables().get(radiusConfigDbTable).getColumns().keySet();
|
if (rsc.getAcctServer() != null) {
|
||||||
|
updateColumns.put("acct_server", new Atom<>(rsc.getAcctServer().getHostAddress()));
|
||||||
if (columnKeys.contains("acct_server") && columnKeys.contains("acct_secret") && columnKeys.contains("acct_port") && columnKeys.contains("secret")) {
|
}
|
||||||
|
if (rsc.getSharedSecret() != null) {
|
||||||
if (rsc.getAcctServer() != null) {
|
updateColumns.put("acct_secret", new Atom<>(rsc.getSharedSecret()));
|
||||||
updateColumns.put("acct_server", new Atom<>(rsc.getAcctServer().getHostAddress()));
|
}
|
||||||
|
if (rsc.getAcctPort() != null) {
|
||||||
|
updateColumns.put("acct_port", new Atom<>(rsc.getAcctPort()));
|
||||||
|
}
|
||||||
|
|
||||||
|
if( databaseSchema.getTables().get(radiusConfigDbTable).getColumns().containsKey("auto_discover") ){
|
||||||
|
if (rsc.getUseRadSec() && 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));
|
||||||
}
|
}
|
||||||
|
|
||||||
if (rsc.getSharedSecret() != null) {
|
|
||||||
updateColumns.put("secret", new Atom<>(rsc.getSharedSecret()));
|
|
||||||
updateColumns.put("acct_secret", new Atom<>(rsc.getSharedSecret()));
|
|
||||||
}
|
|
||||||
|
|
||||||
if (rsc.getAcctPort() != null) {
|
|
||||||
updateColumns.put("acct_port", new Atom<>(rsc.getAcctPort()));
|
|
||||||
}
|
|
||||||
|
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|
||||||
Row row = new Row(updateColumns);
|
Row row = new Row(updateColumns);
|
||||||
operations.add(new Insert(radiusConfigDbTable, row));
|
operations.add(new Insert(radiusConfigDbTable, row));
|
||||||
}
|
}
|
||||||
|
|||||||
@@ -781,15 +781,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
|
||||||
@@ -822,18 +817,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());
|
||||||
}
|
}
|
||||||
@@ -876,28 +864,34 @@ 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;
|
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