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
|
|
|
|
|
|
|
|
|
|
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")
|
2019-03-02 09:15:40 +01:00
|
|
|
self._packet = eval(str(bwPacket.strip()))
|
2018-01-07 14:10:42 +01:00
|
|
|
|
|
|
|
|
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"""
|
2019-10-27 21:58:06 +01:00
|
|
|
self._packet[fieldName] = str(value)
|
2018-01-07 14:10:42 +01:00
|
|
|
|
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:
|
2019-10-27 21:58:06 +01:00
|
|
|
return str(self._packet[fieldName])
|
2018-01-07 14:10:42 +01:00
|
|
|
except:
|
|
|
|
|
logging.warning("field not found: %s", fieldName)
|
|
|
|
|
return None
|
|
|
|
|
|
2018-01-15 14:18:15 +01:00
|
|
|
def printInfo(self):
|
2018-01-11 13:02:04 +01:00
|
|
|
"""!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
|
2018-09-20 23:55:53 +02:00
|
|
|
"""
|
2018-01-13 09:56:46 +01:00
|
|
|
logging.info("[%s]", self.get("mode"))
|