From f5e0ceb3b74d5105d78a1fdcd7710108bb047c5c Mon Sep 17 00:00:00 2001 From: Quentin WEPHRE Date: Mon, 17 Mar 2025 08:17:51 +0100 Subject: [PATCH] Maintenance update --- Moulinette/data_path_config.py | 6 ++-- Python/azure_iot_hub_1.py | 64 ---------------------------------- 2 files changed, 3 insertions(+), 67 deletions(-) delete mode 100644 Python/azure_iot_hub_1.py diff --git a/Moulinette/data_path_config.py b/Moulinette/data_path_config.py index 937f870..4b493cd 100644 --- a/Moulinette/data_path_config.py +++ b/Moulinette/data_path_config.py @@ -40,7 +40,7 @@ allowed_name_characters.append('.') logging.basicConfig(format='%(asctime)s %(levelname)-8s %(message)s', filename='data_config_debug.log', filemode='w', level=logging.DEBUG, datefmt='%Y%m%d%H%M%S') dir_name = 'I-Sight_Generated_Files' -input_datamodel = 'DATAMODEL_1.0.6_DANISH.xlsx' +input_datamodel = 'DATAMODEL_1.0.6_BEI.xlsx' shell_script_name = dir_name + '/I-Sight_Configuration_' global_shell_script_name = dir_name + '/I-Sight_Global_Configuration.sh' @@ -204,7 +204,7 @@ def jq_filter(current_device, dsh, dsh_global, row_device): if filter in jq_filter_set and filter != "bitfield": logging.debug("Creating standard telemetry topic " + filter + ".") jq_data = {} - jq_data["enable"] = False + jq_data["enable"] = True jq_data["properties"] = [{"key": "deviceType", "value": "AC_GATEWAY"}, {"key": "cdid", "value": current_device}] jq_data["outputTopic"] = filter jq_data["sendOutThreshold"] = {"mode": "bySize", "size": int(128000), "time": int(30), "sizeIdleTimer": {"enable": True, "time": int(30)}} @@ -505,4 +505,4 @@ if __name__ == "__main__": main() logging.shutdown() shutil.move("data_config_debug.log", dir_name + "/data_config_debug.log") - \ No newline at end of file + diff --git a/Python/azure_iot_hub_1.py b/Python/azure_iot_hub_1.py deleted file mode 100644 index 4f0fc74..0000000 --- a/Python/azure_iot_hub_1.py +++ /dev/null @@ -1,64 +0,0 @@ -from azure.iot.hub import IoTHubRegistryManager -from azure.iot.hub.protocol.models import QuerySpecification -from azure.iot.hub.models import CloudToDeviceMethod, CloudToDeviceMethodResult -from dotenv import load_dotenv - -import json -import os - -load_dotenv() - -module_id = "thingspro-agent" -method_name = "thingspro-api-v1" -payload = '{"method":"GET", "path":"/device/general"}' - -# Install the Azure IoT Hub SDK: -# pip install azure-iot-hub - -# Authenticate to your Azure account -CONNECTION_STRING = str(os.getenv("CONNECTION_STRING_SAFT_PROD")) -# CONNECTION_STRING = str(os.getenv("CONNECTION_STRING_INOX_PROD")) -if CONNECTION_STRING == "": - print("Provide a connection string for the Iot Hub before running the script!") - exit(13) - - -registry_manager = IoTHubRegistryManager.from_connection_string(CONNECTION_STRING) -query_spec = QuerySpecification(query="SELECT * FROM devices WHERE IS_DEFINED(tags.site) AND capabilities.iotEdge = true") - -query_result = registry_manager.query_iot_hub(query_spec) -devices = [] -for item in query_result.items: - number = int(-1) - deviceId = "null" - site = "null" - if item.tagss['number']: - number = int(item.tags['number']) - if item.tags['deviceId']: - deviceId = item.tags['deviceId'] - if item.tags['site']: - site = item.tags['site'] - - devices.append([int(item.tags['number']), item.tags['deviceId'], item.tags['site']]) - -ordered_devices = sorted(devices, key = lambda x: (x[2], x[0])) - -for i in ordered_devices: - current_device_modules = registry_manager.get_modules(i[1]) - for module in current_device_modules: - if module.module_id == module_id: - thingspro_module = module - if thingspro_module: - #print("Found thingspro-agent for " + i[1] + " (" + i[2] + ")") - try: - direct_method = CloudToDeviceMethod(method_name=method_name, payload=json.loads(payload)) - response = registry_manager.invoke_device_module_method(device_id=i[1], module_id=module_id, direct_method_request=direct_method) - #print(response.payload) - if str(i[1]) == str(response.payload['data']['hostName']): - print(str(i[2]), str(i[0]), str(i[1]), response.payload['data']['description'], response.payload['data']['firmwareVersion'], sep=";") - else: - print(str(i[2]), str(i[0]), str(i[1]), response.payload['data']['description'], response.payload['data']['hostName'], response.payload['data']['firmwareVersion'], sep=";") - except: - print(str(i[2]), str(i[0]), str(i[1]), "UNREACHABLE",sep=";") - else: - print("No thingspro-agent available for " + i[1] + " (" + i[2] + ")") \ No newline at end of file