diff --git a/app.py b/app.py index ad5b853..dd82210 100644 --- a/app.py +++ b/app.py @@ -56,16 +56,18 @@ class UnifiAPI: self.session.verify = False def get_all_devices(self): - logger.debug(f"Fetching all devices from {self.base_url}") + logger.info(f"Fetching devices from UniFi controller at {self.base_url}") try: url = f"{self.base_url}/proxy/network/integration/v1/sites/{self.site_id}/devices" + logger.debug(f"Making request to: {url}") + logger.debug(f"Using headers: {self.headers}") response = self.session.get(url, headers=self.headers) response.raise_for_status() devices = response.json() - logger.debug(f"API Response: {devices}") + logger.info(f"Successfully fetched {len(devices)} devices") return devices except Exception as e: - logger.error(f"Error fetching devices: {e}") + logger.error(f"Failed to fetch devices: {str(e)}") return [] def get_device_details(self, ip_address): @@ -171,18 +173,22 @@ def status(): @app.route('/api/diagnostics') def get_diagnostics(): + logger.info("Diagnostics endpoint called") try: config = load_config() + unifi = UnifiAPI(config) + devices = unifi.get_all_devices() + logger.info(f"Found {len(devices)} devices") diagnostics = {} for device in config['devices']: - if device.get('device_id'): - logger.debug(f"Fetching diagnostics for device: {device['name']}") - diagnostics[device['name']] = run_diagnostics(device) - logger.debug(f"Returning diagnostics: {diagnostics}") + logger.info(f"Getting diagnostics for {device['name']}") + device_details = unifi.get_device_details(device['ip']) + if device_details: + diagnostics[device['name']] = device_details return jsonify(diagnostics) except Exception as e: logger.error(f"Error in diagnostics endpoint: {str(e)}") - return jsonify({"error": str(e)}), 500 + return jsonify({"error": str(e)}) # Application entry point if __name__ == '__main__':