|
61 | 61 | mcp.Description("[Optional] End timestamp for the query to be executed at."+
|
62 | 62 | " Must be either Unix timestamp or RFC3339. Defaults to current time."),
|
63 | 63 | ),
|
| 64 | + ) |
| 65 | + |
| 66 | + labelNamesTool = mcp.NewTool("label_names", |
| 67 | + mcp.WithDescription("Returns the unique label names present in the block in sorted order by given time range and matchers"), |
| 68 | + mcp.WithArray("matchers", |
| 69 | + mcp.Required(), |
| 70 | + mcp.Description("Label matchers"), |
| 71 | + ), |
| 72 | + mcp.WithString("start_time", |
| 73 | + mcp.Description("[Optional] Start timestamp for the query to be executed at."+ |
| 74 | + " Must be either Unix timestamp or RFC3339. Defaults to 5m ago."), |
| 75 | + ), |
| 76 | + mcp.WithString("end_time", |
| 77 | + mcp.Required(), |
| 78 | + mcp.Description("[Optional] End timestamp for the query to be executed at."+ |
| 79 | + " Must be either Unix timestamp or RFC3339. Defaults to current time."), |
64 | 80 | ),
|
65 | 81 | )
|
66 | 82 |
|
@@ -208,6 +224,43 @@ func seriesToolHandler(ctx context.Context, request mcp.CallToolRequest) (*mcp.C
|
208 | 224 | return mcp.NewToolResultText(data), err
|
209 | 225 | }
|
210 | 226 |
|
| 227 | +func labelNamesToolHandler(ctx context.Context, request mcp.CallToolRequest) (*mcp.CallToolResult, error) { |
| 228 | + arguments := request.Params.Arguments |
| 229 | + argMatchers, ok := arguments["matchers"].([]any) |
| 230 | + if !ok { |
| 231 | + return nil, errors.New("matchers must be an array") |
| 232 | + } |
| 233 | + |
| 234 | + matchers := make([]string, len(argMatchers)) |
| 235 | + for i, m := range argMatchers { |
| 236 | + matchers[i] = m.(string) |
| 237 | + } |
| 238 | + |
| 239 | + endTs := time.Now() |
| 240 | + startTs := endTs.Add(DefaultLookbackDelta) |
| 241 | + |
| 242 | + if argEndTime, ok := arguments["end_time"].(string); ok { |
| 243 | + parsedEndTime, err := mcpProm.ParseTimestamp(argEndTime) |
| 244 | + if err != nil { |
| 245 | + return nil, fmt.Errorf("failed to parse end_time %s from args: %w", argEndTime, err) |
| 246 | + } |
| 247 | + |
| 248 | + endTs = parsedEndTime |
| 249 | + } |
| 250 | + |
| 251 | + if argStartTime, ok := arguments["start_time"].(string); ok { |
| 252 | + parsedStartTime, err := mcpProm.ParseTimestamp(argStartTime) |
| 253 | + if err != nil { |
| 254 | + return nil, fmt.Errorf("failed to parse start_time %s from args: %w", argStartTime, err) |
| 255 | + } |
| 256 | + |
| 257 | + startTs = parsedStartTime |
| 258 | + } |
| 259 | + |
| 260 | + data, err := labelNamesApiCall(ctx, matchers, startTs, endTs) |
| 261 | + return mcp.NewToolResultText(data), err |
| 262 | +} |
| 263 | + |
211 | 264 | func listAlertsToolHandler(ctx context.Context, request mcp.CallToolRequest) (*mcp.CallToolResult, error) {
|
212 | 265 | data, err := listAlertsApiCall(ctx)
|
213 | 266 | return mcp.NewToolResultText(data), err
|
|
0 commit comments