use of org.openmuc.framework.datalogger.spi.DataLoggerService in project OpenMUC by isc-konstanz.
the class DataManager method handleInterruptEvent.
private void handleInterruptEvent() {
if (stopFlag) {
prepareStop();
return;
}
long currentTime = 0;
if (newRootConfigWithoutDefaults != null) {
currentTime = System.currentTimeMillis();
applyConfiguration(newRootConfigWithoutDefaults, currentTime);
newRootConfigWithoutDefaults = null;
newConfigSignal.countDown();
}
synchronized (receivedRecordContainers) {
List<ChannelRecordContainer> recordContainers;
LoggingController loggingController = new LoggingController(activeDataLoggers);
List<ChannelRecordContainerImpl> channelRecordContainerList = new ArrayList<>();
while ((recordContainers = receivedRecordContainers.poll()) != null) {
recordContainers.stream().map(recContainer -> (ChannelRecordContainerImpl) recContainer).filter(containerImpl -> containerImpl.getChannel().getChannelState() == ChannelState.LISTENING || containerImpl.getChannel().getDriverId().equals(DriverOptionsFactory.VIRTUAL)).forEach(containerImpl -> {
containerImpl.getChannel().setNewRecord(containerImpl.getRecord());
if (containerImpl.getChannel().isLoggingEvent())
channelRecordContainerList.add(containerImpl);
});
}
loggingController.deliverLogsToEventBasedLogServices(channelRecordContainerList);
}
synchronized (samplingTaskFinished) {
SamplingTask samplingTask;
while ((samplingTask = samplingTaskFinished.poll()) != null) {
samplingTask.storeValues();
samplingTask.device.taskFinished();
}
}
synchronized (tasksFinished) {
DeviceTask deviceTask;
while ((deviceTask = tasksFinished.poll()) != null) {
deviceTask.device.taskFinished();
}
}
synchronized (newDrivers) {
// Needed to synchronize with getRunningDrivers
synchronized (activeDrivers) {
activeDrivers.putAll(newDrivers);
}
for (Entry<String, DriverService> newDriverEntry : newDrivers.entrySet()) {
String driverId = newDriverEntry.getKey();
logger.info("Registered driver: " + driverId);
DriverConfigImpl driverConfig = rootConfig.driverConfigsById.get(driverId);
if (driverConfig == null) {
continue;
}
driverConfig.activeDriver = newDriverEntry.getValue();
for (DeviceConfigImpl deviceConfig : driverConfig.deviceConfigsById.values()) {
deviceConfig.device.driverRegisteredSignal();
}
}
newDrivers.clear();
}
synchronized (newServers) {
if (!newServers.isEmpty()) {
activeServers.addAll(newServers);
for (ServerService server : newServers) {
logger.info("Registered server: {}", server.getId());
notifyServer(server);
}
newServers.clear();
}
}
synchronized (newDataLoggers) {
if (!newDataLoggers.isEmpty()) {
activeDataLoggers.addAll(newDataLoggers);
for (DataLoggerService dataLogger : newDataLoggers) {
logger.info("Registered data logger: {}", dataLogger.getId());
dataLogger.setChannelsToLog(rootConfig.logChannels);
}
newDataLoggers.clear();
}
}
if (driverToBeRemovedId != null) {
DriverService removedDriver;
synchronized (activeDrivers) {
removedDriver = activeDrivers.remove(driverToBeRemovedId);
}
if (removedDriver == null) {
// drivers was removed before it was added to activeDrivers
newDrivers.remove(driverToBeRemovedId);
driverRemovedSignal.countDown();
} else {
DriverConfigImpl driverConfig = rootConfig.driverConfigsById.get(driverToBeRemovedId);
if (driverConfig != null) {
activeDeviceCountDown = driverConfig.deviceConfigsById.size();
if (activeDeviceCountDown > 0) {
// all devices have to be given a chance to finish their current task and disconnect:
for (DeviceConfigImpl deviceConfig : driverConfig.deviceConfigsById.values()) {
deviceConfig.device.driverDeregisteredSignal();
}
synchronized (driverRemovedSignal) {
if (activeDeviceCountDown == 0) {
driverRemovedSignal.countDown();
}
}
} else {
driverRemovedSignal.countDown();
}
} else {
driverRemovedSignal.countDown();
}
}
driverToBeRemovedId = null;
}
if (serverToBeRemoved != null) {
if (!activeServers.remove(serverToBeRemoved)) {
newServers.remove(serverToBeRemoved);
}
serverToBeRemoved = null;
serverRemovedSignal.countDown();
}
if (dataLoggerToBeRemoved != null) {
if (!activeDataLoggers.remove(dataLoggerToBeRemoved)) {
newDataLoggers.remove(dataLoggerToBeRemoved);
}
dataLoggerToBeRemoved = null;
dataLoggerRemovedSignal.countDown();
}
synchronized (connectionFailures) {
if (currentTime == 0) {
currentTime = System.currentTimeMillis();
}
Device connectionFailureDevice;
while ((connectionFailureDevice = connectionFailures.poll()) != null) {
connectionFailureDevice.connectFailureSignal(currentTime);
}
}
synchronized (connectedDevices) {
if (currentTime == 0) {
currentTime = System.currentTimeMillis();
}
Device connectedDevice;
while ((connectedDevice = connectedDevices.poll()) != null) {
connectedDevice.connectedSignal(currentTime);
}
}
synchronized (newWriteTasks) {
addTasksAndClear(newWriteTasks);
}
synchronized (newReadTasks) {
addTasksAndClear(newReadTasks);
}
synchronized (disconnectedDevices) {
Device connectedDevice;
while ((connectedDevice = disconnectedDevices.poll()) != null) {
connectedDevice.disconnectedSignal();
}
}
}
use of org.openmuc.framework.datalogger.spi.DataLoggerService in project OpenMUC by isc-konstanz.
the class LoggingController method deliverLogsToLogServices.
private void deliverLogsToLogServices(long startTime) {
for (DataLoggerService dataLogger : activeDataLoggers) {
List<LoggingRecord> logContainers = logContainerMap.get(dataLogger.getId());
dataLogger.log(logContainers, startTime);
}
}
use of org.openmuc.framework.datalogger.spi.DataLoggerService in project OpenMUC by isc-konstanz.
the class LoggingController method deliverLogsToEventBasedLogServices.
public void deliverLogsToEventBasedLogServices(List<ChannelRecordContainerImpl> channelRecordContainerList) {
initLoggingRecordMap();
channelRecordContainerList.stream().forEach(channelRecord -> fillLoggingRecordMapWithChannel(channelRecord.getChannel()));
for (DataLoggerService dataLogger : activeDataLoggers) {
List<LoggingRecord> logContainers = logContainerMap.get(dataLogger.getId());
if (!logContainers.isEmpty()) {
dataLogger.logEvent(logContainers, System.currentTimeMillis());
}
}
}
use of org.openmuc.framework.datalogger.spi.DataLoggerService in project OpenMUC by isc-konstanz.
the class DataManager method getDataLogger.
DataLoggerService getDataLogger(String loggerId) throws DataLoggerNotAvailableException {
DataLoggerService dataLogger;
if (loggerId == null || loggerId.isEmpty()) {
dataLogger = activeDataLoggers.peekFirst();
} else {
dataLogger = activeDataLoggers.stream().filter(activeLogger -> activeLogger.getId().equals(loggerId)).findFirst().orElseThrow(() -> {
logger.warn("DataLogger with id " + loggerId + " not found for reading logs!");
return new DataLoggerNotAvailableException();
});
}
logger.debug("Accessing logged values using {}", dataLogger.getId());
return dataLogger;
}
Aggregations