from datetime import datetime from eive_tmtc.config.definitions import CustomServiceList from spacepackets.ecss import PusTelecommand from tmtccmd import DefaultProcedureInfo, TcHandlerBase from tmtccmd.logging import get_console_logger from tmtccmd.tc import DefaultPusQueueHelper, service_provider from tmtccmd.tc.decorator import ServiceProviderParams LOGGER = get_console_logger() class OpCodes: SET_CURRENT_TIME = ["0", "set-curr-time"] class Info: SET_CURRENT_TIME = "Setting current time in ASCII format" @service_provider(CustomServiceList.TIME.value) def pack_set_current_time_ascii_command(p: ServiceProviderParams): q = p.queue_helper time_test_current_time = datetime.utcnow().isoformat() + "Z" + "\0" current_time_ascii = time_test_current_time.encode("ascii") LOGGER.info(f"Current time in ASCII format: {current_time_ascii}") q.add_log_cmd(Info.SET_CURRENT_TIME) q.add_pus_tc(PusTelecommand(service=9, subservice=128, app_data=current_time_ascii))