-
Notifications
You must be signed in to change notification settings - Fork 0
/
recipesGetById.ts
116 lines (106 loc) · 2.91 KB
/
recipesGetById.ts
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
/*
* Code generated by Speakeasy (https://speakeasy.com). DO NOT EDIT.
*/
import { SpeakeasyRecipeBookCore } from "../core.js";
import { encodeSimple } from "../lib/encodings.js";
import * as M from "../lib/matchers.js";
import { safeParse } from "../lib/schemas.js";
import { RequestOptions } from "../lib/sdks.js";
import { pathToFunc } from "../lib/url.js";
import * as custom_components from "../models/custom_components/index.js";
import {
ConnectionError,
InvalidRequestError,
RequestAbortedError,
RequestTimeoutError,
UnexpectedClientError,
} from "../models/custom_errors/httpclienterrors.js";
import { SDKError } from "../models/custom_errors/sdkerror.js";
import { SDKValidationError } from "../models/custom_errors/sdkvalidationerror.js";
import * as custom_operations from "../models/custom_operations/index.js";
import { Result } from "../types/fp.js";
/**
* Get a recipe by ID
*/
export async function recipesGetById(
client: SpeakeasyRecipeBookCore,
request: custom_operations.GetRecipeByIdRequest,
options?: RequestOptions,
): Promise<
Result<
custom_components.Recipe,
| SDKError
| SDKValidationError
| UnexpectedClientError
| InvalidRequestError
| RequestAbortedError
| RequestTimeoutError
| ConnectionError
>
> {
const parsed = safeParse(
request,
(value) =>
custom_operations.GetRecipeByIdRequest$outboundSchema.parse(value),
"Input validation failed",
);
if (!parsed.ok) {
return parsed;
}
const payload = parsed.value;
const body = null;
const pathParams = {
recipeId: encodeSimple("recipeId", payload.recipeId, {
explode: false,
charEncoding: "percent",
}),
};
const path = pathToFunc("/recipes/{recipeId}")(pathParams);
const headers = new Headers({
Accept: "application/json",
});
const context = {
operationID: "getRecipeById",
oAuth2Scopes: [],
securitySource: null,
};
const requestRes = client._createRequest(context, {
method: "GET",
path: path,
headers: headers,
body: body,
timeoutMs: options?.timeoutMs || client._options.timeoutMs || -1,
}, options);
if (!requestRes.ok) {
return requestRes;
}
const req = requestRes.value;
const doResult = await client._do(req, {
context,
errorCodes: ["404", "4XX", "5XX"],
retryConfig: options?.retries
|| client._options.retryConfig,
retryCodes: options?.retryCodes || ["429", "500", "502", "503", "504"],
});
if (!doResult.ok) {
return doResult;
}
const response = doResult.value;
const [result] = await M.match<
custom_components.Recipe,
| SDKError
| SDKValidationError
| UnexpectedClientError
| InvalidRequestError
| RequestAbortedError
| RequestTimeoutError
| ConnectionError
>(
M.json(200, custom_components.Recipe$inboundSchema),
M.fail([404, "4XX", "5XX"]),
)(response);
if (!result.ok) {
return result;
}
return result;
}