@xyo-network/api-call-witness 2.94.3 → 2.94.4
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/dist/browser/Config.d.cts +6 -6
- package/dist/browser/Config.d.mts +6 -6
- package/dist/browser/Config.d.ts +6 -6
- package/dist/browser/Payload.d.cts +10 -10
- package/dist/browser/Payload.d.mts +10 -10
- package/dist/browser/Payload.d.ts +10 -10
- package/dist/neutral/Config.d.cts +167 -0
- package/dist/neutral/Config.d.cts.map +1 -0
- package/dist/neutral/Config.d.mts +167 -0
- package/dist/neutral/Config.d.mts.map +1 -0
- package/dist/neutral/Config.d.ts +167 -0
- package/dist/neutral/Config.d.ts.map +1 -0
- package/dist/neutral/Payload.d.cts +127 -0
- package/dist/neutral/Payload.d.cts.map +1 -0
- package/dist/neutral/Payload.d.mts +127 -0
- package/dist/neutral/Payload.d.mts.map +1 -0
- package/dist/neutral/Payload.d.ts +127 -0
- package/dist/neutral/Payload.d.ts.map +1 -0
- package/dist/neutral/Witness.d.cts +20 -0
- package/dist/neutral/Witness.d.cts.map +1 -0
- package/dist/neutral/Witness.d.mts +20 -0
- package/dist/neutral/Witness.d.mts.map +1 -0
- package/dist/neutral/Witness.d.ts +20 -0
- package/dist/neutral/Witness.d.ts.map +1 -0
- package/dist/neutral/index.cjs +250 -0
- package/dist/neutral/index.cjs.map +1 -0
- package/dist/neutral/index.d.cts +4 -0
- package/dist/neutral/index.d.cts.map +1 -0
- package/dist/neutral/index.d.mts +4 -0
- package/dist/neutral/index.d.mts.map +1 -0
- package/dist/neutral/index.d.ts +4 -0
- package/dist/neutral/index.d.ts.map +1 -0
- package/dist/neutral/index.js +217 -0
- package/dist/neutral/index.js.map +1 -0
- package/dist/neutral/lib/checkIpfsUrl.d.cts +8 -0
- package/dist/neutral/lib/checkIpfsUrl.d.cts.map +1 -0
- package/dist/neutral/lib/checkIpfsUrl.d.mts +8 -0
- package/dist/neutral/lib/checkIpfsUrl.d.mts.map +1 -0
- package/dist/neutral/lib/checkIpfsUrl.d.ts +8 -0
- package/dist/neutral/lib/checkIpfsUrl.d.ts.map +1 -0
- package/dist/neutral/lib/index.d.cts +2 -0
- package/dist/neutral/lib/index.d.cts.map +1 -0
- package/dist/neutral/lib/index.d.mts +2 -0
- package/dist/neutral/lib/index.d.mts.map +1 -0
- package/dist/neutral/lib/index.d.ts +2 -0
- package/dist/neutral/lib/index.d.ts.map +1 -0
- package/dist/node/Config.d.cts +6 -6
- package/dist/node/Config.d.mts +6 -6
- package/dist/node/Config.d.ts +6 -6
- package/dist/node/Payload.d.cts +10 -10
- package/dist/node/Payload.d.mts +10 -10
- package/dist/node/Payload.d.ts +10 -10
- package/package.json +19 -19
|
@@ -0,0 +1,217 @@
|
|
|
1
|
+
// src/Config.ts
|
|
2
|
+
import { AsObjectFactory } from "@xylabs/object";
|
|
3
|
+
import { isPayloadOfSchemaType } from "@xyo-network/payload-model";
|
|
4
|
+
var ApiCallWitnessConfigSchema = "network.xyo.api.call.witness.config";
|
|
5
|
+
var isApiCallWitnessConfig = isPayloadOfSchemaType(ApiCallWitnessConfigSchema);
|
|
6
|
+
var asApiCallWitnessConfig = AsObjectFactory.create(isApiCallWitnessConfig);
|
|
7
|
+
var isApiUriCallWitnessConfig = (value) => isApiCallWitnessConfig(value) && !!value.uri;
|
|
8
|
+
var asApiUriCallWitnessConfig = AsObjectFactory.create(isApiUriCallWitnessConfig);
|
|
9
|
+
var isApiUriTemplateCallWitnessConfig = (value) => isApiCallWitnessConfig(value) && !!value.uriTemplate;
|
|
10
|
+
var asApiUriTemplateCallWitnessConfig = AsObjectFactory.create(isApiUriTemplateCallWitnessConfig);
|
|
11
|
+
|
|
12
|
+
// src/Payload.ts
|
|
13
|
+
import { AsObjectFactory as AsObjectFactory2 } from "@xylabs/object";
|
|
14
|
+
import { isPayloadOfSchemaType as isPayloadOfSchemaType2 } from "@xyo-network/payload-model";
|
|
15
|
+
var ApiCallSchema = "network.xyo.api.call";
|
|
16
|
+
var isApiUriCall = (value) => isApiCall(value) && !!value.uri;
|
|
17
|
+
var asApiUriCall = AsObjectFactory2.create(isApiUriCall);
|
|
18
|
+
var isApiUriTemplateCall = (value) => isApiCall(value) && !!(value.uriTemplate || value.params);
|
|
19
|
+
var asApiUriTemplateCall = AsObjectFactory2.create(isApiUriTemplateCall);
|
|
20
|
+
var ApiCallResultSchema = "network.xyo.api.call.result";
|
|
21
|
+
var isApiCall = isPayloadOfSchemaType2(ApiCallSchema);
|
|
22
|
+
var asApiCall = AsObjectFactory2.create(isApiCall);
|
|
23
|
+
var isApiCallJsonResult = (x) => {
|
|
24
|
+
return isPayloadOfSchemaType2(ApiCallResultSchema)(x) && x?.contentType === "application/json";
|
|
25
|
+
};
|
|
26
|
+
var asApiCallJsonResult = AsObjectFactory2.create(isApiCallJsonResult);
|
|
27
|
+
var isApiCallResult = isPayloadOfSchemaType2(ApiCallResultSchema);
|
|
28
|
+
var asApiCallResult = AsObjectFactory2.create(isApiCallResult);
|
|
29
|
+
|
|
30
|
+
// src/Witness.ts
|
|
31
|
+
import { assertEx as assertEx2 } from "@xylabs/assert";
|
|
32
|
+
import { Axios, AxiosJson } from "@xylabs/axios";
|
|
33
|
+
import { AbstractWitness } from "@xyo-network/abstract-witness";
|
|
34
|
+
import { PayloadHasher } from "@xyo-network/hash";
|
|
35
|
+
import { PayloadBuilder } from "@xyo-network/payload-builder";
|
|
36
|
+
import { isPayloadOfSchemaType as isPayloadOfSchemaType3 } from "@xyo-network/payload-model";
|
|
37
|
+
import { fromByteArray } from "base64-js";
|
|
38
|
+
import fillTemplate from "es6-dynamic-template";
|
|
39
|
+
|
|
40
|
+
// src/lib/checkIpfsUrl.ts
|
|
41
|
+
import { assertEx } from "@xylabs/assert";
|
|
42
|
+
var allowIpfsIoRepair = true;
|
|
43
|
+
var checkIpfsUrl = (urlToCheck, ipfsGateway) => {
|
|
44
|
+
try {
|
|
45
|
+
const url = new URL(urlToCheck);
|
|
46
|
+
let protocol = url.protocol;
|
|
47
|
+
let host = url.host;
|
|
48
|
+
let path = url.pathname;
|
|
49
|
+
const query = url.search;
|
|
50
|
+
if (protocol === "ipfs:") {
|
|
51
|
+
protocol = "https:";
|
|
52
|
+
host = assertEx(ipfsGateway, () => "No ipfsGateway provided");
|
|
53
|
+
path = url.host === "ipfs" ? `ipfs${path}` : `ipfs/${url.host}${path}`;
|
|
54
|
+
const root = `${protocol}//${host}/${path}`;
|
|
55
|
+
return query?.length > 0 ? `${root}?${query}` : root;
|
|
56
|
+
} else if (allowIpfsIoRepair && protocol === "https" && host === "ipfs.io") {
|
|
57
|
+
protocol = "https:";
|
|
58
|
+
host = assertEx(ipfsGateway, () => "No ipfsGateway provided");
|
|
59
|
+
const pathParts = path.split("/");
|
|
60
|
+
if (pathParts[0] === "ipfs") {
|
|
61
|
+
pathParts.shift();
|
|
62
|
+
}
|
|
63
|
+
path = pathParts.join("/");
|
|
64
|
+
const root = `${protocol}//${host}/${path}`;
|
|
65
|
+
return query?.length > 0 ? `${root}?${query}` : root;
|
|
66
|
+
} else {
|
|
67
|
+
return urlToCheck;
|
|
68
|
+
}
|
|
69
|
+
} catch {
|
|
70
|
+
return urlToCheck;
|
|
71
|
+
}
|
|
72
|
+
};
|
|
73
|
+
|
|
74
|
+
// src/Witness.ts
|
|
75
|
+
var ApiCallWitness = class extends AbstractWitness {
|
|
76
|
+
static configSchemas = [...super.configSchemas, ApiCallWitnessConfigSchema];
|
|
77
|
+
static defaultConfigSchema = ApiCallWitnessConfigSchema;
|
|
78
|
+
get accept() {
|
|
79
|
+
return this.config.accept ?? "application/json";
|
|
80
|
+
}
|
|
81
|
+
get ipfsGateway() {
|
|
82
|
+
return this.params.ipfsGateway;
|
|
83
|
+
}
|
|
84
|
+
get timeout() {
|
|
85
|
+
return this.config.timeout;
|
|
86
|
+
}
|
|
87
|
+
getFullUri(call) {
|
|
88
|
+
const { uri: callUri } = asApiUriCall(call) ?? {};
|
|
89
|
+
const { uriTemplate: callUriTemplate, params: callParams, queries: callQueries } = asApiUriTemplateCall(call) ?? {};
|
|
90
|
+
const { uri: configUri } = asApiUriCallWitnessConfig(this.config) ?? {};
|
|
91
|
+
const { uriTemplate: configUriTemplate, params: configParams, queries: configQueries } = asApiUriTemplateCallWitnessConfig(this.config) ?? {};
|
|
92
|
+
const params = { ...configParams, ...callParams };
|
|
93
|
+
let url = void 0;
|
|
94
|
+
if (callUri) {
|
|
95
|
+
url = new URL(callUri);
|
|
96
|
+
} else if (callUriTemplate) {
|
|
97
|
+
url = new URL(fillTemplate(callUriTemplate, params));
|
|
98
|
+
} else if (configUri) {
|
|
99
|
+
url = new URL(configUri);
|
|
100
|
+
} else if (configUriTemplate) {
|
|
101
|
+
url = new URL(fillTemplate(configUriTemplate, params));
|
|
102
|
+
}
|
|
103
|
+
if (url) {
|
|
104
|
+
const queries = Object.entries({ ...configQueries, ...callQueries });
|
|
105
|
+
queries.map(([key, value]) => url?.searchParams.set(key, value));
|
|
106
|
+
return url.href;
|
|
107
|
+
}
|
|
108
|
+
throw new Error("Unable to determine uri. No uri/uriTemplate specified in either the call or config.");
|
|
109
|
+
}
|
|
110
|
+
async observeHandler(inPayloads = []) {
|
|
111
|
+
await this.started("throw");
|
|
112
|
+
try {
|
|
113
|
+
const observations = await Promise.all(
|
|
114
|
+
inPayloads.filter(isPayloadOfSchemaType3(ApiCallSchema)).map(async (call) => {
|
|
115
|
+
const { verb: callVerb } = call;
|
|
116
|
+
const { verb: configVerb } = this.config;
|
|
117
|
+
const verb = callVerb ?? configVerb ?? "get";
|
|
118
|
+
const uri = this.getFullUri(call);
|
|
119
|
+
const validatedUri = assertEx2(checkIpfsUrl(uri, this.ipfsGateway), () => "Invalid URI");
|
|
120
|
+
if (verb === "get") {
|
|
121
|
+
return this.httpGet(validatedUri, (await PayloadBuilder.build(call)).$hash);
|
|
122
|
+
}
|
|
123
|
+
const observation = {
|
|
124
|
+
call: await PayloadHasher.hash(call),
|
|
125
|
+
schema: ApiCallResultSchema
|
|
126
|
+
};
|
|
127
|
+
return observation;
|
|
128
|
+
})
|
|
129
|
+
);
|
|
130
|
+
return observations;
|
|
131
|
+
} catch (ex) {
|
|
132
|
+
const error = ex;
|
|
133
|
+
console.error(`Error [${this.config.name}]: ${error.message}`);
|
|
134
|
+
console.log(error.stack);
|
|
135
|
+
throw error;
|
|
136
|
+
}
|
|
137
|
+
}
|
|
138
|
+
async httpGet(url, call) {
|
|
139
|
+
const result = {
|
|
140
|
+
call,
|
|
141
|
+
schema: ApiCallResultSchema
|
|
142
|
+
};
|
|
143
|
+
try {
|
|
144
|
+
switch (this.accept) {
|
|
145
|
+
case "application/json": {
|
|
146
|
+
const axios = new AxiosJson({ headers: { ...this.params.headers, Accept: "application/json" }, timeout: this.timeout });
|
|
147
|
+
const response = await axios.get(url);
|
|
148
|
+
if (response.status >= 200 && response.status < 300) {
|
|
149
|
+
const jsonResult = result;
|
|
150
|
+
jsonResult.data = response.data;
|
|
151
|
+
jsonResult.contentType = "application/json";
|
|
152
|
+
} else {
|
|
153
|
+
const errorResult = result;
|
|
154
|
+
errorResult.http = {
|
|
155
|
+
status: response.status
|
|
156
|
+
};
|
|
157
|
+
}
|
|
158
|
+
break;
|
|
159
|
+
}
|
|
160
|
+
default: {
|
|
161
|
+
const axios = new Axios({ headers: this.params.headers, responseType: "arraybuffer", timeout: this.timeout });
|
|
162
|
+
const response = await axios.get(url);
|
|
163
|
+
if (response.status >= 200 && response.status < 300) {
|
|
164
|
+
const jsonResult = result;
|
|
165
|
+
jsonResult.data = fromByteArray(Buffer.from(response.data, "binary"));
|
|
166
|
+
jsonResult.contentType = response.headers["content-type"]?.toString() ?? "application/octet-stream";
|
|
167
|
+
} else {
|
|
168
|
+
const errorResult = result;
|
|
169
|
+
errorResult.http = {
|
|
170
|
+
status: response.status
|
|
171
|
+
};
|
|
172
|
+
}
|
|
173
|
+
break;
|
|
174
|
+
}
|
|
175
|
+
}
|
|
176
|
+
} catch (ex) {
|
|
177
|
+
const axiosError = ex;
|
|
178
|
+
if (axiosError.isAxiosError) {
|
|
179
|
+
if (axiosError?.response?.status !== void 0) {
|
|
180
|
+
result.http = result.http ?? {};
|
|
181
|
+
result.http.status = axiosError?.response?.status;
|
|
182
|
+
}
|
|
183
|
+
if (axiosError?.code !== void 0) {
|
|
184
|
+
result.http = result.http ?? {};
|
|
185
|
+
result.http.code = axiosError?.code;
|
|
186
|
+
}
|
|
187
|
+
return result;
|
|
188
|
+
} else {
|
|
189
|
+
throw ex;
|
|
190
|
+
}
|
|
191
|
+
}
|
|
192
|
+
return result;
|
|
193
|
+
}
|
|
194
|
+
};
|
|
195
|
+
export {
|
|
196
|
+
ApiCallResultSchema,
|
|
197
|
+
ApiCallSchema,
|
|
198
|
+
ApiCallWitness,
|
|
199
|
+
ApiCallWitnessConfigSchema,
|
|
200
|
+
asApiCall,
|
|
201
|
+
asApiCallJsonResult,
|
|
202
|
+
asApiCallResult,
|
|
203
|
+
asApiCallWitnessConfig,
|
|
204
|
+
asApiUriCall,
|
|
205
|
+
asApiUriCallWitnessConfig,
|
|
206
|
+
asApiUriTemplateCall,
|
|
207
|
+
asApiUriTemplateCallWitnessConfig,
|
|
208
|
+
isApiCall,
|
|
209
|
+
isApiCallJsonResult,
|
|
210
|
+
isApiCallResult,
|
|
211
|
+
isApiCallWitnessConfig,
|
|
212
|
+
isApiUriCall,
|
|
213
|
+
isApiUriCallWitnessConfig,
|
|
214
|
+
isApiUriTemplateCall,
|
|
215
|
+
isApiUriTemplateCallWitnessConfig
|
|
216
|
+
};
|
|
217
|
+
//# sourceMappingURL=index.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"sources":["../../src/Config.ts","../../src/Payload.ts","../../src/Witness.ts","../../src/lib/checkIpfsUrl.ts"],"sourcesContent":["import { AsObjectFactory } from '@xylabs/object'\nimport { isPayloadOfSchemaType } from '@xyo-network/payload-model'\nimport { WitnessConfig } from '@xyo-network/witness-model'\n\nimport { ApiCall, ApiUriCall, ApiUriTemplateCall } from './Payload'\n\nexport const ApiCallWitnessConfigSchema = 'network.xyo.api.call.witness.config'\nexport type ApiCallWitnessConfigSchema = typeof ApiCallWitnessConfigSchema\n\nexport type ApiCallWitnessConfigBase = WitnessConfig<{\n accept?: 'application/json'\n queries?: ApiCall['queries']\n schema: ApiCallWitnessConfigSchema\n timeout?: number\n verb?: ApiCall['verb']\n}>\n\nexport type ApiUriCallWitnessConfig = WitnessConfig<\n ApiCallWitnessConfigBase & {\n uri: ApiUriCall['uri']\n }\n>\n\nexport type ApiUriTemplateCallWitnessConfig = WitnessConfig<\n ApiCallWitnessConfigBase & {\n params?: Record<string, string>\n uriTemplate: ApiUriTemplateCall['uriTemplate']\n }\n>\n\nexport type ApiCallWitnessConfig = ApiUriCallWitnessConfig | ApiUriTemplateCallWitnessConfig | ApiCallWitnessConfigBase\n\nexport const isApiCallWitnessConfig = isPayloadOfSchemaType<ApiCallWitnessConfig>(ApiCallWitnessConfigSchema)\nexport const asApiCallWitnessConfig = AsObjectFactory.create(isApiCallWitnessConfig)\n\nexport const isApiUriCallWitnessConfig = (value?: unknown): value is ApiUriCallWitnessConfig =>\n isApiCallWitnessConfig(value) && !!(value as ApiUriCallWitnessConfig).uri\nexport const asApiUriCallWitnessConfig = AsObjectFactory.create(isApiUriCallWitnessConfig)\n\nexport const isApiUriTemplateCallWitnessConfig = (value?: unknown): value is ApiUriTemplateCallWitnessConfig =>\n isApiCallWitnessConfig(value) && !!(value as ApiUriTemplateCallWitnessConfig).uriTemplate\nexport const asApiUriTemplateCallWitnessConfig = AsObjectFactory.create(isApiUriTemplateCallWitnessConfig)\n","import { Hash } from '@xylabs/hex'\nimport { AsObjectFactory, JsonArray, JsonObject } from '@xylabs/object'\nimport { isPayloadOfSchemaType, Payload } from '@xyo-network/payload-model'\n\nexport const ApiCallSchema = 'network.xyo.api.call'\nexport type ApiCallSchema = typeof ApiCallSchema\n\nexport type Verb = 'get' | 'post'\nexport type Queries = Record<string, string>\n\nexport interface ApiCallFields {\n queries?: Queries\n verb?: Verb\n}\n\nexport type ApiUriCall = Payload<\n ApiCallFields & {\n uri: string\n },\n ApiCallSchema\n>\nexport const isApiUriCall = (value?: unknown): value is ApiUriCall => isApiCall(value) && !!(value as ApiUriCall).uri\nexport const asApiUriCall = AsObjectFactory.create(isApiUriCall)\n\nexport type ApiUriTemplateCall = Payload<\n ApiCallFields & {\n params?: Record<string, string>\n uriTemplate?: string\n },\n ApiCallSchema\n>\nexport const isApiUriTemplateCall = (value?: unknown): value is ApiUriTemplateCall =>\n isApiCall(value) && !!((value as ApiUriTemplateCall).uriTemplate || (value as ApiUriTemplateCall).params)\nexport const asApiUriTemplateCall = AsObjectFactory.create(isApiUriTemplateCall)\n\nexport type ApiCall = ApiUriCall | ApiUriTemplateCall\n\nexport const ApiCallResultSchema = 'network.xyo.api.call.result'\nexport type ApiCallResultSchema = typeof ApiCallResultSchema\n\nexport const isApiCall = isPayloadOfSchemaType<ApiCall>(ApiCallSchema)\nexport const asApiCall = AsObjectFactory.create(isApiCall)\n\nexport interface HttpMeta {\n code?: string\n status?: number\n}\n\nexport type ApiCallJsonResultType = JsonArray | JsonObject\n\nexport type ApiCallJsonResult<T extends ApiCallJsonResultType = ApiCallJsonResultType> = Payload<\n {\n call: Hash\n contentType: 'application/json'\n data: T\n },\n ApiCallResultSchema\n>\n\nexport const isApiCallJsonResult = <T extends ApiCallJsonResultType = ApiCallJsonResultType>(x?: unknown | null): x is ApiCallJsonResult<T> => {\n return isPayloadOfSchemaType(ApiCallResultSchema)(x) && (x as ApiCallJsonResult)?.contentType === 'application/json'\n}\nexport const asApiCallJsonResult = AsObjectFactory.create(isApiCallJsonResult)\n\nexport type ApiCallBase64Result = Payload<\n {\n call: Hash\n contentType: Exclude<string, ApiCallJsonResult['contentType']>\n data: string\n },\n ApiCallResultSchema\n>\n\nexport type ApiCallErrorResult = Payload<\n {\n call: Hash\n http?: HttpMeta\n },\n ApiCallResultSchema\n>\n\nexport type ApiCallResult<TJson extends JsonArray | JsonObject = JsonArray | JsonObject> =\n | ApiCallBase64Result\n | ApiCallJsonResult<TJson>\n | ApiCallErrorResult\n\nexport const isApiCallResult = isPayloadOfSchemaType<ApiCallResult>(ApiCallResultSchema)\nexport const asApiCallResult = AsObjectFactory.create(isApiCallResult)\n","/* eslint-disable max-statements */\nimport { assertEx } from '@xylabs/assert'\nimport { Axios, AxiosError, AxiosJson } from '@xylabs/axios'\nimport { Hash } from '@xylabs/hex'\nimport { AbstractWitness } from '@xyo-network/abstract-witness'\nimport { PayloadHasher } from '@xyo-network/hash'\nimport { PayloadBuilder } from '@xyo-network/payload-builder'\nimport { isPayloadOfSchemaType, Schema } from '@xyo-network/payload-model'\nimport { WitnessParams } from '@xyo-network/witness-model'\nimport { fromByteArray } from 'base64-js'\nimport fillTemplate from 'es6-dynamic-template'\n\nimport { ApiCallWitnessConfig, ApiCallWitnessConfigSchema, asApiUriCallWitnessConfig, asApiUriTemplateCallWitnessConfig } from './Config'\nimport { checkIpfsUrl } from './lib'\nimport {\n ApiCall,\n ApiCallBase64Result,\n ApiCallErrorResult,\n ApiCallJsonResult,\n ApiCallJsonResultType,\n ApiCallResult,\n ApiCallResultSchema,\n ApiCallSchema,\n asApiUriCall,\n asApiUriTemplateCall,\n} from './Payload'\n\nexport type ApiCallWitnessParams = WitnessParams<\n ApiCallWitnessConfig,\n {\n headers?: Record<string, string | undefined>\n ipfsGateway?: string\n }\n>\n\nexport class ApiCallWitness<TParams extends ApiCallWitnessParams = ApiCallWitnessParams> extends AbstractWitness<TParams, ApiCall, ApiCallResult> {\n static override readonly configSchemas: Schema[] = [...super.configSchemas, ApiCallWitnessConfigSchema]\n static override readonly defaultConfigSchema: Schema = ApiCallWitnessConfigSchema\n\n get accept() {\n return this.config.accept ?? 'application/json'\n }\n\n get ipfsGateway() {\n return this.params.ipfsGateway\n }\n\n get timeout() {\n return this.config.timeout\n }\n\n getFullUri(call?: ApiCall): string {\n const { uri: callUri } = asApiUriCall(call) ?? {}\n const { uriTemplate: callUriTemplate, params: callParams, queries: callQueries } = asApiUriTemplateCall(call) ?? {}\n const { uri: configUri } = asApiUriCallWitnessConfig(this.config) ?? {}\n const { uriTemplate: configUriTemplate, params: configParams, queries: configQueries } = asApiUriTemplateCallWitnessConfig(this.config) ?? {}\n\n const params = { ...configParams, ...callParams }\n\n let url: URL | undefined = undefined\n\n if (callUri) {\n url = new URL(callUri)\n } else if (callUriTemplate) {\n url = new URL(fillTemplate(callUriTemplate, params))\n } else if (configUri) {\n url = new URL(configUri)\n } else if (configUriTemplate) {\n url = new URL(fillTemplate(configUriTemplate, params))\n }\n\n if (url) {\n const queries = Object.entries({ ...configQueries, ...callQueries })\n queries.map(([key, value]) => url?.searchParams.set(key, value))\n return url.href\n }\n\n throw new Error('Unable to determine uri. No uri/uriTemplate specified in either the call or config.')\n }\n\n protected override async observeHandler(inPayloads: ApiCall[] = []): Promise<ApiCallResult[]> {\n await this.started('throw')\n try {\n const observations = await Promise.all(\n inPayloads.filter(isPayloadOfSchemaType(ApiCallSchema)).map(async (call) => {\n const { verb: callVerb } = call\n const { verb: configVerb } = this.config\n const verb = callVerb ?? configVerb ?? 'get'\n const uri = this.getFullUri(call)\n\n const validatedUri = assertEx(checkIpfsUrl(uri, this.ipfsGateway), () => 'Invalid URI')\n\n if (verb === 'get') {\n return this.httpGet(validatedUri, (await PayloadBuilder.build(call)).$hash)\n }\n\n const observation: ApiCallResult = {\n call: await PayloadHasher.hash(call),\n schema: ApiCallResultSchema,\n }\n return observation\n }),\n )\n return observations\n } catch (ex) {\n const error = ex as Error\n console.error(`Error [${this.config.name}]: ${error.message}`)\n console.log(error.stack)\n throw error\n }\n }\n\n private async httpGet(url: string, call: Hash): Promise<ApiCallResult> {\n const result: ApiCallResult = {\n call,\n schema: ApiCallResultSchema,\n }\n try {\n switch (this.accept) {\n case 'application/json': {\n const axios = new AxiosJson({ headers: { ...this.params.headers, Accept: 'application/json' }, timeout: this.timeout })\n const response = await axios.get<ApiCallJsonResultType>(url)\n if (response.status >= 200 && response.status < 300) {\n const jsonResult = result as ApiCallJsonResult\n jsonResult.data = response.data\n jsonResult.contentType = 'application/json'\n } else {\n const errorResult = result as ApiCallErrorResult\n errorResult.http = {\n status: response.status,\n }\n }\n break\n }\n default: {\n const axios = new Axios({ headers: this.params.headers, responseType: 'arraybuffer', timeout: this.timeout })\n const response = await axios.get(url)\n if (response.status >= 200 && response.status < 300) {\n const jsonResult = result as ApiCallBase64Result\n jsonResult.data = fromByteArray(Buffer.from(response.data, 'binary'))\n jsonResult.contentType = response.headers['content-type']?.toString() ?? 'application/octet-stream'\n } else {\n const errorResult = result as ApiCallErrorResult\n errorResult.http = {\n status: response.status,\n }\n }\n break\n }\n }\n } catch (ex) {\n const axiosError = ex as AxiosError\n if (axiosError.isAxiosError) {\n if (axiosError?.response?.status !== undefined) {\n result.http = result.http ?? {}\n result.http.status = axiosError?.response?.status\n }\n if (axiosError?.code !== undefined) {\n result.http = result.http ?? {}\n result.http.code = axiosError?.code\n }\n return result\n } else {\n throw ex\n }\n }\n return result\n }\n}\n","import { assertEx } from '@xylabs/assert'\n\nconst allowIpfsIoRepair = true\n\n/**\n * Returns the equivalent IPFS gateway URL for the supplied URL.\n * @param urlToCheck The URL to check\n * @returns If the supplied URL is an IPFS URL, it converts the URL to the\n * equivalent IPFS gateway URL. Otherwise, returns the original URL.\n */\nexport const checkIpfsUrl = (urlToCheck: string, ipfsGateway?: string): string => {\n try {\n const url = new URL(urlToCheck)\n let protocol = url.protocol\n let host = url.host\n let path = url.pathname\n const query = url.search\n if (protocol === 'ipfs:') {\n protocol = 'https:'\n host = assertEx(ipfsGateway, () => 'No ipfsGateway provided')\n path = url.host === 'ipfs' ? `ipfs${path}` : `ipfs/${url.host}${path}`\n const root = `${protocol}//${host}/${path}`\n return query?.length > 0 ? `${root}?${query}` : root\n } else if (allowIpfsIoRepair && protocol === 'https' && host === 'ipfs.io') {\n protocol = 'https:'\n host = assertEx(ipfsGateway, () => 'No ipfsGateway provided')\n const pathParts = path.split('/')\n if (pathParts[0] === 'ipfs') {\n pathParts.shift()\n }\n path = pathParts.join('/')\n const root = `${protocol}//${host}/${path}`\n return query?.length > 0 ? `${root}?${query}` : root\n } else {\n return urlToCheck\n }\n } catch {\n //const error = ex as Error\n //console.error(`${error.name}:${error.message} [${urlToCheck}]`)\n //console.log(error.stack)\n return urlToCheck\n }\n}\n"],"mappings":"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","names":["AsObjectFactory","isPayloadOfSchemaType","assertEx","isPayloadOfSchemaType","isPayloadOfSchemaType","assertEx"]}
|
|
@@ -0,0 +1,8 @@
|
|
|
1
|
+
/**
|
|
2
|
+
* Returns the equivalent IPFS gateway URL for the supplied URL.
|
|
3
|
+
* @param urlToCheck The URL to check
|
|
4
|
+
* @returns If the supplied URL is an IPFS URL, it converts the URL to the
|
|
5
|
+
* equivalent IPFS gateway URL. Otherwise, returns the original URL.
|
|
6
|
+
*/
|
|
7
|
+
export declare const checkIpfsUrl: (urlToCheck: string, ipfsGateway?: string) => string;
|
|
8
|
+
//# sourceMappingURL=checkIpfsUrl.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"checkIpfsUrl.d.ts","sourceRoot":"","sources":["../../../src/lib/checkIpfsUrl.ts"],"names":[],"mappings":"AAIA;;;;;GAKG;AACH,eAAO,MAAM,YAAY,eAAgB,MAAM,gBAAgB,MAAM,KAAG,MAgCvE,CAAA"}
|
|
@@ -0,0 +1,8 @@
|
|
|
1
|
+
/**
|
|
2
|
+
* Returns the equivalent IPFS gateway URL for the supplied URL.
|
|
3
|
+
* @param urlToCheck The URL to check
|
|
4
|
+
* @returns If the supplied URL is an IPFS URL, it converts the URL to the
|
|
5
|
+
* equivalent IPFS gateway URL. Otherwise, returns the original URL.
|
|
6
|
+
*/
|
|
7
|
+
export declare const checkIpfsUrl: (urlToCheck: string, ipfsGateway?: string) => string;
|
|
8
|
+
//# sourceMappingURL=checkIpfsUrl.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"checkIpfsUrl.d.ts","sourceRoot":"","sources":["../../../src/lib/checkIpfsUrl.ts"],"names":[],"mappings":"AAIA;;;;;GAKG;AACH,eAAO,MAAM,YAAY,eAAgB,MAAM,gBAAgB,MAAM,KAAG,MAgCvE,CAAA"}
|
|
@@ -0,0 +1,8 @@
|
|
|
1
|
+
/**
|
|
2
|
+
* Returns the equivalent IPFS gateway URL for the supplied URL.
|
|
3
|
+
* @param urlToCheck The URL to check
|
|
4
|
+
* @returns If the supplied URL is an IPFS URL, it converts the URL to the
|
|
5
|
+
* equivalent IPFS gateway URL. Otherwise, returns the original URL.
|
|
6
|
+
*/
|
|
7
|
+
export declare const checkIpfsUrl: (urlToCheck: string, ipfsGateway?: string) => string;
|
|
8
|
+
//# sourceMappingURL=checkIpfsUrl.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"checkIpfsUrl.d.ts","sourceRoot":"","sources":["../../../src/lib/checkIpfsUrl.ts"],"names":[],"mappings":"AAIA;;;;;GAKG;AACH,eAAO,MAAM,YAAY,eAAgB,MAAM,gBAAgB,MAAM,KAAG,MAgCvE,CAAA"}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../../../src/lib/index.ts"],"names":[],"mappings":"AAAA,cAAc,gBAAgB,CAAA"}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../../../src/lib/index.ts"],"names":[],"mappings":"AAAA,cAAc,gBAAgB,CAAA"}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../../../src/lib/index.ts"],"names":[],"mappings":"AAAA,cAAc,gBAAgB,CAAA"}
|
package/dist/node/Config.d.cts
CHANGED
|
@@ -19,8 +19,8 @@ export type ApiUriTemplateCallWitnessConfig = WitnessConfig<ApiCallWitnessConfig
|
|
|
19
19
|
export type ApiCallWitnessConfig = ApiUriCallWitnessConfig | ApiUriTemplateCallWitnessConfig | ApiCallWitnessConfigBase;
|
|
20
20
|
export declare const isApiCallWitnessConfig: (x?: unknown) => x is ApiCallWitnessConfig;
|
|
21
21
|
export declare const asApiCallWitnessConfig: {
|
|
22
|
-
<TType extends ApiCallWitnessConfig>(value: import("@xylabs/promise").AnyNonPromise
|
|
23
|
-
<TType_1 extends ApiCallWitnessConfig>(value: import("@xylabs/promise").AnyNonPromise
|
|
22
|
+
<TType extends ApiCallWitnessConfig>(value: import("@xylabs/promise").AnyNonPromise, config?: import("@xylabs/object").TypeCheckConfig | undefined): TType | undefined;
|
|
23
|
+
<TType_1 extends ApiCallWitnessConfig>(value: import("@xylabs/promise").AnyNonPromise, assert: import("@xylabs/object").StringOrAlertFunction<ApiCallWitnessConfig>, config?: import("@xylabs/object").TypeCheckConfig | undefined): TType_1;
|
|
24
24
|
};
|
|
25
25
|
export declare const isApiUriCallWitnessConfig: (value?: unknown) => value is import("@xyo-network/payload-model").SchemaFields & import("@xyo-network/payload-model").PayloadFields & Omit<import("@xyo-network/module-model").ArchivingModuleConfig & import("@xyo-network/module-model").ModuleConfigFields & {
|
|
26
26
|
schema: "network.xyo.api.call.witness.config";
|
|
@@ -56,7 +56,7 @@ export declare const asApiUriCallWitnessConfig: {
|
|
|
56
56
|
uri: ApiUriCall['uri'];
|
|
57
57
|
}, "schema"> & {
|
|
58
58
|
schema: "network.xyo.api.call.witness.config";
|
|
59
|
-
}>(value: import("@xylabs/promise").AnyNonPromise
|
|
59
|
+
}>(value: import("@xylabs/promise").AnyNonPromise, config?: import("@xylabs/object").TypeCheckConfig | undefined): TType | undefined;
|
|
60
60
|
<TType_1 extends import("@xyo-network/payload-model").SchemaFields & import("@xyo-network/payload-model").PayloadFields & Omit<import("@xyo-network/module-model").ArchivingModuleConfig & import("@xyo-network/module-model").ModuleConfigFields & {
|
|
61
61
|
schema: "network.xyo.api.call.witness.config";
|
|
62
62
|
} & import("@xyo-network/payload-model").SchemaFields & import("@xyo-network/payload-model").PayloadFields & Omit<import("@xyo-network/module-model").ArchivingModuleConfig & import("@xyo-network/module-model").ModuleConfigFields & {
|
|
@@ -73,7 +73,7 @@ export declare const asApiUriCallWitnessConfig: {
|
|
|
73
73
|
uri: ApiUriCall['uri'];
|
|
74
74
|
}, "schema"> & {
|
|
75
75
|
schema: "network.xyo.api.call.witness.config";
|
|
76
|
-
}>(value: import("@xylabs/promise").AnyNonPromise
|
|
76
|
+
}>(value: import("@xylabs/promise").AnyNonPromise, assert: import("@xylabs/object").StringOrAlertFunction<import("@xyo-network/payload-model").SchemaFields & import("@xyo-network/payload-model").PayloadFields & Omit<import("@xyo-network/module-model").ArchivingModuleConfig & import("@xyo-network/module-model").ModuleConfigFields & {
|
|
77
77
|
schema: "network.xyo.api.call.witness.config";
|
|
78
78
|
} & import("@xyo-network/payload-model").SchemaFields & import("@xyo-network/payload-model").PayloadFields & Omit<import("@xyo-network/module-model").ArchivingModuleConfig & import("@xyo-network/module-model").ModuleConfigFields & {
|
|
79
79
|
schema: "network.xyo.api.call.witness.config";
|
|
@@ -127,7 +127,7 @@ export declare const asApiUriTemplateCallWitnessConfig: {
|
|
|
127
127
|
uriTemplate: ApiUriTemplateCall['uriTemplate'];
|
|
128
128
|
}, "schema"> & {
|
|
129
129
|
schema: "network.xyo.api.call.witness.config";
|
|
130
|
-
}>(value: import("@xylabs/promise").AnyNonPromise
|
|
130
|
+
}>(value: import("@xylabs/promise").AnyNonPromise, config?: import("@xylabs/object").TypeCheckConfig | undefined): TType | undefined;
|
|
131
131
|
<TType_1 extends import("@xyo-network/payload-model").SchemaFields & import("@xyo-network/payload-model").PayloadFields & Omit<import("@xyo-network/module-model").ArchivingModuleConfig & import("@xyo-network/module-model").ModuleConfigFields & {
|
|
132
132
|
schema: "network.xyo.api.call.witness.config";
|
|
133
133
|
} & import("@xyo-network/payload-model").SchemaFields & import("@xyo-network/payload-model").PayloadFields & Omit<import("@xyo-network/module-model").ArchivingModuleConfig & import("@xyo-network/module-model").ModuleConfigFields & {
|
|
@@ -145,7 +145,7 @@ export declare const asApiUriTemplateCallWitnessConfig: {
|
|
|
145
145
|
uriTemplate: ApiUriTemplateCall['uriTemplate'];
|
|
146
146
|
}, "schema"> & {
|
|
147
147
|
schema: "network.xyo.api.call.witness.config";
|
|
148
|
-
}>(value: import("@xylabs/promise").AnyNonPromise
|
|
148
|
+
}>(value: import("@xylabs/promise").AnyNonPromise, assert: import("@xylabs/object").StringOrAlertFunction<import("@xyo-network/payload-model").SchemaFields & import("@xyo-network/payload-model").PayloadFields & Omit<import("@xyo-network/module-model").ArchivingModuleConfig & import("@xyo-network/module-model").ModuleConfigFields & {
|
|
149
149
|
schema: "network.xyo.api.call.witness.config";
|
|
150
150
|
} & import("@xyo-network/payload-model").SchemaFields & import("@xyo-network/payload-model").PayloadFields & Omit<import("@xyo-network/module-model").ArchivingModuleConfig & import("@xyo-network/module-model").ModuleConfigFields & {
|
|
151
151
|
schema: "network.xyo.api.call.witness.config";
|
package/dist/node/Config.d.mts
CHANGED
|
@@ -19,8 +19,8 @@ export type ApiUriTemplateCallWitnessConfig = WitnessConfig<ApiCallWitnessConfig
|
|
|
19
19
|
export type ApiCallWitnessConfig = ApiUriCallWitnessConfig | ApiUriTemplateCallWitnessConfig | ApiCallWitnessConfigBase;
|
|
20
20
|
export declare const isApiCallWitnessConfig: (x?: unknown) => x is ApiCallWitnessConfig;
|
|
21
21
|
export declare const asApiCallWitnessConfig: {
|
|
22
|
-
<TType extends ApiCallWitnessConfig>(value: import("@xylabs/promise").AnyNonPromise
|
|
23
|
-
<TType_1 extends ApiCallWitnessConfig>(value: import("@xylabs/promise").AnyNonPromise
|
|
22
|
+
<TType extends ApiCallWitnessConfig>(value: import("@xylabs/promise").AnyNonPromise, config?: import("@xylabs/object").TypeCheckConfig | undefined): TType | undefined;
|
|
23
|
+
<TType_1 extends ApiCallWitnessConfig>(value: import("@xylabs/promise").AnyNonPromise, assert: import("@xylabs/object").StringOrAlertFunction<ApiCallWitnessConfig>, config?: import("@xylabs/object").TypeCheckConfig | undefined): TType_1;
|
|
24
24
|
};
|
|
25
25
|
export declare const isApiUriCallWitnessConfig: (value?: unknown) => value is import("@xyo-network/payload-model").SchemaFields & import("@xyo-network/payload-model").PayloadFields & Omit<import("@xyo-network/module-model").ArchivingModuleConfig & import("@xyo-network/module-model").ModuleConfigFields & {
|
|
26
26
|
schema: "network.xyo.api.call.witness.config";
|
|
@@ -56,7 +56,7 @@ export declare const asApiUriCallWitnessConfig: {
|
|
|
56
56
|
uri: ApiUriCall['uri'];
|
|
57
57
|
}, "schema"> & {
|
|
58
58
|
schema: "network.xyo.api.call.witness.config";
|
|
59
|
-
}>(value: import("@xylabs/promise").AnyNonPromise
|
|
59
|
+
}>(value: import("@xylabs/promise").AnyNonPromise, config?: import("@xylabs/object").TypeCheckConfig | undefined): TType | undefined;
|
|
60
60
|
<TType_1 extends import("@xyo-network/payload-model").SchemaFields & import("@xyo-network/payload-model").PayloadFields & Omit<import("@xyo-network/module-model").ArchivingModuleConfig & import("@xyo-network/module-model").ModuleConfigFields & {
|
|
61
61
|
schema: "network.xyo.api.call.witness.config";
|
|
62
62
|
} & import("@xyo-network/payload-model").SchemaFields & import("@xyo-network/payload-model").PayloadFields & Omit<import("@xyo-network/module-model").ArchivingModuleConfig & import("@xyo-network/module-model").ModuleConfigFields & {
|
|
@@ -73,7 +73,7 @@ export declare const asApiUriCallWitnessConfig: {
|
|
|
73
73
|
uri: ApiUriCall['uri'];
|
|
74
74
|
}, "schema"> & {
|
|
75
75
|
schema: "network.xyo.api.call.witness.config";
|
|
76
|
-
}>(value: import("@xylabs/promise").AnyNonPromise
|
|
76
|
+
}>(value: import("@xylabs/promise").AnyNonPromise, assert: import("@xylabs/object").StringOrAlertFunction<import("@xyo-network/payload-model").SchemaFields & import("@xyo-network/payload-model").PayloadFields & Omit<import("@xyo-network/module-model").ArchivingModuleConfig & import("@xyo-network/module-model").ModuleConfigFields & {
|
|
77
77
|
schema: "network.xyo.api.call.witness.config";
|
|
78
78
|
} & import("@xyo-network/payload-model").SchemaFields & import("@xyo-network/payload-model").PayloadFields & Omit<import("@xyo-network/module-model").ArchivingModuleConfig & import("@xyo-network/module-model").ModuleConfigFields & {
|
|
79
79
|
schema: "network.xyo.api.call.witness.config";
|
|
@@ -127,7 +127,7 @@ export declare const asApiUriTemplateCallWitnessConfig: {
|
|
|
127
127
|
uriTemplate: ApiUriTemplateCall['uriTemplate'];
|
|
128
128
|
}, "schema"> & {
|
|
129
129
|
schema: "network.xyo.api.call.witness.config";
|
|
130
|
-
}>(value: import("@xylabs/promise").AnyNonPromise
|
|
130
|
+
}>(value: import("@xylabs/promise").AnyNonPromise, config?: import("@xylabs/object").TypeCheckConfig | undefined): TType | undefined;
|
|
131
131
|
<TType_1 extends import("@xyo-network/payload-model").SchemaFields & import("@xyo-network/payload-model").PayloadFields & Omit<import("@xyo-network/module-model").ArchivingModuleConfig & import("@xyo-network/module-model").ModuleConfigFields & {
|
|
132
132
|
schema: "network.xyo.api.call.witness.config";
|
|
133
133
|
} & import("@xyo-network/payload-model").SchemaFields & import("@xyo-network/payload-model").PayloadFields & Omit<import("@xyo-network/module-model").ArchivingModuleConfig & import("@xyo-network/module-model").ModuleConfigFields & {
|
|
@@ -145,7 +145,7 @@ export declare const asApiUriTemplateCallWitnessConfig: {
|
|
|
145
145
|
uriTemplate: ApiUriTemplateCall['uriTemplate'];
|
|
146
146
|
}, "schema"> & {
|
|
147
147
|
schema: "network.xyo.api.call.witness.config";
|
|
148
|
-
}>(value: import("@xylabs/promise").AnyNonPromise
|
|
148
|
+
}>(value: import("@xylabs/promise").AnyNonPromise, assert: import("@xylabs/object").StringOrAlertFunction<import("@xyo-network/payload-model").SchemaFields & import("@xyo-network/payload-model").PayloadFields & Omit<import("@xyo-network/module-model").ArchivingModuleConfig & import("@xyo-network/module-model").ModuleConfigFields & {
|
|
149
149
|
schema: "network.xyo.api.call.witness.config";
|
|
150
150
|
} & import("@xyo-network/payload-model").SchemaFields & import("@xyo-network/payload-model").PayloadFields & Omit<import("@xyo-network/module-model").ArchivingModuleConfig & import("@xyo-network/module-model").ModuleConfigFields & {
|
|
151
151
|
schema: "network.xyo.api.call.witness.config";
|
package/dist/node/Config.d.ts
CHANGED
|
@@ -19,8 +19,8 @@ export type ApiUriTemplateCallWitnessConfig = WitnessConfig<ApiCallWitnessConfig
|
|
|
19
19
|
export type ApiCallWitnessConfig = ApiUriCallWitnessConfig | ApiUriTemplateCallWitnessConfig | ApiCallWitnessConfigBase;
|
|
20
20
|
export declare const isApiCallWitnessConfig: (x?: unknown) => x is ApiCallWitnessConfig;
|
|
21
21
|
export declare const asApiCallWitnessConfig: {
|
|
22
|
-
<TType extends ApiCallWitnessConfig>(value: import("@xylabs/promise").AnyNonPromise
|
|
23
|
-
<TType_1 extends ApiCallWitnessConfig>(value: import("@xylabs/promise").AnyNonPromise
|
|
22
|
+
<TType extends ApiCallWitnessConfig>(value: import("@xylabs/promise").AnyNonPromise, config?: import("@xylabs/object").TypeCheckConfig | undefined): TType | undefined;
|
|
23
|
+
<TType_1 extends ApiCallWitnessConfig>(value: import("@xylabs/promise").AnyNonPromise, assert: import("@xylabs/object").StringOrAlertFunction<ApiCallWitnessConfig>, config?: import("@xylabs/object").TypeCheckConfig | undefined): TType_1;
|
|
24
24
|
};
|
|
25
25
|
export declare const isApiUriCallWitnessConfig: (value?: unknown) => value is import("@xyo-network/payload-model").SchemaFields & import("@xyo-network/payload-model").PayloadFields & Omit<import("@xyo-network/module-model").ArchivingModuleConfig & import("@xyo-network/module-model").ModuleConfigFields & {
|
|
26
26
|
schema: "network.xyo.api.call.witness.config";
|
|
@@ -56,7 +56,7 @@ export declare const asApiUriCallWitnessConfig: {
|
|
|
56
56
|
uri: ApiUriCall['uri'];
|
|
57
57
|
}, "schema"> & {
|
|
58
58
|
schema: "network.xyo.api.call.witness.config";
|
|
59
|
-
}>(value: import("@xylabs/promise").AnyNonPromise
|
|
59
|
+
}>(value: import("@xylabs/promise").AnyNonPromise, config?: import("@xylabs/object").TypeCheckConfig | undefined): TType | undefined;
|
|
60
60
|
<TType_1 extends import("@xyo-network/payload-model").SchemaFields & import("@xyo-network/payload-model").PayloadFields & Omit<import("@xyo-network/module-model").ArchivingModuleConfig & import("@xyo-network/module-model").ModuleConfigFields & {
|
|
61
61
|
schema: "network.xyo.api.call.witness.config";
|
|
62
62
|
} & import("@xyo-network/payload-model").SchemaFields & import("@xyo-network/payload-model").PayloadFields & Omit<import("@xyo-network/module-model").ArchivingModuleConfig & import("@xyo-network/module-model").ModuleConfigFields & {
|
|
@@ -73,7 +73,7 @@ export declare const asApiUriCallWitnessConfig: {
|
|
|
73
73
|
uri: ApiUriCall['uri'];
|
|
74
74
|
}, "schema"> & {
|
|
75
75
|
schema: "network.xyo.api.call.witness.config";
|
|
76
|
-
}>(value: import("@xylabs/promise").AnyNonPromise
|
|
76
|
+
}>(value: import("@xylabs/promise").AnyNonPromise, assert: import("@xylabs/object").StringOrAlertFunction<import("@xyo-network/payload-model").SchemaFields & import("@xyo-network/payload-model").PayloadFields & Omit<import("@xyo-network/module-model").ArchivingModuleConfig & import("@xyo-network/module-model").ModuleConfigFields & {
|
|
77
77
|
schema: "network.xyo.api.call.witness.config";
|
|
78
78
|
} & import("@xyo-network/payload-model").SchemaFields & import("@xyo-network/payload-model").PayloadFields & Omit<import("@xyo-network/module-model").ArchivingModuleConfig & import("@xyo-network/module-model").ModuleConfigFields & {
|
|
79
79
|
schema: "network.xyo.api.call.witness.config";
|
|
@@ -127,7 +127,7 @@ export declare const asApiUriTemplateCallWitnessConfig: {
|
|
|
127
127
|
uriTemplate: ApiUriTemplateCall['uriTemplate'];
|
|
128
128
|
}, "schema"> & {
|
|
129
129
|
schema: "network.xyo.api.call.witness.config";
|
|
130
|
-
}>(value: import("@xylabs/promise").AnyNonPromise
|
|
130
|
+
}>(value: import("@xylabs/promise").AnyNonPromise, config?: import("@xylabs/object").TypeCheckConfig | undefined): TType | undefined;
|
|
131
131
|
<TType_1 extends import("@xyo-network/payload-model").SchemaFields & import("@xyo-network/payload-model").PayloadFields & Omit<import("@xyo-network/module-model").ArchivingModuleConfig & import("@xyo-network/module-model").ModuleConfigFields & {
|
|
132
132
|
schema: "network.xyo.api.call.witness.config";
|
|
133
133
|
} & import("@xyo-network/payload-model").SchemaFields & import("@xyo-network/payload-model").PayloadFields & Omit<import("@xyo-network/module-model").ArchivingModuleConfig & import("@xyo-network/module-model").ModuleConfigFields & {
|
|
@@ -145,7 +145,7 @@ export declare const asApiUriTemplateCallWitnessConfig: {
|
|
|
145
145
|
uriTemplate: ApiUriTemplateCall['uriTemplate'];
|
|
146
146
|
}, "schema"> & {
|
|
147
147
|
schema: "network.xyo.api.call.witness.config";
|
|
148
|
-
}>(value: import("@xylabs/promise").AnyNonPromise
|
|
148
|
+
}>(value: import("@xylabs/promise").AnyNonPromise, assert: import("@xylabs/object").StringOrAlertFunction<import("@xyo-network/payload-model").SchemaFields & import("@xyo-network/payload-model").PayloadFields & Omit<import("@xyo-network/module-model").ArchivingModuleConfig & import("@xyo-network/module-model").ModuleConfigFields & {
|
|
149
149
|
schema: "network.xyo.api.call.witness.config";
|
|
150
150
|
} & import("@xyo-network/payload-model").SchemaFields & import("@xyo-network/payload-model").PayloadFields & Omit<import("@xyo-network/module-model").ArchivingModuleConfig & import("@xyo-network/module-model").ModuleConfigFields & {
|
|
151
151
|
schema: "network.xyo.api.call.witness.config";
|
package/dist/node/Payload.d.cts
CHANGED
|
@@ -22,12 +22,12 @@ export declare const asApiUriCall: {
|
|
|
22
22
|
uri: string;
|
|
23
23
|
} & {
|
|
24
24
|
schema: "network.xyo.api.call";
|
|
25
|
-
}>(value: import("@xylabs/promise").AnyNonPromise
|
|
25
|
+
}>(value: import("@xylabs/promise").AnyNonPromise, config?: import("@xylabs/object").TypeCheckConfig | undefined): TType | undefined;
|
|
26
26
|
<TType_1 extends import("@xyo-network/payload-model").SchemaFields & import("@xyo-network/payload-model").PayloadFields & ApiCallFields & {
|
|
27
27
|
uri: string;
|
|
28
28
|
} & {
|
|
29
29
|
schema: "network.xyo.api.call";
|
|
30
|
-
}>(value: import("@xylabs/promise").AnyNonPromise
|
|
30
|
+
}>(value: import("@xylabs/promise").AnyNonPromise, assert: import("@xylabs/object").StringOrAlertFunction<import("@xyo-network/payload-model").SchemaFields & import("@xyo-network/payload-model").PayloadFields & ApiCallFields & {
|
|
31
31
|
uri: string;
|
|
32
32
|
} & {
|
|
33
33
|
schema: "network.xyo.api.call";
|
|
@@ -49,13 +49,13 @@ export declare const asApiUriTemplateCall: {
|
|
|
49
49
|
uriTemplate?: string | undefined;
|
|
50
50
|
} & {
|
|
51
51
|
schema: "network.xyo.api.call";
|
|
52
|
-
}>(value: import("@xylabs/promise").AnyNonPromise
|
|
52
|
+
}>(value: import("@xylabs/promise").AnyNonPromise, config?: import("@xylabs/object").TypeCheckConfig | undefined): TType | undefined;
|
|
53
53
|
<TType_1 extends import("@xyo-network/payload-model").SchemaFields & import("@xyo-network/payload-model").PayloadFields & ApiCallFields & {
|
|
54
54
|
params?: Record<string, string> | undefined;
|
|
55
55
|
uriTemplate?: string | undefined;
|
|
56
56
|
} & {
|
|
57
57
|
schema: "network.xyo.api.call";
|
|
58
|
-
}>(value: import("@xylabs/promise").AnyNonPromise
|
|
58
|
+
}>(value: import("@xylabs/promise").AnyNonPromise, assert: import("@xylabs/object").StringOrAlertFunction<import("@xyo-network/payload-model").SchemaFields & import("@xyo-network/payload-model").PayloadFields & ApiCallFields & {
|
|
59
59
|
params?: Record<string, string> | undefined;
|
|
60
60
|
uriTemplate?: string | undefined;
|
|
61
61
|
} & {
|
|
@@ -67,8 +67,8 @@ export declare const ApiCallResultSchema = "network.xyo.api.call.result";
|
|
|
67
67
|
export type ApiCallResultSchema = typeof ApiCallResultSchema;
|
|
68
68
|
export declare const isApiCall: (x?: unknown) => x is ApiCall;
|
|
69
69
|
export declare const asApiCall: {
|
|
70
|
-
<TType extends ApiCall>(value: import("@xylabs/promise").AnyNonPromise
|
|
71
|
-
<TType_1 extends ApiCall>(value: import("@xylabs/promise").AnyNonPromise
|
|
70
|
+
<TType extends ApiCall>(value: import("@xylabs/promise").AnyNonPromise, config?: import("@xylabs/object").TypeCheckConfig | undefined): TType | undefined;
|
|
71
|
+
<TType_1 extends ApiCall>(value: import("@xylabs/promise").AnyNonPromise, assert: import("@xylabs/object").StringOrAlertFunction<ApiCall>, config?: import("@xylabs/object").TypeCheckConfig | undefined): TType_1;
|
|
72
72
|
};
|
|
73
73
|
export interface HttpMeta {
|
|
74
74
|
code?: string;
|
|
@@ -94,14 +94,14 @@ export declare const asApiCallJsonResult: {
|
|
|
94
94
|
data: ApiCallJsonResultType;
|
|
95
95
|
} & {
|
|
96
96
|
schema: "network.xyo.api.call.result";
|
|
97
|
-
}>(value: import("@xylabs/promise").AnyNonPromise
|
|
97
|
+
}>(value: import("@xylabs/promise").AnyNonPromise, config?: import("@xylabs/object").TypeCheckConfig | undefined): TType | undefined;
|
|
98
98
|
<TType_1 extends import("@xyo-network/payload-model").SchemaFields & import("@xyo-network/payload-model").PayloadFields & {
|
|
99
99
|
call: Hash;
|
|
100
100
|
contentType: 'application/json';
|
|
101
101
|
data: ApiCallJsonResultType;
|
|
102
102
|
} & {
|
|
103
103
|
schema: "network.xyo.api.call.result";
|
|
104
|
-
}>(value: import("@xylabs/promise").AnyNonPromise
|
|
104
|
+
}>(value: import("@xylabs/promise").AnyNonPromise, assert: import("@xylabs/object").StringOrAlertFunction<import("@xyo-network/payload-model").SchemaFields & import("@xyo-network/payload-model").PayloadFields & {
|
|
105
105
|
call: Hash;
|
|
106
106
|
contentType: 'application/json';
|
|
107
107
|
data: ApiCallJsonResultType;
|
|
@@ -121,7 +121,7 @@ export type ApiCallErrorResult = Payload<{
|
|
|
121
121
|
export type ApiCallResult<TJson extends JsonArray | JsonObject = JsonArray | JsonObject> = ApiCallBase64Result | ApiCallJsonResult<TJson> | ApiCallErrorResult;
|
|
122
122
|
export declare const isApiCallResult: (x?: unknown) => x is ApiCallResult<JsonArray | JsonObject>;
|
|
123
123
|
export declare const asApiCallResult: {
|
|
124
|
-
<TType extends ApiCallResult<JsonArray | JsonObject>>(value: import("@xylabs/promise").AnyNonPromise
|
|
125
|
-
<TType_1 extends ApiCallResult<JsonArray | JsonObject>>(value: import("@xylabs/promise").AnyNonPromise
|
|
124
|
+
<TType extends ApiCallResult<JsonArray | JsonObject>>(value: import("@xylabs/promise").AnyNonPromise, config?: import("@xylabs/object").TypeCheckConfig | undefined): TType | undefined;
|
|
125
|
+
<TType_1 extends ApiCallResult<JsonArray | JsonObject>>(value: import("@xylabs/promise").AnyNonPromise, assert: import("@xylabs/object").StringOrAlertFunction<ApiCallResult<JsonArray | JsonObject>>, config?: import("@xylabs/object").TypeCheckConfig | undefined): TType_1;
|
|
126
126
|
};
|
|
127
127
|
//# sourceMappingURL=Payload.d.ts.map
|