@apifuse/provider-sdk 2.1.0-beta.1 → 2.1.0-beta.10

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.
Files changed (212) hide show
  1. package/AUTHORING.md +208 -2
  2. package/CHANGELOG.md +47 -0
  3. package/README.md +114 -10
  4. package/SUBMISSION.md +87 -0
  5. package/bin/apifuse-check.ts +86 -4
  6. package/bin/apifuse-dev.ts +87 -13
  7. package/bin/apifuse-pack-check.ts +80 -0
  8. package/bin/apifuse-pack-smoke.ts +303 -2
  9. package/bin/apifuse-perf.ts +142 -49
  10. package/bin/apifuse-record.ts +182 -104
  11. package/bin/apifuse-submit-check.ts +2538 -0
  12. package/bin/apifuse.ts +1 -1
  13. package/dist/ceremonies/index.d.ts +41 -0
  14. package/dist/ceremonies/index.js +490 -0
  15. package/dist/choice-token.d.ts +24 -0
  16. package/dist/choice-token.js +74 -0
  17. package/dist/cli/commands.d.ts +10 -0
  18. package/dist/cli/commands.js +80 -0
  19. package/dist/cli/create.d.ts +47 -0
  20. package/dist/cli/create.js +762 -0
  21. package/dist/cli/templates/provider/.dockerignore.tpl +22 -0
  22. package/dist/cli/templates/provider/.gitignore.tpl +22 -0
  23. package/dist/cli/templates/provider/Dockerfile.tpl +7 -0
  24. package/dist/cli/templates/provider/README.md.tpl +160 -0
  25. package/dist/cli/templates/provider/dev.ts.tpl +5 -0
  26. package/dist/cli/templates/provider/domain/README.md.tpl +3 -0
  27. package/dist/cli/templates/provider/index.test.ts.tpl +13 -0
  28. package/dist/cli/templates/provider/index.ts.tpl +15 -0
  29. package/dist/cli/templates/provider/mappers/README.md.tpl +3 -0
  30. package/dist/cli/templates/provider/meta.ts.tpl +7 -0
  31. package/dist/cli/templates/provider/operations/index.ts.tpl +5 -0
  32. package/dist/cli/templates/provider/operations/ping.ts.tpl +24 -0
  33. package/dist/cli/templates/provider/schemas/ping.ts.tpl +24 -0
  34. package/dist/cli/templates/provider/start.ts.tpl +5 -0
  35. package/dist/cli/templates/provider/upstream/README.md.tpl +3 -0
  36. package/dist/config/loader.d.ts +107 -0
  37. package/dist/config/loader.js +935 -0
  38. package/dist/contract-json.d.ts +9 -0
  39. package/dist/contract-json.js +51 -0
  40. package/dist/contract-serialization.d.ts +4 -0
  41. package/dist/contract-serialization.js +78 -0
  42. package/dist/contract-types.d.ts +49 -0
  43. package/dist/contract-types.js +1 -0
  44. package/dist/contract.d.ts +6 -0
  45. package/dist/contract.js +155 -0
  46. package/dist/define.d.ts +97 -0
  47. package/dist/define.js +1320 -0
  48. package/dist/dev.d.ts +9 -0
  49. package/dist/dev.js +15 -0
  50. package/dist/errors.d.ts +59 -0
  51. package/dist/errors.js +97 -0
  52. package/dist/i18n/catalog.d.ts +29 -0
  53. package/dist/i18n/catalog.js +159 -0
  54. package/dist/i18n/index.d.ts +2 -0
  55. package/dist/i18n/index.js +2 -0
  56. package/dist/i18n/keys.d.ts +10 -0
  57. package/dist/i18n/keys.js +34 -0
  58. package/dist/index.d.ts +41 -0
  59. package/dist/index.js +37 -0
  60. package/dist/lint.d.ts +73 -0
  61. package/dist/lint.js +702 -0
  62. package/dist/observability.d.ts +5 -0
  63. package/dist/observability.js +39 -0
  64. package/dist/provider.d.ts +9 -0
  65. package/dist/provider.js +8 -0
  66. package/dist/public-schema-field-lint.d.ts +2 -0
  67. package/dist/public-schema-field-lint.js +158 -0
  68. package/dist/recipes/gov-api.d.ts +19 -0
  69. package/dist/recipes/gov-api.js +72 -0
  70. package/dist/recipes/rest-api.d.ts +21 -0
  71. package/dist/recipes/rest-api.js +115 -0
  72. package/dist/runtime/auth-flow.d.ts +14 -0
  73. package/dist/runtime/auth-flow.js +44 -0
  74. package/dist/runtime/browser.d.ts +25 -0
  75. package/dist/runtime/browser.js +1034 -0
  76. package/dist/runtime/cache.d.ts +10 -0
  77. package/dist/runtime/cache.js +372 -0
  78. package/dist/runtime/choice.d.ts +15 -0
  79. package/dist/runtime/choice.js +435 -0
  80. package/dist/runtime/credential.d.ts +8 -0
  81. package/dist/runtime/credential.js +61 -0
  82. package/dist/runtime/env.d.ts +2 -0
  83. package/dist/runtime/env.js +10 -0
  84. package/dist/runtime/executor.d.ts +16 -0
  85. package/dist/runtime/executor.js +51 -0
  86. package/dist/runtime/http.d.ts +8 -0
  87. package/dist/runtime/http.js +706 -0
  88. package/dist/runtime/insights.d.ts +9 -0
  89. package/dist/runtime/insights.js +324 -0
  90. package/dist/runtime/instrumentation.d.ts +8 -0
  91. package/dist/runtime/instrumentation.js +269 -0
  92. package/dist/runtime/key-derivation.d.ts +24 -0
  93. package/dist/runtime/key-derivation.js +73 -0
  94. package/dist/runtime/keyring.d.ts +25 -0
  95. package/dist/runtime/keyring.js +93 -0
  96. package/dist/runtime/namespace.d.ts +9 -0
  97. package/dist/runtime/namespace.js +19 -0
  98. package/dist/runtime/otlp.d.ts +39 -0
  99. package/dist/runtime/otlp.js +103 -0
  100. package/dist/runtime/perf.d.ts +12 -0
  101. package/dist/runtime/perf.js +52 -0
  102. package/dist/runtime/prevalidate.d.ts +12 -0
  103. package/dist/runtime/prevalidate.js +173 -0
  104. package/dist/runtime/provider.d.ts +2 -0
  105. package/dist/runtime/provider.js +11 -0
  106. package/dist/runtime/proxy-errors.d.ts +21 -0
  107. package/dist/runtime/proxy-errors.js +83 -0
  108. package/dist/runtime/proxy-telemetry.d.ts +8 -0
  109. package/dist/runtime/proxy-telemetry.js +174 -0
  110. package/dist/runtime/redis.d.ts +17 -0
  111. package/dist/runtime/redis.js +82 -0
  112. package/dist/runtime/request-options.d.ts +3 -0
  113. package/dist/runtime/request-options.js +42 -0
  114. package/dist/runtime/state.d.ts +17 -0
  115. package/dist/runtime/state.js +344 -0
  116. package/dist/runtime/stealth.d.ts +18 -0
  117. package/dist/runtime/stealth.js +834 -0
  118. package/dist/runtime/stt.d.ts +22 -0
  119. package/dist/runtime/stt.js +480 -0
  120. package/dist/runtime/trace.d.ts +26 -0
  121. package/dist/runtime/trace.js +142 -0
  122. package/dist/runtime/waterfall.d.ts +12 -0
  123. package/dist/runtime/waterfall.js +147 -0
  124. package/dist/schema.d.ts +74 -0
  125. package/dist/schema.js +243 -0
  126. package/dist/serve.d.ts +1 -0
  127. package/dist/serve.js +1 -0
  128. package/dist/server/index.d.ts +3 -0
  129. package/dist/server/index.js +2 -0
  130. package/dist/server/serve.d.ts +64 -0
  131. package/dist/server/serve.js +1110 -0
  132. package/dist/server/types.d.ts +136 -0
  133. package/dist/server/types.js +86 -0
  134. package/dist/stealth/profiles.d.ts +4 -0
  135. package/dist/stealth/profiles.js +259 -0
  136. package/dist/stream.d.ts +44 -0
  137. package/dist/stream.js +151 -0
  138. package/dist/testing/helpers.d.ts +23 -0
  139. package/dist/testing/helpers.js +95 -0
  140. package/dist/testing/index.d.ts +2 -0
  141. package/dist/testing/index.js +2 -0
  142. package/dist/testing/run.d.ts +34 -0
  143. package/dist/testing/run.js +303 -0
  144. package/dist/types.d.ts +1326 -0
  145. package/dist/types.js +61 -0
  146. package/dist/utils/date.d.ts +6 -0
  147. package/dist/utils/date.js +101 -0
  148. package/dist/utils/parse.d.ts +16 -0
  149. package/dist/utils/parse.js +51 -0
  150. package/dist/utils/text.d.ts +4 -0
  151. package/dist/utils/text.js +14 -0
  152. package/dist/utils/transform.d.ts +8 -0
  153. package/dist/utils/transform.js +48 -0
  154. package/package.json +57 -30
  155. package/src/ceremonies/index.ts +8 -2
  156. package/src/choice-token.ts +165 -0
  157. package/src/cli/commands.ts +34 -11
  158. package/src/cli/create.ts +214 -52
  159. package/src/cli/templates/provider/.dockerignore.tpl +22 -0
  160. package/src/cli/templates/provider/.gitignore.tpl +22 -0
  161. package/src/cli/templates/provider/README.md.tpl +120 -1
  162. package/src/cli/templates/provider/dev.ts.tpl +1 -1
  163. package/src/cli/templates/provider/domain/README.md.tpl +3 -0
  164. package/src/cli/templates/provider/index.ts.tpl +5 -48
  165. package/src/cli/templates/provider/mappers/README.md.tpl +3 -0
  166. package/src/cli/templates/provider/meta.ts.tpl +7 -0
  167. package/src/cli/templates/provider/operations/index.ts.tpl +5 -0
  168. package/src/cli/templates/provider/operations/ping.ts.tpl +24 -0
  169. package/src/cli/templates/provider/schemas/ping.ts.tpl +24 -0
  170. package/src/cli/templates/provider/start.ts.tpl +1 -1
  171. package/src/cli/templates/provider/upstream/README.md.tpl +3 -0
  172. package/src/config/loader.ts +1224 -9
  173. package/src/contract-json.ts +75 -0
  174. package/src/contract-serialization.ts +89 -0
  175. package/src/contract-types.ts +52 -0
  176. package/src/contract.ts +215 -0
  177. package/src/define.ts +1688 -48
  178. package/src/errors.ts +27 -0
  179. package/src/i18n/catalog.ts +277 -0
  180. package/src/i18n/index.ts +2 -0
  181. package/src/i18n/keys.ts +64 -0
  182. package/src/index.ts +174 -9
  183. package/src/lint.ts +547 -73
  184. package/src/observability.ts +41 -0
  185. package/src/provider.ts +104 -4
  186. package/src/public-schema-field-lint.ts +237 -0
  187. package/src/runtime/auth-flow.ts +7 -0
  188. package/src/runtime/browser.ts +762 -51
  189. package/src/runtime/cache.ts +528 -0
  190. package/src/runtime/choice.ts +760 -0
  191. package/src/runtime/executor.ts +32 -3
  192. package/src/runtime/http.ts +939 -195
  193. package/src/runtime/insights.ts +11 -11
  194. package/src/runtime/instrumentation.ts +12 -4
  195. package/src/runtime/key-derivation.ts +1 -1
  196. package/src/runtime/keyring.ts +4 -3
  197. package/src/runtime/proxy-errors.ts +132 -0
  198. package/src/runtime/proxy-telemetry.ts +253 -0
  199. package/src/runtime/redis.ts +116 -0
  200. package/src/runtime/request-options.ts +66 -0
  201. package/src/runtime/state.ts +563 -0
  202. package/src/runtime/stealth.ts +1159 -0
  203. package/src/runtime/stt.ts +629 -0
  204. package/src/runtime/trace.ts +1 -1
  205. package/src/schema.ts +363 -1
  206. package/src/server/serve.ts +1157 -75
  207. package/src/server/types.ts +37 -0
  208. package/src/stream.ts +210 -0
  209. package/src/testing/run.ts +31 -5
  210. package/src/types.ts +1107 -59
  211. package/src/runtime/tls.ts +0 -434
  212. package/src/types/playwright-stealth.d.ts +0 -9
@@ -8,6 +8,65 @@ Generated with `apifuse create`.
8
8
  bun run dev
9
9
  bun run check
10
10
  bun run test
11
+ bun run submit-check
12
+ ```
13
+
14
+
15
+ ## Module layout
16
+
17
+ The generated provider uses the recommended split layout:
18
+
19
+ ```text
20
+ index.ts # composition root: defineProvider() and wiring only
21
+ meta.ts # provider metadata
22
+ operations/ # APIFuse operation contracts and handlers
23
+ schemas/ # public input/output schemas near operations
24
+ upstream/ # upstream ceremony: clients, auth, request builders
25
+ mappers/ # upstream-to-APIFuse normalization helpers
26
+ domain/ # shared provider-specific business ceremony
27
+ ```
28
+
29
+ Small providers may stay in one file, but larger providers are easier to
30
+ review when `index.ts` remains a short composition root.
31
+
32
+ ## Pre-submission report
33
+
34
+ Before posting bounty evidence, run:
35
+
36
+ ```bash
37
+ bun run submit-check
38
+ ```
39
+
40
+ This writes `submission-report.md` with a review-readiness score, blockers,
41
+ warnings, health coverage notes, fixture/schema evidence, and remediation. A
42
+ score is not a payout guarantee; blockers must be fixed before maintainer
43
+ review. The generated `ping` starter intentionally warns until you replace it
44
+ with real upstream-backed Operations. The full public-only checklist is shipped
45
+ in `node_modules/@apifuse/provider-sdk/SUBMISSION.md`.
46
+
47
+
48
+ ## Operation guide
49
+
50
+ ### Parameters
51
+
52
+ Starter `ping` accepts `{ "value": string }`. Replace this section with each
53
+ real operation's input schema, required fields, formats, limits, and examples
54
+ before submitting bounty evidence.
55
+
56
+ ### Response
57
+
58
+ Starter `ping` returns `{ "ok": boolean, "message": string }`. Replace this
59
+ section with the normalized response fields, units, enum values, pagination,
60
+ and upstream caveats for each real operation.
61
+
62
+ ### Example
63
+
64
+ ```json
65
+ {
66
+ "requestId": "req_local_ping",
67
+ "input": { "value": "hello" },
68
+ "headers": {}
69
+ }
11
70
  ```
12
71
 
13
72
  ## Provider server contract
@@ -21,13 +80,55 @@ bun run test
21
80
  - `POST /auth/poll`
22
81
  - `POST /auth/disconnect`
23
82
 
83
+ ## Local smoke
84
+
85
+ ```bash
86
+ curl -s http://localhost:3900/health
87
+ curl -s -X POST http://localhost:3900/v1/ping \
88
+ -H 'Content-Type: application/json' \
89
+ -d '{"requestId":"req_local_ping","input":{"value":"hello"},"headers":{}}'
90
+ ```
91
+
92
+ The `POST /v1/{operation}` body is a request envelope:
93
+
94
+ - `requestId` is required and can be any unique local debugging string.
95
+ - `input` contains the operation input shape.
96
+ - `headers` is optional.
97
+ - `connection` is optional; omit it for no-auth/public operations. For
98
+ credential debugging, pass `{ "id", "mode", "secrets", "metadata",
99
+ "externalRef" }` with local-only secret values.
100
+
101
+ Structured errors return an `error` object with `code`, `message`,
102
+ `requestId`, and optional `details`; validation failures include field paths in
103
+ `details`, and the `apifuse dev` terminal prints a structured provider log.
104
+
105
+ ## Debugging checklist
106
+
107
+ - `invalid_request`: include `requestId` and `input`; omit `connection` for
108
+ public/no-auth operations and never send `connection: null`.
109
+ - Credentials: declare `credential.keys`, pass local-only values through
110
+ `connection.secrets`, and read them with `ctx.credential`.
111
+ - Auth flow: call `/auth/start`, then `/auth/continue` with the same `flowId`;
112
+ carry returned `contextPatch` values into the next request's `context`.
113
+ - Stealth/browser runtime: keep access-sensitive operations on `ctx.stealth.fetch()` with an
114
+ SDK stealth `profile`; the TypeScript stealth runtime uses `impit` internally.
115
+ `ctx.stealth` supports Chrome/Firefox-style profiles. For TypeScript browser
116
+ Providers or Safari-specific behavior use `browser.engine: "playwright-stealth"`
117
+ (`nodriver` is Python-runtime only), then install local Chromium with
118
+ `bunx playwright install chromium` or set `APIFUSE__CDP_POOL__URL`.
119
+
24
120
  ## Next steps
25
121
 
26
122
  1. Replace the sample `ping` operation with real upstream logic.
27
- 2. Record a real fixture with `bun run record:sample` or a provider-specific equivalent.
123
+ 2. Once the real operation declares `upstream.baseUrl` and uses `ctx.http` or
124
+ `ctx.stealth`, record a fixture with:
125
+ `bun run record -- --operation <operation> --params '<json-input>'`.
28
126
  3. Replace the starter `healthCheckUnsupported` with a real `healthCheck` for read-only upstream operations when safe.
29
127
  4. Extend tests and operation metadata until the provider is bounty-ready.
30
128
 
129
+ `apifuse record` is not expected to work with the generated local-only `ping`
130
+ operation because it intentionally has no upstream response to capture.
131
+
31
132
  ## Health-check authorship
32
133
 
33
134
  Every operation must declare exactly one of:
@@ -39,3 +140,21 @@ Every operation must declare exactly one of:
39
140
 
40
141
  The generated `ping` operation uses `healthCheckUnsupported` only because it is
41
142
  a local scaffold check, not a real upstream API probe.
143
+
144
+ `healthCheck.cases[].assertions` receives `{ data, status, durationMs, meta }`.
145
+ `data` is the parsed operation output. Use this shape in real operations:
146
+
147
+ ```ts
148
+ healthCheck: {
149
+ interval: "5m",
150
+ cases: [{
151
+ name: "lookup baseline",
152
+ input: { q: "btc" },
153
+ assertions: ({ data, status, durationMs }) => {
154
+ if (status !== 200 || data.results.length === 0 || durationMs > 3000) {
155
+ return { status: "degraded", label: "lookup baseline changed" };
156
+ }
157
+ },
158
+ }],
159
+ }
160
+ ```
@@ -2,4 +2,4 @@ import { startDevServer } from "@apifuse/provider-sdk";
2
2
 
3
3
  import provider from "./index";
4
4
 
5
- startDevServer(provider, { port: Number(process.env.PORT) || 3900 });
5
+ startDevServer(provider, { port: Number(process.env.APIFUSE__RUNTIME__PORT) || 3900 });
@@ -0,0 +1,3 @@
1
+ # Domain
2
+
3
+ Put provider-specific business ceremony here when it is shared across operations and too complex to live inside one operation module.
@@ -1,24 +1,7 @@
1
- import { defineProvider, z } from "@apifuse/provider-sdk";
1
+ import { defineProvider } from "@apifuse/provider-sdk/provider";
2
2
 
3
- const InputSchema = z
4
- .object({
5
- value: z
6
- .string()
7
- .default("hello")
8
- .describe("Sample input value used to verify the generated provider scaffold is wired correctly."),
9
- })
10
- .describe("Input payload for the generated ping operation.");
11
-
12
- const OutputSchema = z
13
- .object({
14
- ok: z
15
- .boolean()
16
- .describe("Whether the generated provider handled the sample request successfully."),
17
- message: z
18
- .string()
19
- .describe("Human-readable confirmation that the generated provider round-tripped the sample payload."),
20
- })
21
- .describe("Output payload returned by the generated ping operation.");
3
+ import { providerMeta } from "./meta";
4
+ import { operations } from "./operations";
22
5
 
23
6
  export default defineProvider({
24
7
  id: "{{PROVIDER_ID}}",
@@ -27,32 +10,6 @@ export default defineProvider({
27
10
  allowedHosts: ["api.example.com"],
28
11
  reviewed: "community",
29
12
  {{SECRETS_BLOCK}}{{CREDENTIAL_BLOCK}}auth: {{AUTH_BLOCK}},
30
- meta: {
31
- displayName: "{{DISPLAY_NAME}}",
32
- description: "{{DISPLAY_NAME}} provider starter for ApiFuse community contributions.",
33
- category: "{{CATEGORY}}",
34
- tags: ["{{PROVIDER_ID}}", "starter", "community"],
35
- },
36
- operations: {
37
- ping: {
38
- description:
39
- "Confirms the generated provider wiring is operational by echoing a small sample payload through the ApiFuse runtime contract. Use when validating local development, baseline checks, or first-pass bounty scaffolds. Do NOT use for production data retrieval or upstream-specific workflows because this starter operation exists only to prove the generated project compiles, serves, and round-trips input/output correctly. Returns a success flag plus a message containing the supplied value.",
40
- input: InputSchema,
41
- output: OutputSchema,
42
- handler: async (_ctx, input) => {
43
- return {
44
- ok: true,
45
- message: "{{DISPLAY_NAME}} received: " + input.value,
46
- };
47
- },
48
- fixtures: {
49
- request: { value: "hello" },
50
- response: { ok: true, message: "{{DISPLAY_NAME}} received: hello" },
51
- },
52
- healthCheckUnsupported: {
53
- reason:
54
- "Generated local-only scaffold operation. Replace this with a real healthCheck for upstream-backed bounty operations when safe; keep healthCheckUnsupported only for destructive, paid, credential-sensitive, or otherwise unprobeable operations with a specific rationale.",
55
- },
56
- },
57
- },
13
+ meta: providerMeta,
14
+ operations: operations,
58
15
  });
@@ -0,0 +1,3 @@
1
+ # Mappers
2
+
3
+ Put normalization helpers here when upstream responses need to become public APIFuse operation outputs.
@@ -0,0 +1,7 @@
1
+ export const providerMeta = {
2
+ displayName: "{{PROVIDER_ID}}",
3
+ displayNameKey: "meta.displayName",
4
+ descriptionKey: "meta.description",
5
+ category: "{{CATEGORY}}",
6
+ tags: ["{{PROVIDER_ID}}", "starter", "community"],
7
+ } as const;
@@ -0,0 +1,5 @@
1
+ import { pingOperation } from "./ping";
2
+
3
+ export const operations = {
4
+ ping: pingOperation,
5
+ };
@@ -0,0 +1,24 @@
1
+ import { defineOperation } from "@apifuse/provider-sdk/provider";
2
+
3
+ import { pingInputSchema, pingOutputSchema } from "../schemas/ping";
4
+
5
+ export const pingOperation = defineOperation({
6
+ descriptionKey: "operations.ping.description",
7
+ input: pingInputSchema,
8
+ output: pingOutputSchema,
9
+ handler: async ({{HANDLER_CTX}}, input) => {
10
+ {{BROWSER_HANDLER_BLOCK}}
11
+ return {
12
+ ok: true,
13
+ message: "{{DISPLAY_NAME}} received: " + input.value{{BROWSER_RESPONSE_FIELDS}},
14
+ };
15
+ },
16
+ fixtures: {
17
+ request: { value: "hello" },
18
+ response: { ok: true, message: "{{DISPLAY_NAME}} received: hello" },
19
+ },
20
+ healthCheckUnsupported: {
21
+ reason:
22
+ "Generated local-only scaffold operation. Replace this with a real healthCheck for upstream-backed bounty operations when safe; keep healthCheckUnsupported only for destructive, paid, credential-sensitive, or otherwise unprobeable operations with a specific rationale.",
23
+ },
24
+ });
@@ -0,0 +1,24 @@
1
+ import { describeKey, z } from "@apifuse/provider-sdk/provider";
2
+
3
+ export const pingInputSchema = describeKey(
4
+ z.object({
5
+ value: describeKey(z.string(), "schemaDescriptions.input.value"),
6
+ }),
7
+ "schemaDescriptions.input.root",
8
+ );
9
+
10
+ export const pingOutputSchema = describeKey(
11
+ z.object({
12
+ ok: describeKey(z.boolean(), "schemaDescriptions.output.ok"),
13
+ message: describeKey(z.string(), "schemaDescriptions.output.message"),
14
+ pageTitle: describeKey(
15
+ z.string().optional(),
16
+ "schemaDescriptions.output.pageTitle",
17
+ ),
18
+ frameCount: describeKey(
19
+ z.number().int().nonnegative().optional(),
20
+ "schemaDescriptions.output.frameCount",
21
+ ),
22
+ }),
23
+ "schemaDescriptions.output.root",
24
+ );
@@ -2,4 +2,4 @@ import { serve } from "@apifuse/provider-sdk";
2
2
 
3
3
  import provider from "./index";
4
4
 
5
- await serve(provider, { port: Number(process.env.PORT) || 3000 });
5
+ await serve(provider, { port: Number(process.env.APIFUSE__RUNTIME__PORT) || 3000 });
@@ -0,0 +1,3 @@
1
+ # Upstream
2
+
3
+ Put upstream HTTP clients, auth ceremony helpers, request builders, and protocol-specific types here once the provider talks to the real upstream service.