- Standardized error handling across tool implementations - Improved return type consistency for tool execution results - Simplified configuration parsing and type definitions - Enhanced type safety for various configuration schemas - Cleaned up and normalized tool response structures - Updated SSE and event subscription tool implementations
48 lines
1.3 KiB
TypeScript
48 lines
1.3 KiB
TypeScript
import { z } from "zod";
|
|
import { Tool } from "../types/index.js";
|
|
import { APP_CONFIG } from "../config/app.config.js";
|
|
import { HassState } from "../types/index.js";
|
|
|
|
export const listDevicesTool: Tool = {
|
|
name: "list_devices",
|
|
description: "List all available Home Assistant devices",
|
|
parameters: z.object({}).describe("No parameters required"),
|
|
execute: async () => {
|
|
try {
|
|
const response = await fetch(`${APP_CONFIG.HASS_HOST}/api/states`, {
|
|
headers: {
|
|
Authorization: `Bearer ${APP_CONFIG.HASS_TOKEN}`,
|
|
"Content-Type": "application/json",
|
|
},
|
|
});
|
|
|
|
if (!response.ok) {
|
|
throw new Error(`Failed to fetch devices: ${response.statusText}`);
|
|
}
|
|
|
|
const states = (await response.json()) as HassState[];
|
|
const devices: Record<string, HassState[]> = {};
|
|
|
|
// Group devices by domain
|
|
states.forEach((state) => {
|
|
const [domain] = state.entity_id.split(".");
|
|
if (!devices[domain]) {
|
|
devices[domain] = [];
|
|
}
|
|
devices[domain].push(state);
|
|
});
|
|
|
|
return {
|
|
success: true,
|
|
devices,
|
|
};
|
|
} catch (error) {
|
|
return {
|
|
success: false,
|
|
message:
|
|
error instanceof Error ? error.message : "Unknown error occurred",
|
|
};
|
|
}
|
|
},
|
|
};
|