2018-01-07 14:10:42 +01:00
|
|
|
#!/usr/bin/python
|
|
|
|
|
# -*- coding: utf-8 -*-
|
|
|
|
|
"""!
|
|
|
|
|
____ ____ ______ __ __ __ _____
|
|
|
|
|
/ __ )/ __ \/ ___/ | / /___ _/ /______/ /_ |__ /
|
|
|
|
|
/ __ / / / /\__ \| | /| / / __ `/ __/ ___/ __ \ /_ <
|
|
|
|
|
/ /_/ / /_/ /___/ /| |/ |/ / /_/ / /_/ /__/ / / / ___/ /
|
|
|
|
|
/_____/\____//____/ |__/|__/\__,_/\__/\___/_/ /_/ /____/
|
|
|
|
|
German BOS Information Script
|
|
|
|
|
by Bastian Schroll
|
|
|
|
|
|
|
|
|
|
@file: packet.py
|
|
|
|
|
@date: 06.01.2018
|
|
|
|
|
@author: Bastian Schroll
|
|
|
|
|
@description: Class for a BOSWatch data packet
|
|
|
|
|
"""
|
|
|
|
|
import logging
|
|
|
|
|
import time
|
2018-01-08 19:57:28 +01:00
|
|
|
from boswatch.config import Config
|
2018-01-07 14:10:42 +01:00
|
|
|
from boswatch import version
|
|
|
|
|
|
|
|
|
|
logging.debug("- %s loaded", __name__)
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
class Packet:
|
|
|
|
|
"""!Class implementation of an BOSWatch packet"""
|
|
|
|
|
|
|
|
|
|
def __init__(self, bwPacket=None):
|
|
|
|
|
"""!Build a new BOSWatch packet or copy existing data in it
|
|
|
|
|
|
|
|
|
|
@param bwPacket: Existing data to copy"""
|
|
|
|
|
if bwPacket is None:
|
|
|
|
|
logging.debug("create new bwPacket")
|
|
|
|
|
self._packet = {"timestamp": time.time()}
|
|
|
|
|
else:
|
2018-01-07 19:46:37 +01:00
|
|
|
logging.debug("create bwPacket from string")
|
2018-01-07 14:10:42 +01:00
|
|
|
self._packet = eval(bwPacket)
|
|
|
|
|
|
|
|
|
|
def __str__(self):
|
|
|
|
|
"""!Return the intern _packet dict as string"""
|
|
|
|
|
return str(self._packet)
|
|
|
|
|
|
2018-01-09 11:33:23 +01:00
|
|
|
def set(self, fieldName, value):
|
2018-01-07 14:10:42 +01:00
|
|
|
"""!Set a field in the intern _packet dict
|
|
|
|
|
|
|
|
|
|
@param fieldName: Name of the data to set
|
|
|
|
|
@param value: Value to set"""
|
|
|
|
|
self._packet[fieldName] = str(value)
|
|
|
|
|
|
2018-01-09 11:33:23 +01:00
|
|
|
def get(self, fieldName):
|
2018-01-07 14:10:42 +01:00
|
|
|
"""!Returns the value from a single field.
|
|
|
|
|
If field not existing `None` is returned
|
|
|
|
|
|
|
|
|
|
@param fieldName: Name of the field
|
|
|
|
|
@return Value or None"""
|
|
|
|
|
try:
|
|
|
|
|
return self._packet[fieldName]
|
|
|
|
|
except:
|
|
|
|
|
logging.warning("field not found: %s", fieldName)
|
|
|
|
|
return None
|
|
|
|
|
|
|
|
|
|
def addClientData(self):
|
|
|
|
|
"""!Add the client information to the decoded data
|
|
|
|
|
|
|
|
|
|
This function adds the following data to the bwPacket:
|
|
|
|
|
- clientName
|
|
|
|
|
- clientVersion
|
|
|
|
|
- clientBuildDate
|
|
|
|
|
- clientBranch
|
|
|
|
|
- inputSource
|
|
|
|
|
- frequency"""
|
2018-01-08 19:57:28 +01:00
|
|
|
config = Config()
|
2018-01-07 14:10:42 +01:00
|
|
|
logging.debug("add client data to bwPacket")
|
2018-01-11 13:02:04 +01:00
|
|
|
self.set("clientName", config.getStr("Client", "Name", "clientConfig"))
|
2018-01-09 11:33:23 +01:00
|
|
|
self.set("clientVersion", version.client)
|
|
|
|
|
self.set("clientBuildDate", version.date)
|
|
|
|
|
self.set("clientBranch", version.branch)
|
2018-01-11 13:02:04 +01:00
|
|
|
self.set("inputSource", config.getStr("Server", "InputSource", "clientConfig"))
|
|
|
|
|
self.set("frequency", config.getStr("Stick", "Frequency", "clientConfig"))
|
2018-01-07 14:10:42 +01:00
|
|
|
|
|
|
|
|
def addServerData(self):
|
|
|
|
|
"""!Add the server information to the decoded data
|
|
|
|
|
|
|
|
|
|
This function adds the following data to the bwPacket:
|
|
|
|
|
- serverName
|
|
|
|
|
- serverVersion
|
|
|
|
|
- serverBuildDate
|
|
|
|
|
- serverBranch"""
|
2018-01-08 19:57:28 +01:00
|
|
|
config = Config()
|
2018-01-07 14:10:42 +01:00
|
|
|
logging.debug("add server data to bwPacket")
|
2018-01-11 13:02:04 +01:00
|
|
|
self.set("serverName", config.getStr("Server", "Name", "serverConfig"))
|
2018-01-09 11:33:23 +01:00
|
|
|
self.set("serverVersion", version.server)
|
|
|
|
|
self.set("serverBuildDate", version.date)
|
|
|
|
|
self.set("serverBranch", version.branch)
|
2018-01-11 13:02:04 +01:00
|
|
|
|
|
|
|
|
@staticmethod
|
|
|
|
|
def infoToLog(bwPacket):
|
|
|
|
|
"""!Print a info message to the log on INFO level.
|
|
|
|
|
Contains the most useful info about this packet.
|
|
|
|
|
@todo not complete yet - must be edit to print nice formatted messages on console
|
|
|
|
|
|
|
|
|
|
@param bwPacket: BOSWatch packet instance"""
|
|
|
|
|
logging.info("%s packet received", bwPacket.get("mode"))
|