@hookdeck/outpost-sdk 0.9.0 → 0.9.2
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/README.md +14 -7
- package/bin/mcp-server.js +1026 -408
- package/bin/mcp-server.js.map +48 -41
- package/dist/commonjs/funcs/attemptsGet.js.map +1 -1
- package/dist/commonjs/funcs/destinationsCreate.js.map +1 -1
- package/dist/commonjs/funcs/destinationsDelete.js.map +1 -1
- package/dist/commonjs/funcs/destinationsDisable.js.map +1 -1
- package/dist/commonjs/funcs/destinationsEnable.js.map +1 -1
- package/dist/commonjs/funcs/destinationsGet.js.map +1 -1
- package/dist/commonjs/funcs/destinationsGetAttempt.js.map +1 -1
- package/dist/commonjs/funcs/destinationsList.js.map +1 -1
- package/dist/commonjs/funcs/destinationsListAttempts.js.map +1 -1
- package/dist/commonjs/funcs/destinationsUpdate.js.map +1 -1
- package/dist/commonjs/funcs/eventsGet.js.map +1 -1
- package/dist/commonjs/funcs/metricsGetAttemptMetrics.d.ts +28 -0
- package/dist/commonjs/funcs/metricsGetAttemptMetrics.d.ts.map +1 -0
- package/dist/commonjs/funcs/metricsGetAttemptMetrics.js +142 -0
- package/dist/commonjs/funcs/metricsGetAttemptMetrics.js.map +1 -0
- package/dist/commonjs/funcs/metricsGetEventMetrics.d.ts +26 -0
- package/dist/commonjs/funcs/metricsGetEventMetrics.d.ts.map +1 -0
- package/dist/commonjs/funcs/metricsGetEventMetrics.js +136 -0
- package/dist/commonjs/funcs/metricsGetEventMetrics.js.map +1 -0
- package/dist/commonjs/funcs/schemasGetDestinationType.js.map +1 -1
- package/dist/commonjs/funcs/tenantsDelete.js.map +1 -1
- package/dist/commonjs/funcs/tenantsGet.js.map +1 -1
- package/dist/commonjs/funcs/tenantsGetPortalUrl.js.map +1 -1
- package/dist/commonjs/funcs/tenantsGetToken.js.map +1 -1
- package/dist/commonjs/funcs/tenantsUpsert.js.map +1 -1
- package/dist/commonjs/lib/config.d.ts +3 -3
- package/dist/commonjs/lib/config.js +3 -3
- package/dist/commonjs/lib/config.js.map +1 -1
- package/dist/commonjs/lib/files.d.ts +13 -0
- package/dist/commonjs/lib/files.d.ts.map +1 -1
- package/dist/commonjs/lib/files.js +19 -0
- package/dist/commonjs/lib/files.js.map +1 -1
- package/dist/commonjs/lib/sdks.d.ts.map +1 -1
- package/dist/commonjs/lib/sdks.js +8 -4
- package/dist/commonjs/lib/sdks.js.map +1 -1
- package/dist/commonjs/lib/url.d.ts.map +1 -1
- package/dist/commonjs/lib/url.js +4 -2
- package/dist/commonjs/lib/url.js.map +1 -1
- package/dist/commonjs/mcp-server/mcp-server.js +1 -1
- package/dist/commonjs/mcp-server/server.d.ts.map +1 -1
- package/dist/commonjs/mcp-server/server.js +5 -1
- package/dist/commonjs/mcp-server/server.js.map +1 -1
- package/dist/commonjs/mcp-server/tools/metricsGetAttemptMetrics.d.ts +8 -0
- package/dist/commonjs/mcp-server/tools/metricsGetAttemptMetrics.d.ts.map +1 -0
- package/dist/commonjs/mcp-server/tools/metricsGetAttemptMetrics.js +74 -0
- package/dist/commonjs/mcp-server/tools/metricsGetAttemptMetrics.js.map +1 -0
- package/dist/commonjs/mcp-server/tools/metricsGetEventMetrics.d.ts +8 -0
- package/dist/commonjs/mcp-server/tools/metricsGetEventMetrics.d.ts.map +1 -0
- package/dist/commonjs/mcp-server/tools/metricsGetEventMetrics.js +72 -0
- package/dist/commonjs/mcp-server/tools/metricsGetEventMetrics.js.map +1 -0
- package/dist/commonjs/models/components/attempt.d.ts +104 -6
- package/dist/commonjs/models/components/attempt.d.ts.map +1 -1
- package/dist/commonjs/models/components/attempt.js +106 -11
- package/dist/commonjs/models/components/attempt.js.map +1 -1
- package/dist/commonjs/models/components/destinationschemafield.d.ts +1 -0
- package/dist/commonjs/models/components/destinationschemafield.d.ts.map +1 -1
- package/dist/commonjs/models/components/destinationschemafield.js +1 -0
- package/dist/commonjs/models/components/destinationschemafield.js.map +1 -1
- package/dist/commonjs/models/components/index.d.ts +3 -2
- package/dist/commonjs/models/components/index.d.ts.map +1 -1
- package/dist/commonjs/models/components/index.js +3 -2
- package/dist/commonjs/models/components/index.js.map +1 -1
- package/dist/commonjs/models/components/metricsdatapoint.d.ts +38 -0
- package/dist/commonjs/models/components/metricsdatapoint.d.ts.map +1 -0
- package/dist/commonjs/models/components/{eventsummary.js → metricsdatapoint.js} +18 -31
- package/dist/commonjs/models/components/metricsdatapoint.js.map +1 -0
- package/dist/commonjs/models/components/metricsmetadata.d.ts +40 -0
- package/dist/commonjs/models/components/metricsmetadata.d.ts.map +1 -0
- package/dist/commonjs/models/components/{eventfull.js → metricsmetadata.js} +26 -33
- package/dist/commonjs/models/components/metricsmetadata.js.map +1 -0
- package/dist/commonjs/models/components/metricsresponse.d.ts +24 -0
- package/dist/commonjs/models/components/metricsresponse.d.ts.map +1 -0
- package/dist/commonjs/models/components/metricsresponse.js +62 -0
- package/dist/commonjs/models/components/metricsresponse.js.map +1 -0
- package/dist/commonjs/models/operations/getattempt.d.ts +2 -0
- package/dist/commonjs/models/operations/getattempt.d.ts.map +1 -1
- package/dist/commonjs/models/operations/getattempt.js.map +1 -1
- package/dist/commonjs/models/operations/getattemptmetrics.d.ts +273 -0
- package/dist/commonjs/models/operations/getattemptmetrics.d.ts.map +1 -0
- package/dist/commonjs/models/operations/getattemptmetrics.js +326 -0
- package/dist/commonjs/models/operations/getattemptmetrics.js.map +1 -0
- package/dist/commonjs/models/operations/geteventmetrics.d.ts +158 -0
- package/dist/commonjs/models/operations/geteventmetrics.d.ts.map +1 -0
- package/dist/commonjs/models/operations/geteventmetrics.js +208 -0
- package/dist/commonjs/models/operations/geteventmetrics.js.map +1 -0
- package/dist/commonjs/models/operations/gettenantdestinationattempt.d.ts +2 -0
- package/dist/commonjs/models/operations/gettenantdestinationattempt.d.ts.map +1 -1
- package/dist/commonjs/models/operations/gettenantdestinationattempt.js.map +1 -1
- package/dist/commonjs/models/operations/index.d.ts +2 -0
- package/dist/commonjs/models/operations/index.d.ts.map +1 -1
- package/dist/commonjs/models/operations/index.js +2 -0
- package/dist/commonjs/models/operations/index.js.map +1 -1
- package/dist/commonjs/models/operations/listattempts.d.ts +2 -0
- package/dist/commonjs/models/operations/listattempts.d.ts.map +1 -1
- package/dist/commonjs/models/operations/listattempts.js.map +1 -1
- package/dist/commonjs/models/operations/listtenantdestinationattempts.d.ts +2 -0
- package/dist/commonjs/models/operations/listtenantdestinationattempts.d.ts.map +1 -1
- package/dist/commonjs/models/operations/listtenantdestinationattempts.js.map +1 -1
- package/dist/commonjs/sdk/metrics.d.ts +36 -0
- package/dist/commonjs/sdk/metrics.d.ts.map +1 -0
- package/dist/commonjs/sdk/metrics.js +48 -0
- package/dist/commonjs/sdk/metrics.js.map +1 -0
- package/dist/commonjs/sdk/sdk.d.ts +3 -0
- package/dist/commonjs/sdk/sdk.d.ts.map +1 -1
- package/dist/commonjs/sdk/sdk.js +4 -0
- package/dist/commonjs/sdk/sdk.js.map +1 -1
- package/dist/esm/funcs/attemptsGet.js.map +1 -1
- package/dist/esm/funcs/destinationsCreate.js.map +1 -1
- package/dist/esm/funcs/destinationsDelete.js.map +1 -1
- package/dist/esm/funcs/destinationsDisable.js.map +1 -1
- package/dist/esm/funcs/destinationsEnable.js.map +1 -1
- package/dist/esm/funcs/destinationsGet.js.map +1 -1
- package/dist/esm/funcs/destinationsGetAttempt.js.map +1 -1
- package/dist/esm/funcs/destinationsList.js.map +1 -1
- package/dist/esm/funcs/destinationsListAttempts.js.map +1 -1
- package/dist/esm/funcs/destinationsUpdate.js.map +1 -1
- package/dist/esm/funcs/eventsGet.js.map +1 -1
- package/dist/esm/funcs/metricsGetAttemptMetrics.d.ts +28 -0
- package/dist/esm/funcs/metricsGetAttemptMetrics.d.ts.map +1 -0
- package/dist/esm/funcs/metricsGetAttemptMetrics.js +106 -0
- package/dist/esm/funcs/metricsGetAttemptMetrics.js.map +1 -0
- package/dist/esm/funcs/metricsGetEventMetrics.d.ts +26 -0
- package/dist/esm/funcs/metricsGetEventMetrics.d.ts.map +1 -0
- package/dist/esm/funcs/metricsGetEventMetrics.js +100 -0
- package/dist/esm/funcs/metricsGetEventMetrics.js.map +1 -0
- package/dist/esm/funcs/schemasGetDestinationType.js.map +1 -1
- package/dist/esm/funcs/tenantsDelete.js.map +1 -1
- package/dist/esm/funcs/tenantsGet.js.map +1 -1
- package/dist/esm/funcs/tenantsGetPortalUrl.js.map +1 -1
- package/dist/esm/funcs/tenantsGetToken.js.map +1 -1
- package/dist/esm/funcs/tenantsUpsert.js.map +1 -1
- package/dist/esm/lib/config.d.ts +3 -3
- package/dist/esm/lib/config.js +3 -3
- package/dist/esm/lib/config.js.map +1 -1
- package/dist/esm/lib/files.d.ts +13 -0
- package/dist/esm/lib/files.d.ts.map +1 -1
- package/dist/esm/lib/files.js +18 -0
- package/dist/esm/lib/files.js.map +1 -1
- package/dist/esm/lib/sdks.d.ts.map +1 -1
- package/dist/esm/lib/sdks.js +8 -4
- package/dist/esm/lib/sdks.js.map +1 -1
- package/dist/esm/lib/url.d.ts.map +1 -1
- package/dist/esm/lib/url.js +4 -2
- package/dist/esm/lib/url.js.map +1 -1
- package/dist/esm/mcp-server/mcp-server.js +1 -1
- package/dist/esm/mcp-server/server.d.ts.map +1 -1
- package/dist/esm/mcp-server/server.js +5 -1
- package/dist/esm/mcp-server/server.js.map +1 -1
- package/dist/esm/mcp-server/tools/metricsGetAttemptMetrics.d.ts +8 -0
- package/dist/esm/mcp-server/tools/metricsGetAttemptMetrics.d.ts.map +1 -0
- package/dist/esm/mcp-server/tools/metricsGetAttemptMetrics.js +38 -0
- package/dist/esm/mcp-server/tools/metricsGetAttemptMetrics.js.map +1 -0
- package/dist/esm/mcp-server/tools/metricsGetEventMetrics.d.ts +8 -0
- package/dist/esm/mcp-server/tools/metricsGetEventMetrics.d.ts.map +1 -0
- package/dist/esm/mcp-server/tools/metricsGetEventMetrics.js +36 -0
- package/dist/esm/mcp-server/tools/metricsGetEventMetrics.js.map +1 -0
- package/dist/esm/models/components/attempt.d.ts +104 -6
- package/dist/esm/models/components/attempt.d.ts.map +1 -1
- package/dist/esm/models/components/attempt.js +101 -10
- package/dist/esm/models/components/attempt.js.map +1 -1
- package/dist/esm/models/components/destinationschemafield.d.ts +1 -0
- package/dist/esm/models/components/destinationschemafield.d.ts.map +1 -1
- package/dist/esm/models/components/destinationschemafield.js +1 -0
- package/dist/esm/models/components/destinationschemafield.js.map +1 -1
- package/dist/esm/models/components/index.d.ts +3 -2
- package/dist/esm/models/components/index.d.ts.map +1 -1
- package/dist/esm/models/components/index.js +3 -2
- package/dist/esm/models/components/index.js.map +1 -1
- package/dist/esm/models/components/metricsdatapoint.d.ts +38 -0
- package/dist/esm/models/components/metricsdatapoint.d.ts.map +1 -0
- package/dist/esm/models/components/metricsdatapoint.js +33 -0
- package/dist/esm/models/components/metricsdatapoint.js.map +1 -0
- package/dist/esm/models/components/metricsmetadata.d.ts +40 -0
- package/dist/esm/models/components/metricsmetadata.d.ts.map +1 -0
- package/dist/esm/models/components/metricsmetadata.js +41 -0
- package/dist/esm/models/components/metricsmetadata.js.map +1 -0
- package/dist/esm/models/components/metricsresponse.d.ts +24 -0
- package/dist/esm/models/components/metricsresponse.d.ts.map +1 -0
- package/dist/esm/models/components/metricsresponse.js +24 -0
- package/dist/esm/models/components/metricsresponse.js.map +1 -0
- package/dist/esm/models/operations/getattempt.d.ts +2 -0
- package/dist/esm/models/operations/getattempt.d.ts.map +1 -1
- package/dist/esm/models/operations/getattempt.js.map +1 -1
- package/dist/esm/models/operations/getattemptmetrics.d.ts +273 -0
- package/dist/esm/models/operations/getattemptmetrics.d.ts.map +1 -0
- package/dist/esm/models/operations/getattemptmetrics.js +272 -0
- package/dist/esm/models/operations/getattemptmetrics.js.map +1 -0
- package/dist/esm/models/operations/geteventmetrics.d.ts +158 -0
- package/dist/esm/models/operations/geteventmetrics.d.ts.map +1 -0
- package/dist/esm/models/operations/geteventmetrics.js +160 -0
- package/dist/esm/models/operations/geteventmetrics.js.map +1 -0
- package/dist/esm/models/operations/gettenantdestinationattempt.d.ts +2 -0
- package/dist/esm/models/operations/gettenantdestinationattempt.d.ts.map +1 -1
- package/dist/esm/models/operations/gettenantdestinationattempt.js.map +1 -1
- package/dist/esm/models/operations/index.d.ts +2 -0
- package/dist/esm/models/operations/index.d.ts.map +1 -1
- package/dist/esm/models/operations/index.js +2 -0
- package/dist/esm/models/operations/index.js.map +1 -1
- package/dist/esm/models/operations/listattempts.d.ts +2 -0
- package/dist/esm/models/operations/listattempts.d.ts.map +1 -1
- package/dist/esm/models/operations/listattempts.js.map +1 -1
- package/dist/esm/models/operations/listtenantdestinationattempts.d.ts +2 -0
- package/dist/esm/models/operations/listtenantdestinationattempts.d.ts.map +1 -1
- package/dist/esm/models/operations/listtenantdestinationattempts.js.map +1 -1
- package/dist/esm/sdk/metrics.d.ts +36 -0
- package/dist/esm/sdk/metrics.d.ts.map +1 -0
- package/dist/esm/sdk/metrics.js +44 -0
- package/dist/esm/sdk/metrics.js.map +1 -0
- package/dist/esm/sdk/sdk.d.ts +3 -0
- package/dist/esm/sdk/sdk.d.ts.map +1 -1
- package/dist/esm/sdk/sdk.js +4 -0
- package/dist/esm/sdk/sdk.js.map +1 -1
- package/jsr.json +1 -1
- package/package.json +1 -1
- package/src/funcs/attemptsGet.ts +0 -1
- package/src/funcs/destinationsCreate.ts +0 -1
- package/src/funcs/destinationsDelete.ts +0 -1
- package/src/funcs/destinationsDisable.ts +0 -1
- package/src/funcs/destinationsEnable.ts +0 -1
- package/src/funcs/destinationsGet.ts +0 -1
- package/src/funcs/destinationsGetAttempt.ts +0 -1
- package/src/funcs/destinationsList.ts +0 -1
- package/src/funcs/destinationsListAttempts.ts +0 -1
- package/src/funcs/destinationsUpdate.ts +0 -1
- package/src/funcs/eventsGet.ts +0 -1
- package/src/funcs/metricsGetAttemptMetrics.ts +206 -0
- package/src/funcs/metricsGetEventMetrics.ts +200 -0
- package/src/funcs/schemasGetDestinationType.ts +0 -1
- package/src/funcs/tenantsDelete.ts +0 -1
- package/src/funcs/tenantsGet.ts +0 -1
- package/src/funcs/tenantsGetPortalUrl.ts +0 -1
- package/src/funcs/tenantsGetToken.ts +0 -1
- package/src/funcs/tenantsUpsert.ts +0 -1
- package/src/lib/config.ts +3 -3
- package/src/lib/files.ts +22 -0
- package/src/lib/sdks.ts +7 -5
- package/src/lib/url.ts +16 -14
- package/src/mcp-server/mcp-server.ts +1 -1
- package/src/mcp-server/server.ts +5 -1
- package/src/mcp-server/tools/metricsGetAttemptMetrics.ts +47 -0
- package/src/mcp-server/tools/metricsGetEventMetrics.ts +45 -0
- package/src/models/components/attempt.ts +224 -23
- package/src/models/components/destinationschemafield.ts +1 -0
- package/src/models/components/index.ts +3 -2
- package/src/models/components/metricsdatapoint.ts +79 -0
- package/src/models/components/metricsmetadata.ts +93 -0
- package/src/models/components/metricsresponse.ts +68 -0
- package/src/models/operations/getattempt.ts +2 -0
- package/src/models/operations/getattemptmetrics.ts +668 -0
- package/src/models/operations/geteventmetrics.ts +434 -0
- package/src/models/operations/gettenantdestinationattempt.ts +2 -0
- package/src/models/operations/index.ts +2 -0
- package/src/models/operations/listattempts.ts +2 -0
- package/src/models/operations/listtenantdestinationattempts.ts +2 -0
- package/src/sdk/metrics.ts +62 -0
- package/src/sdk/sdk.ts +6 -0
- package/dist/commonjs/models/components/eventfull.d.ts +0 -57
- package/dist/commonjs/models/components/eventfull.d.ts.map +0 -1
- package/dist/commonjs/models/components/eventfull.js.map +0 -1
- package/dist/commonjs/models/components/eventsummary.d.ts +0 -48
- package/dist/commonjs/models/components/eventsummary.d.ts.map +0 -1
- package/dist/commonjs/models/components/eventsummary.js.map +0 -1
- package/dist/esm/models/components/eventfull.d.ts +0 -57
- package/dist/esm/models/components/eventfull.d.ts.map +0 -1
- package/dist/esm/models/components/eventfull.js +0 -48
- package/dist/esm/models/components/eventfull.js.map +0 -1
- package/dist/esm/models/components/eventsummary.d.ts +0 -48
- package/dist/esm/models/components/eventsummary.d.ts.map +0 -1
- package/dist/esm/models/components/eventsummary.js +0 -46
- package/dist/esm/models/components/eventsummary.js.map +0 -1
- package/src/models/components/eventfull.ts +0 -107
- package/src/models/components/eventsummary.ts +0 -100
|
@@ -0,0 +1,206 @@
|
|
|
1
|
+
/*
|
|
2
|
+
* Code generated by Speakeasy (https://speakeasy.com). DO NOT EDIT.
|
|
3
|
+
*/
|
|
4
|
+
|
|
5
|
+
import { OutpostCore } from "../core.js";
|
|
6
|
+
import { encodeFormQuery } from "../lib/encodings.js";
|
|
7
|
+
import * as M from "../lib/matchers.js";
|
|
8
|
+
import { compactMap } from "../lib/primitives.js";
|
|
9
|
+
import { safeParse } from "../lib/schemas.js";
|
|
10
|
+
import { RequestOptions } from "../lib/sdks.js";
|
|
11
|
+
import { extractSecurity, resolveGlobalSecurity } from "../lib/security.js";
|
|
12
|
+
import { pathToFunc } from "../lib/url.js";
|
|
13
|
+
import * as components from "../models/components/index.js";
|
|
14
|
+
import {
|
|
15
|
+
ConnectionError,
|
|
16
|
+
InvalidRequestError,
|
|
17
|
+
RequestAbortedError,
|
|
18
|
+
RequestTimeoutError,
|
|
19
|
+
UnexpectedClientError,
|
|
20
|
+
} from "../models/errors/httpclienterrors.js";
|
|
21
|
+
import * as errors from "../models/errors/index.js";
|
|
22
|
+
import { OutpostError } from "../models/errors/outposterror.js";
|
|
23
|
+
import { ResponseValidationError } from "../models/errors/responsevalidationerror.js";
|
|
24
|
+
import { SDKValidationError } from "../models/errors/sdkvalidationerror.js";
|
|
25
|
+
import * as operations from "../models/operations/index.js";
|
|
26
|
+
import { APICall, APIPromise } from "../types/async.js";
|
|
27
|
+
import { Result } from "../types/fp.js";
|
|
28
|
+
|
|
29
|
+
/**
|
|
30
|
+
* Get Attempt Metrics
|
|
31
|
+
*
|
|
32
|
+
* @remarks
|
|
33
|
+
* Returns aggregated delivery attempt metrics. Supports time bucketing via granularity,
|
|
34
|
+
* dimensional grouping, and filtering.
|
|
35
|
+
*
|
|
36
|
+
* **Measures:** `count`, `successful_count`, `failed_count`, `error_rate`,
|
|
37
|
+
* `first_attempt_count`, `retry_count`, `manual_retry_count`, `avg_attempt_number`,
|
|
38
|
+
* `rate`, `successful_rate`, `failed_rate`
|
|
39
|
+
*
|
|
40
|
+
* **Dimensions:** `tenant_id` (admin-only), `destination_id`, `topic`, `status`, `code`, `manual`, `attempt_number`
|
|
41
|
+
*
|
|
42
|
+
* **Filters:** `tenant_id` (admin-only), `destination_id`, `topic`, `status`, `code`, `manual`, `attempt_number`
|
|
43
|
+
*/
|
|
44
|
+
export function metricsGetAttemptMetrics(
|
|
45
|
+
client: OutpostCore,
|
|
46
|
+
request: operations.GetAttemptMetricsRequest,
|
|
47
|
+
options?: RequestOptions,
|
|
48
|
+
): APIPromise<
|
|
49
|
+
Result<
|
|
50
|
+
components.MetricsResponse,
|
|
51
|
+
| errors.BadRequestError
|
|
52
|
+
| errors.UnauthorizedError
|
|
53
|
+
| errors.APIErrorResponse
|
|
54
|
+
| errors.InternalServerError
|
|
55
|
+
| OutpostError
|
|
56
|
+
| ResponseValidationError
|
|
57
|
+
| ConnectionError
|
|
58
|
+
| RequestAbortedError
|
|
59
|
+
| RequestTimeoutError
|
|
60
|
+
| InvalidRequestError
|
|
61
|
+
| UnexpectedClientError
|
|
62
|
+
| SDKValidationError
|
|
63
|
+
>
|
|
64
|
+
> {
|
|
65
|
+
return new APIPromise($do(
|
|
66
|
+
client,
|
|
67
|
+
request,
|
|
68
|
+
options,
|
|
69
|
+
));
|
|
70
|
+
}
|
|
71
|
+
|
|
72
|
+
async function $do(
|
|
73
|
+
client: OutpostCore,
|
|
74
|
+
request: operations.GetAttemptMetricsRequest,
|
|
75
|
+
options?: RequestOptions,
|
|
76
|
+
): Promise<
|
|
77
|
+
[
|
|
78
|
+
Result<
|
|
79
|
+
components.MetricsResponse,
|
|
80
|
+
| errors.BadRequestError
|
|
81
|
+
| errors.UnauthorizedError
|
|
82
|
+
| errors.APIErrorResponse
|
|
83
|
+
| errors.InternalServerError
|
|
84
|
+
| OutpostError
|
|
85
|
+
| ResponseValidationError
|
|
86
|
+
| ConnectionError
|
|
87
|
+
| RequestAbortedError
|
|
88
|
+
| RequestTimeoutError
|
|
89
|
+
| InvalidRequestError
|
|
90
|
+
| UnexpectedClientError
|
|
91
|
+
| SDKValidationError
|
|
92
|
+
>,
|
|
93
|
+
APICall,
|
|
94
|
+
]
|
|
95
|
+
> {
|
|
96
|
+
const parsed = safeParse(
|
|
97
|
+
request,
|
|
98
|
+
(value) => operations.GetAttemptMetricsRequest$outboundSchema.parse(value),
|
|
99
|
+
"Input validation failed",
|
|
100
|
+
);
|
|
101
|
+
if (!parsed.ok) {
|
|
102
|
+
return [parsed, { status: "invalid" }];
|
|
103
|
+
}
|
|
104
|
+
const payload = parsed.value;
|
|
105
|
+
const body = null;
|
|
106
|
+
|
|
107
|
+
const path = pathToFunc("/metrics/attempts")();
|
|
108
|
+
|
|
109
|
+
const query = encodeFormQuery({
|
|
110
|
+
"dimensions": payload.dimensions,
|
|
111
|
+
"filters[attempt_number]": payload["filters[attempt_number]"],
|
|
112
|
+
"filters[code]": payload["filters[code]"],
|
|
113
|
+
"filters[destination_id]": payload["filters[destination_id]"],
|
|
114
|
+
"filters[manual]": payload["filters[manual]"],
|
|
115
|
+
"filters[status]": payload["filters[status]"],
|
|
116
|
+
"filters[tenant_id]": payload["filters[tenant_id]"],
|
|
117
|
+
"filters[topic]": payload["filters[topic]"],
|
|
118
|
+
"granularity": payload.granularity,
|
|
119
|
+
"measures": payload.measures,
|
|
120
|
+
"time[end]": payload["time[end]"],
|
|
121
|
+
"time[start]": payload["time[start]"],
|
|
122
|
+
});
|
|
123
|
+
|
|
124
|
+
const headers = new Headers(compactMap({
|
|
125
|
+
Accept: "application/json",
|
|
126
|
+
}));
|
|
127
|
+
|
|
128
|
+
const secConfig = await extractSecurity(client._options.apiKey);
|
|
129
|
+
const securityInput = secConfig == null ? {} : { apiKey: secConfig };
|
|
130
|
+
const requestSecurity = resolveGlobalSecurity(securityInput);
|
|
131
|
+
|
|
132
|
+
const context = {
|
|
133
|
+
options: client._options,
|
|
134
|
+
baseURL: options?.serverURL ?? client._baseURL ?? "",
|
|
135
|
+
operationID: "getAttemptMetrics",
|
|
136
|
+
oAuth2Scopes: null,
|
|
137
|
+
|
|
138
|
+
resolvedSecurity: requestSecurity,
|
|
139
|
+
|
|
140
|
+
securitySource: client._options.apiKey,
|
|
141
|
+
retryConfig: options?.retries
|
|
142
|
+
|| client._options.retryConfig
|
|
143
|
+
|| { strategy: "none" },
|
|
144
|
+
retryCodes: options?.retryCodes || ["429", "500", "502", "503", "504"],
|
|
145
|
+
};
|
|
146
|
+
|
|
147
|
+
const requestRes = client._createRequest(context, {
|
|
148
|
+
security: requestSecurity,
|
|
149
|
+
method: "GET",
|
|
150
|
+
baseURL: options?.serverURL,
|
|
151
|
+
path: path,
|
|
152
|
+
headers: headers,
|
|
153
|
+
query: query,
|
|
154
|
+
body: body,
|
|
155
|
+
userAgent: client._options.userAgent,
|
|
156
|
+
timeoutMs: options?.timeoutMs || client._options.timeoutMs || -1,
|
|
157
|
+
}, options);
|
|
158
|
+
if (!requestRes.ok) {
|
|
159
|
+
return [requestRes, { status: "invalid" }];
|
|
160
|
+
}
|
|
161
|
+
const req = requestRes.value;
|
|
162
|
+
|
|
163
|
+
const doResult = await client._do(req, {
|
|
164
|
+
context,
|
|
165
|
+
errorCodes: ["400", "401", "403", "4XX", "500", "5XX"],
|
|
166
|
+
retryConfig: context.retryConfig,
|
|
167
|
+
retryCodes: context.retryCodes,
|
|
168
|
+
});
|
|
169
|
+
if (!doResult.ok) {
|
|
170
|
+
return [doResult, { status: "request-error", request: req }];
|
|
171
|
+
}
|
|
172
|
+
const response = doResult.value;
|
|
173
|
+
|
|
174
|
+
const responseFields = {
|
|
175
|
+
HttpMeta: { Response: response, Request: req },
|
|
176
|
+
};
|
|
177
|
+
|
|
178
|
+
const [result] = await M.match<
|
|
179
|
+
components.MetricsResponse,
|
|
180
|
+
| errors.BadRequestError
|
|
181
|
+
| errors.UnauthorizedError
|
|
182
|
+
| errors.APIErrorResponse
|
|
183
|
+
| errors.InternalServerError
|
|
184
|
+
| OutpostError
|
|
185
|
+
| ResponseValidationError
|
|
186
|
+
| ConnectionError
|
|
187
|
+
| RequestAbortedError
|
|
188
|
+
| RequestTimeoutError
|
|
189
|
+
| InvalidRequestError
|
|
190
|
+
| UnexpectedClientError
|
|
191
|
+
| SDKValidationError
|
|
192
|
+
>(
|
|
193
|
+
M.json(200, components.MetricsResponse$inboundSchema),
|
|
194
|
+
M.jsonErr(400, errors.BadRequestError$inboundSchema),
|
|
195
|
+
M.jsonErr(401, errors.UnauthorizedError$inboundSchema),
|
|
196
|
+
M.jsonErr(403, errors.APIErrorResponse$inboundSchema),
|
|
197
|
+
M.jsonErr(500, errors.InternalServerError$inboundSchema),
|
|
198
|
+
M.fail("4XX"),
|
|
199
|
+
M.fail("5XX"),
|
|
200
|
+
)(response, req, { extraFields: responseFields });
|
|
201
|
+
if (!result.ok) {
|
|
202
|
+
return [result, { status: "complete", request: req, response }];
|
|
203
|
+
}
|
|
204
|
+
|
|
205
|
+
return [result, { status: "complete", request: req, response }];
|
|
206
|
+
}
|
|
@@ -0,0 +1,200 @@
|
|
|
1
|
+
/*
|
|
2
|
+
* Code generated by Speakeasy (https://speakeasy.com). DO NOT EDIT.
|
|
3
|
+
*/
|
|
4
|
+
|
|
5
|
+
import { OutpostCore } from "../core.js";
|
|
6
|
+
import { encodeFormQuery } from "../lib/encodings.js";
|
|
7
|
+
import * as M from "../lib/matchers.js";
|
|
8
|
+
import { compactMap } from "../lib/primitives.js";
|
|
9
|
+
import { safeParse } from "../lib/schemas.js";
|
|
10
|
+
import { RequestOptions } from "../lib/sdks.js";
|
|
11
|
+
import { extractSecurity, resolveGlobalSecurity } from "../lib/security.js";
|
|
12
|
+
import { pathToFunc } from "../lib/url.js";
|
|
13
|
+
import * as components from "../models/components/index.js";
|
|
14
|
+
import {
|
|
15
|
+
ConnectionError,
|
|
16
|
+
InvalidRequestError,
|
|
17
|
+
RequestAbortedError,
|
|
18
|
+
RequestTimeoutError,
|
|
19
|
+
UnexpectedClientError,
|
|
20
|
+
} from "../models/errors/httpclienterrors.js";
|
|
21
|
+
import * as errors from "../models/errors/index.js";
|
|
22
|
+
import { OutpostError } from "../models/errors/outposterror.js";
|
|
23
|
+
import { ResponseValidationError } from "../models/errors/responsevalidationerror.js";
|
|
24
|
+
import { SDKValidationError } from "../models/errors/sdkvalidationerror.js";
|
|
25
|
+
import * as operations from "../models/operations/index.js";
|
|
26
|
+
import { APICall, APIPromise } from "../types/async.js";
|
|
27
|
+
import { Result } from "../types/fp.js";
|
|
28
|
+
|
|
29
|
+
/**
|
|
30
|
+
* Get Event Metrics
|
|
31
|
+
*
|
|
32
|
+
* @remarks
|
|
33
|
+
* Returns aggregated event publish metrics. Supports time bucketing via granularity,
|
|
34
|
+
* dimensional grouping, and filtering.
|
|
35
|
+
*
|
|
36
|
+
* **Measures:** `count`, `rate`
|
|
37
|
+
*
|
|
38
|
+
* **Dimensions:** `tenant_id` (admin-only), `topic`, `destination_id`
|
|
39
|
+
*
|
|
40
|
+
* **Filters:** `tenant_id` (admin-only), `topic`, `destination_id`
|
|
41
|
+
*/
|
|
42
|
+
export function metricsGetEventMetrics(
|
|
43
|
+
client: OutpostCore,
|
|
44
|
+
request: operations.GetEventMetricsRequest,
|
|
45
|
+
options?: RequestOptions,
|
|
46
|
+
): APIPromise<
|
|
47
|
+
Result<
|
|
48
|
+
components.MetricsResponse,
|
|
49
|
+
| errors.BadRequestError
|
|
50
|
+
| errors.UnauthorizedError
|
|
51
|
+
| errors.APIErrorResponse
|
|
52
|
+
| errors.InternalServerError
|
|
53
|
+
| OutpostError
|
|
54
|
+
| ResponseValidationError
|
|
55
|
+
| ConnectionError
|
|
56
|
+
| RequestAbortedError
|
|
57
|
+
| RequestTimeoutError
|
|
58
|
+
| InvalidRequestError
|
|
59
|
+
| UnexpectedClientError
|
|
60
|
+
| SDKValidationError
|
|
61
|
+
>
|
|
62
|
+
> {
|
|
63
|
+
return new APIPromise($do(
|
|
64
|
+
client,
|
|
65
|
+
request,
|
|
66
|
+
options,
|
|
67
|
+
));
|
|
68
|
+
}
|
|
69
|
+
|
|
70
|
+
async function $do(
|
|
71
|
+
client: OutpostCore,
|
|
72
|
+
request: operations.GetEventMetricsRequest,
|
|
73
|
+
options?: RequestOptions,
|
|
74
|
+
): Promise<
|
|
75
|
+
[
|
|
76
|
+
Result<
|
|
77
|
+
components.MetricsResponse,
|
|
78
|
+
| errors.BadRequestError
|
|
79
|
+
| errors.UnauthorizedError
|
|
80
|
+
| errors.APIErrorResponse
|
|
81
|
+
| errors.InternalServerError
|
|
82
|
+
| OutpostError
|
|
83
|
+
| ResponseValidationError
|
|
84
|
+
| ConnectionError
|
|
85
|
+
| RequestAbortedError
|
|
86
|
+
| RequestTimeoutError
|
|
87
|
+
| InvalidRequestError
|
|
88
|
+
| UnexpectedClientError
|
|
89
|
+
| SDKValidationError
|
|
90
|
+
>,
|
|
91
|
+
APICall,
|
|
92
|
+
]
|
|
93
|
+
> {
|
|
94
|
+
const parsed = safeParse(
|
|
95
|
+
request,
|
|
96
|
+
(value) => operations.GetEventMetricsRequest$outboundSchema.parse(value),
|
|
97
|
+
"Input validation failed",
|
|
98
|
+
);
|
|
99
|
+
if (!parsed.ok) {
|
|
100
|
+
return [parsed, { status: "invalid" }];
|
|
101
|
+
}
|
|
102
|
+
const payload = parsed.value;
|
|
103
|
+
const body = null;
|
|
104
|
+
|
|
105
|
+
const path = pathToFunc("/metrics/events")();
|
|
106
|
+
|
|
107
|
+
const query = encodeFormQuery({
|
|
108
|
+
"dimensions": payload.dimensions,
|
|
109
|
+
"filters[destination_id]": payload["filters[destination_id]"],
|
|
110
|
+
"filters[tenant_id]": payload["filters[tenant_id]"],
|
|
111
|
+
"filters[topic]": payload["filters[topic]"],
|
|
112
|
+
"granularity": payload.granularity,
|
|
113
|
+
"measures": payload.measures,
|
|
114
|
+
"time[end]": payload["time[end]"],
|
|
115
|
+
"time[start]": payload["time[start]"],
|
|
116
|
+
});
|
|
117
|
+
|
|
118
|
+
const headers = new Headers(compactMap({
|
|
119
|
+
Accept: "application/json",
|
|
120
|
+
}));
|
|
121
|
+
|
|
122
|
+
const secConfig = await extractSecurity(client._options.apiKey);
|
|
123
|
+
const securityInput = secConfig == null ? {} : { apiKey: secConfig };
|
|
124
|
+
const requestSecurity = resolveGlobalSecurity(securityInput);
|
|
125
|
+
|
|
126
|
+
const context = {
|
|
127
|
+
options: client._options,
|
|
128
|
+
baseURL: options?.serverURL ?? client._baseURL ?? "",
|
|
129
|
+
operationID: "getEventMetrics",
|
|
130
|
+
oAuth2Scopes: null,
|
|
131
|
+
|
|
132
|
+
resolvedSecurity: requestSecurity,
|
|
133
|
+
|
|
134
|
+
securitySource: client._options.apiKey,
|
|
135
|
+
retryConfig: options?.retries
|
|
136
|
+
|| client._options.retryConfig
|
|
137
|
+
|| { strategy: "none" },
|
|
138
|
+
retryCodes: options?.retryCodes || ["429", "500", "502", "503", "504"],
|
|
139
|
+
};
|
|
140
|
+
|
|
141
|
+
const requestRes = client._createRequest(context, {
|
|
142
|
+
security: requestSecurity,
|
|
143
|
+
method: "GET",
|
|
144
|
+
baseURL: options?.serverURL,
|
|
145
|
+
path: path,
|
|
146
|
+
headers: headers,
|
|
147
|
+
query: query,
|
|
148
|
+
body: body,
|
|
149
|
+
userAgent: client._options.userAgent,
|
|
150
|
+
timeoutMs: options?.timeoutMs || client._options.timeoutMs || -1,
|
|
151
|
+
}, options);
|
|
152
|
+
if (!requestRes.ok) {
|
|
153
|
+
return [requestRes, { status: "invalid" }];
|
|
154
|
+
}
|
|
155
|
+
const req = requestRes.value;
|
|
156
|
+
|
|
157
|
+
const doResult = await client._do(req, {
|
|
158
|
+
context,
|
|
159
|
+
errorCodes: ["400", "401", "403", "4XX", "500", "5XX"],
|
|
160
|
+
retryConfig: context.retryConfig,
|
|
161
|
+
retryCodes: context.retryCodes,
|
|
162
|
+
});
|
|
163
|
+
if (!doResult.ok) {
|
|
164
|
+
return [doResult, { status: "request-error", request: req }];
|
|
165
|
+
}
|
|
166
|
+
const response = doResult.value;
|
|
167
|
+
|
|
168
|
+
const responseFields = {
|
|
169
|
+
HttpMeta: { Response: response, Request: req },
|
|
170
|
+
};
|
|
171
|
+
|
|
172
|
+
const [result] = await M.match<
|
|
173
|
+
components.MetricsResponse,
|
|
174
|
+
| errors.BadRequestError
|
|
175
|
+
| errors.UnauthorizedError
|
|
176
|
+
| errors.APIErrorResponse
|
|
177
|
+
| errors.InternalServerError
|
|
178
|
+
| OutpostError
|
|
179
|
+
| ResponseValidationError
|
|
180
|
+
| ConnectionError
|
|
181
|
+
| RequestAbortedError
|
|
182
|
+
| RequestTimeoutError
|
|
183
|
+
| InvalidRequestError
|
|
184
|
+
| UnexpectedClientError
|
|
185
|
+
| SDKValidationError
|
|
186
|
+
>(
|
|
187
|
+
M.json(200, components.MetricsResponse$inboundSchema),
|
|
188
|
+
M.jsonErr(400, errors.BadRequestError$inboundSchema),
|
|
189
|
+
M.jsonErr(401, errors.UnauthorizedError$inboundSchema),
|
|
190
|
+
M.jsonErr(403, errors.APIErrorResponse$inboundSchema),
|
|
191
|
+
M.jsonErr(500, errors.InternalServerError$inboundSchema),
|
|
192
|
+
M.fail("4XX"),
|
|
193
|
+
M.fail("5XX"),
|
|
194
|
+
)(response, req, { extraFields: responseFields });
|
|
195
|
+
if (!result.ok) {
|
|
196
|
+
return [result, { status: "complete", request: req, response }];
|
|
197
|
+
}
|
|
198
|
+
|
|
199
|
+
return [result, { status: "complete", request: req, response }];
|
|
200
|
+
}
|
package/src/funcs/tenantsGet.ts
CHANGED
package/src/lib/config.ts
CHANGED
|
@@ -65,8 +65,8 @@ export function serverURLFromOptions(options: SDKOptions): URL | null {
|
|
|
65
65
|
export const SDK_METADATA = {
|
|
66
66
|
language: "typescript",
|
|
67
67
|
openapiDocVersion: "0.0.1",
|
|
68
|
-
sdkVersion: "0.9.
|
|
69
|
-
genVersion: "2.
|
|
68
|
+
sdkVersion: "0.9.2",
|
|
69
|
+
genVersion: "2.869.10",
|
|
70
70
|
userAgent:
|
|
71
|
-
"speakeasy-sdk/typescript 0.9.
|
|
71
|
+
"speakeasy-sdk/typescript 0.9.2 2.869.10 0.0.1 @hookdeck/outpost-sdk",
|
|
72
72
|
} as const;
|
package/src/lib/files.ts
CHANGED
|
@@ -80,3 +80,25 @@ export function getContentTypeFromFileName(fileName: string): string | null {
|
|
|
80
80
|
|
|
81
81
|
return mimeTypes[ext] || null;
|
|
82
82
|
}
|
|
83
|
+
|
|
84
|
+
/**
|
|
85
|
+
* Creates a Blob from file content with the given MIME type.
|
|
86
|
+
*
|
|
87
|
+
* Node.js Buffers are Uint8Array subclasses that may share a pooled
|
|
88
|
+
* ArrayBuffer (byteOffset > 0, byteLength < buffer.byteLength). Passing
|
|
89
|
+
* such a Buffer directly to `new Blob([buf])` can include the entire
|
|
90
|
+
* underlying pool on some runtimes, producing a Blob with extra bytes
|
|
91
|
+
* that corrupts multipart uploads.
|
|
92
|
+
*
|
|
93
|
+
* Copying into a standalone Uint8Array ensures the Blob receives only the
|
|
94
|
+
* intended bytes regardless of runtime behaviour.
|
|
95
|
+
*/
|
|
96
|
+
export function bytesToBlob(
|
|
97
|
+
content: Uint8Array<ArrayBufferLike> | ArrayBuffer | Blob | string,
|
|
98
|
+
contentType: string,
|
|
99
|
+
): Blob {
|
|
100
|
+
if (content instanceof Uint8Array) {
|
|
101
|
+
return new Blob([new Uint8Array(content)], { type: contentType });
|
|
102
|
+
}
|
|
103
|
+
return new Blob([content as BlobPart], { type: contentType });
|
|
104
|
+
}
|
package/src/lib/sdks.ts
CHANGED
|
@@ -124,13 +124,15 @@ export class ClientSDK {
|
|
|
124
124
|
if (!base) {
|
|
125
125
|
return ERR(new InvalidRequestError("No base URL provided for operation"));
|
|
126
126
|
}
|
|
127
|
-
const
|
|
128
|
-
|
|
129
|
-
|
|
127
|
+
const baseURL = new URL(base);
|
|
128
|
+
let reqURL: URL;
|
|
130
129
|
if (path) {
|
|
131
|
-
|
|
132
|
-
reqURL
|
|
130
|
+
baseURL.pathname = baseURL.pathname.replace(/\/+$/, "") + "/";
|
|
131
|
+
reqURL = new URL(path, baseURL);
|
|
132
|
+
} else {
|
|
133
|
+
reqURL = baseURL;
|
|
133
134
|
}
|
|
135
|
+
reqURL.hash = "";
|
|
134
136
|
|
|
135
137
|
let finalQuery = query || "";
|
|
136
138
|
|
package/src/lib/url.ts
CHANGED
|
@@ -13,21 +13,23 @@ export function pathToFunc(
|
|
|
13
13
|
const paramRE = /\{([a-zA-Z0-9_][a-zA-Z0-9_-]*?)\}/g;
|
|
14
14
|
|
|
15
15
|
return function buildURLPath(params: Record<string, unknown> = {}): string {
|
|
16
|
-
return pathPattern
|
|
17
|
-
|
|
18
|
-
|
|
19
|
-
|
|
16
|
+
return pathPattern
|
|
17
|
+
.replace(paramRE, function (_, placeholder) {
|
|
18
|
+
if (!hasOwn.call(params, placeholder)) {
|
|
19
|
+
throw new Error(`Parameter '${placeholder}' is required`);
|
|
20
|
+
}
|
|
20
21
|
|
|
21
|
-
|
|
22
|
-
|
|
23
|
-
|
|
24
|
-
|
|
25
|
-
|
|
26
|
-
|
|
22
|
+
const value = params[placeholder];
|
|
23
|
+
if (typeof value !== "string" && typeof value !== "number") {
|
|
24
|
+
throw new Error(
|
|
25
|
+
`Parameter '${placeholder}' must be a string or number`,
|
|
26
|
+
);
|
|
27
|
+
}
|
|
27
28
|
|
|
28
|
-
|
|
29
|
-
|
|
30
|
-
|
|
31
|
-
|
|
29
|
+
return options?.charEncoding === "percent"
|
|
30
|
+
? encodeURIComponent(`${value}`)
|
|
31
|
+
: `${value}`;
|
|
32
|
+
})
|
|
33
|
+
.replace(/^\/+/, "");
|
|
32
34
|
};
|
|
33
35
|
}
|
package/src/mcp-server/server.ts
CHANGED
|
@@ -28,6 +28,8 @@ import { tool$destinationsUpdate } from "./tools/destinationsUpdate.js";
|
|
|
28
28
|
import { tool$eventsGet } from "./tools/eventsGet.js";
|
|
29
29
|
import { tool$eventsList } from "./tools/eventsList.js";
|
|
30
30
|
import { tool$healthCheck } from "./tools/healthCheck.js";
|
|
31
|
+
import { tool$metricsGetAttemptMetrics } from "./tools/metricsGetAttemptMetrics.js";
|
|
32
|
+
import { tool$metricsGetEventMetrics } from "./tools/metricsGetEventMetrics.js";
|
|
31
33
|
import { tool$publishEvent } from "./tools/publishEvent.js";
|
|
32
34
|
import { tool$schemasGetDestinationType } from "./tools/schemasGetDestinationType.js";
|
|
33
35
|
import { tool$schemasListDestinationTypes } from "./tools/schemasListDestinationTypes.js";
|
|
@@ -49,7 +51,7 @@ export function createMCPServer(deps: {
|
|
|
49
51
|
}) {
|
|
50
52
|
const server = new McpServer({
|
|
51
53
|
name: "Outpost",
|
|
52
|
-
version: "0.9.
|
|
54
|
+
version: "0.9.2",
|
|
53
55
|
});
|
|
54
56
|
|
|
55
57
|
const client = new OutpostCore({
|
|
@@ -104,6 +106,8 @@ export function createMCPServer(deps: {
|
|
|
104
106
|
tool(tool$schemasListDestinationTypes);
|
|
105
107
|
tool(tool$schemasGetDestinationType);
|
|
106
108
|
tool(tool$topicsList);
|
|
109
|
+
tool(tool$metricsGetEventMetrics);
|
|
110
|
+
tool(tool$metricsGetAttemptMetrics);
|
|
107
111
|
|
|
108
112
|
return server;
|
|
109
113
|
}
|
|
@@ -0,0 +1,47 @@
|
|
|
1
|
+
/*
|
|
2
|
+
* Code generated by Speakeasy (https://speakeasy.com). DO NOT EDIT.
|
|
3
|
+
*/
|
|
4
|
+
|
|
5
|
+
import { metricsGetAttemptMetrics } from "../../funcs/metricsGetAttemptMetrics.js";
|
|
6
|
+
import * as operations from "../../models/operations/index.js";
|
|
7
|
+
import { formatResult, ToolDefinition } from "../tools.js";
|
|
8
|
+
|
|
9
|
+
const args = {
|
|
10
|
+
request: operations.GetAttemptMetricsRequest$inboundSchema,
|
|
11
|
+
};
|
|
12
|
+
|
|
13
|
+
export const tool$metricsGetAttemptMetrics: ToolDefinition<typeof args> = {
|
|
14
|
+
name: "metrics-get-attempt-metrics",
|
|
15
|
+
description: `Get Attempt Metrics
|
|
16
|
+
|
|
17
|
+
Returns aggregated delivery attempt metrics. Supports time bucketing via granularity,
|
|
18
|
+
dimensional grouping, and filtering.
|
|
19
|
+
|
|
20
|
+
**Measures:** \`count\`, \`successful_count\`, \`failed_count\`, \`error_rate\`,
|
|
21
|
+
\`first_attempt_count\`, \`retry_count\`, \`manual_retry_count\`, \`avg_attempt_number\`,
|
|
22
|
+
\`rate\`, \`successful_rate\`, \`failed_rate\`
|
|
23
|
+
|
|
24
|
+
**Dimensions:** \`tenant_id\` (admin-only), \`destination_id\`, \`topic\`, \`status\`, \`code\`, \`manual\`, \`attempt_number\`
|
|
25
|
+
|
|
26
|
+
**Filters:** \`tenant_id\` (admin-only), \`destination_id\`, \`topic\`, \`status\`, \`code\`, \`manual\`, \`attempt_number\`
|
|
27
|
+
`,
|
|
28
|
+
args,
|
|
29
|
+
tool: async (client, args, ctx) => {
|
|
30
|
+
const [result, apiCall] = await metricsGetAttemptMetrics(
|
|
31
|
+
client,
|
|
32
|
+
args.request,
|
|
33
|
+
{ fetchOptions: { signal: ctx.signal } },
|
|
34
|
+
).$inspect();
|
|
35
|
+
|
|
36
|
+
if (!result.ok) {
|
|
37
|
+
return {
|
|
38
|
+
content: [{ type: "text", text: result.error.message }],
|
|
39
|
+
isError: true,
|
|
40
|
+
};
|
|
41
|
+
}
|
|
42
|
+
|
|
43
|
+
const value = result.value;
|
|
44
|
+
|
|
45
|
+
return formatResult(value, apiCall);
|
|
46
|
+
},
|
|
47
|
+
};
|