@predictorsdk/client 0.1.1 → 0.1.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 +1 -1
- package/dist/Client.js +47 -7
- package/dist/api/client/requests/GetSportsMatchingMarketsRequest.d.ts +4 -4
- package/dist/api/types/ErrorResponse.d.ts +1 -1
- package/dist/api/types/PlatformMarket.d.ts +8 -16
- package/dist/api/types/PlatformMarket.js +1 -9
- package/dist/api/types/PlatformMarketPlatform.d.ts +7 -0
- package/dist/api/types/PlatformMarketPlatform.js +7 -0
- package/dist/api/types/index.d.ts +1 -0
- package/dist/api/types/index.js +1 -0
- package/dist/core/auth/BasicAuth.d.ts +2 -2
- package/dist/core/auth/BasicAuth.js +6 -1
- package/dist/core/index.d.ts +1 -0
- package/dist/core/index.js +1 -0
- package/dist/core/schemas/Schema.d.ts +88 -0
- package/dist/core/schemas/Schema.js +22 -0
- package/dist/core/schemas/builders/bigint/bigint.d.ts +2 -0
- package/dist/core/schemas/builders/bigint/bigint.js +53 -0
- package/dist/core/schemas/builders/bigint/index.d.ts +1 -0
- package/dist/core/schemas/builders/bigint/index.js +1 -0
- package/dist/core/schemas/builders/date/date.d.ts +2 -0
- package/dist/core/schemas/builders/date/date.js +62 -0
- package/dist/core/schemas/builders/date/index.d.ts +1 -0
- package/dist/core/schemas/builders/date/index.js +1 -0
- package/dist/core/schemas/builders/enum/enum.d.ts +2 -0
- package/dist/core/schemas/builders/enum/enum.js +35 -0
- package/dist/core/schemas/builders/enum/index.d.ts +1 -0
- package/dist/core/schemas/builders/enum/index.js +1 -0
- package/dist/core/schemas/builders/index.d.ts +14 -0
- package/dist/core/schemas/builders/index.js +14 -0
- package/dist/core/schemas/builders/lazy/index.d.ts +3 -0
- package/dist/core/schemas/builders/lazy/index.js +2 -0
- package/dist/core/schemas/builders/lazy/lazy.d.ts +5 -0
- package/dist/core/schemas/builders/lazy/lazy.js +22 -0
- package/dist/core/schemas/builders/lazy/lazyObject.d.ts +3 -0
- package/dist/core/schemas/builders/lazy/lazyObject.js +17 -0
- package/dist/core/schemas/builders/list/index.d.ts +1 -0
- package/dist/core/schemas/builders/list/index.js +1 -0
- package/dist/core/schemas/builders/list/list.d.ts +2 -0
- package/dist/core/schemas/builders/list/list.js +49 -0
- package/dist/core/schemas/builders/literals/booleanLiteral.d.ts +2 -0
- package/dist/core/schemas/builders/literals/booleanLiteral.js +25 -0
- package/dist/core/schemas/builders/literals/index.d.ts +2 -0
- package/dist/core/schemas/builders/literals/index.js +2 -0
- package/dist/core/schemas/builders/literals/stringLiteral.d.ts +2 -0
- package/dist/core/schemas/builders/literals/stringLiteral.js +25 -0
- package/dist/core/schemas/builders/object/index.d.ts +6 -0
- package/dist/core/schemas/builders/object/index.js +3 -0
- package/dist/core/schemas/builders/object/object.d.ts +3 -0
- package/dist/core/schemas/builders/object/object.js +381 -0
- package/dist/core/schemas/builders/object/objectWithoutOptionalProperties.d.ts +6 -0
- package/dist/core/schemas/builders/object/objectWithoutOptionalProperties.js +4 -0
- package/dist/core/schemas/builders/object/property.d.ts +8 -0
- package/dist/core/schemas/builders/object/property.js +11 -0
- package/dist/core/schemas/builders/object/types.d.ts +31 -0
- package/dist/core/schemas/builders/object/types.js +1 -0
- package/dist/core/schemas/builders/object-like/getObjectLikeUtils.d.ts +9 -0
- package/dist/core/schemas/builders/object-like/getObjectLikeUtils.js +62 -0
- package/dist/core/schemas/builders/object-like/index.d.ts +2 -0
- package/dist/core/schemas/builders/object-like/index.js +1 -0
- package/dist/core/schemas/builders/object-like/types.d.ts +7 -0
- package/dist/core/schemas/builders/object-like/types.js +1 -0
- package/dist/core/schemas/builders/primitives/any.d.ts +2 -0
- package/dist/core/schemas/builders/primitives/any.js +6 -0
- package/dist/core/schemas/builders/primitives/boolean.d.ts +2 -0
- package/dist/core/schemas/builders/primitives/boolean.js +22 -0
- package/dist/core/schemas/builders/primitives/index.d.ts +6 -0
- package/dist/core/schemas/builders/primitives/index.js +6 -0
- package/dist/core/schemas/builders/primitives/never.d.ts +2 -0
- package/dist/core/schemas/builders/primitives/never.js +11 -0
- package/dist/core/schemas/builders/primitives/number.d.ts +2 -0
- package/dist/core/schemas/builders/primitives/number.js +22 -0
- package/dist/core/schemas/builders/primitives/string.d.ts +2 -0
- package/dist/core/schemas/builders/primitives/string.js +22 -0
- package/dist/core/schemas/builders/primitives/unknown.d.ts +2 -0
- package/dist/core/schemas/builders/primitives/unknown.js +3 -0
- package/dist/core/schemas/builders/record/index.d.ts +2 -0
- package/dist/core/schemas/builders/record/index.js +1 -0
- package/dist/core/schemas/builders/record/record.d.ts +4 -0
- package/dist/core/schemas/builders/record/record.js +133 -0
- package/dist/core/schemas/builders/record/types.d.ts +6 -0
- package/dist/core/schemas/builders/record/types.js +1 -0
- package/dist/core/schemas/builders/schema-utils/JsonError.d.ts +5 -0
- package/dist/core/schemas/builders/schema-utils/JsonError.js +9 -0
- package/dist/core/schemas/builders/schema-utils/ParseError.d.ts +5 -0
- package/dist/core/schemas/builders/schema-utils/ParseError.js +9 -0
- package/dist/core/schemas/builders/schema-utils/getSchemaUtils.d.ts +21 -0
- package/dist/core/schemas/builders/schema-utils/getSchemaUtils.js +150 -0
- package/dist/core/schemas/builders/schema-utils/index.d.ts +4 -0
- package/dist/core/schemas/builders/schema-utils/index.js +3 -0
- package/dist/core/schemas/builders/schema-utils/stringifyValidationErrors.d.ts +2 -0
- package/dist/core/schemas/builders/schema-utils/stringifyValidationErrors.js +6 -0
- package/dist/core/schemas/builders/set/index.d.ts +1 -0
- package/dist/core/schemas/builders/set/index.js +1 -0
- package/dist/core/schemas/builders/set/set.d.ts +2 -0
- package/dist/core/schemas/builders/set/set.js +42 -0
- package/dist/core/schemas/builders/undiscriminated-union/index.d.ts +2 -0
- package/dist/core/schemas/builders/undiscriminated-union/index.js +1 -0
- package/dist/core/schemas/builders/undiscriminated-union/types.d.ts +4 -0
- package/dist/core/schemas/builders/undiscriminated-union/types.js +1 -0
- package/dist/core/schemas/builders/undiscriminated-union/undiscriminatedUnion.d.ts +3 -0
- package/dist/core/schemas/builders/undiscriminated-union/undiscriminatedUnion.js +39 -0
- package/dist/core/schemas/builders/union/discriminant.d.ts +5 -0
- package/dist/core/schemas/builders/union/discriminant.js +6 -0
- package/dist/core/schemas/builders/union/index.d.ts +4 -0
- package/dist/core/schemas/builders/union/index.js +2 -0
- package/dist/core/schemas/builders/union/types.d.ts +13 -0
- package/dist/core/schemas/builders/union/types.js +1 -0
- package/dist/core/schemas/builders/union/union.d.ts +4 -0
- package/dist/core/schemas/builders/union/union.js +127 -0
- package/dist/core/schemas/index.d.ts +2 -0
- package/dist/core/schemas/index.js +1 -0
- package/dist/core/schemas/utils/MaybePromise.d.ts +1 -0
- package/dist/core/schemas/utils/MaybePromise.js +1 -0
- package/dist/core/schemas/utils/addQuestionMarksToNullableProperties.d.ts +7 -0
- package/dist/core/schemas/utils/addQuestionMarksToNullableProperties.js +1 -0
- package/dist/core/schemas/utils/createIdentitySchemaCreator.d.ts +2 -0
- package/dist/core/schemas/utils/createIdentitySchemaCreator.js +15 -0
- package/dist/core/schemas/utils/entries.d.ts +1 -0
- package/dist/core/schemas/utils/entries.js +3 -0
- package/dist/core/schemas/utils/filterObject.d.ts +1 -0
- package/dist/core/schemas/utils/filterObject.js +10 -0
- package/dist/core/schemas/utils/getErrorMessageForIncorrectType.d.ts +1 -0
- package/dist/core/schemas/utils/getErrorMessageForIncorrectType.js +24 -0
- package/dist/core/schemas/utils/isPlainObject.d.ts +1 -0
- package/dist/core/schemas/utils/isPlainObject.js +12 -0
- package/dist/core/schemas/utils/keys.d.ts +1 -0
- package/dist/core/schemas/utils/keys.js +3 -0
- package/dist/core/schemas/utils/maybeSkipValidation.d.ts +2 -0
- package/dist/core/schemas/utils/maybeSkipValidation.js +28 -0
- package/dist/core/schemas/utils/partition.d.ts +1 -0
- package/dist/core/schemas/utils/partition.js +12 -0
- package/dist/index.d.ts +1 -0
- package/dist/index.js +1 -0
- package/dist/serialization/index.d.ts +1 -0
- package/dist/serialization/index.js +1 -0
- package/dist/serialization/types/ErrorResponse.d.ts +10 -0
- package/dist/serialization/types/ErrorResponse.js +6 -0
- package/dist/serialization/types/PlatformMarket.d.ts +16 -0
- package/dist/serialization/types/PlatformMarket.js +12 -0
- package/dist/serialization/types/PlatformMarketPlatform.d.ts +7 -0
- package/dist/serialization/types/PlatformMarketPlatform.js +3 -0
- package/dist/serialization/types/SportsMatchingResponse.d.ts +10 -0
- package/dist/serialization/types/SportsMatchingResponse.js +6 -0
- package/dist/serialization/types/index.d.ts +4 -0
- package/dist/serialization/types/index.js +4 -0
- package/package.json +13 -2
|
@@ -0,0 +1,39 @@
|
|
|
1
|
+
import { SchemaType, } from "../../Schema.js";
|
|
2
|
+
import { maybeSkipValidation } from "../../utils/maybeSkipValidation.js";
|
|
3
|
+
import { getSchemaUtils } from "../schema-utils/index.js";
|
|
4
|
+
export function undiscriminatedUnion(schemas) {
|
|
5
|
+
const baseSchema = {
|
|
6
|
+
parse: (raw, opts) => {
|
|
7
|
+
return validateAndTransformUndiscriminatedUnion((schema, opts) => schema.parse(raw, opts), schemas, opts);
|
|
8
|
+
},
|
|
9
|
+
json: (parsed, opts) => {
|
|
10
|
+
return validateAndTransformUndiscriminatedUnion((schema, opts) => schema.json(parsed, opts), schemas, opts);
|
|
11
|
+
},
|
|
12
|
+
getType: () => SchemaType.UNDISCRIMINATED_UNION,
|
|
13
|
+
};
|
|
14
|
+
return {
|
|
15
|
+
...maybeSkipValidation(baseSchema),
|
|
16
|
+
...getSchemaUtils(baseSchema),
|
|
17
|
+
};
|
|
18
|
+
}
|
|
19
|
+
function validateAndTransformUndiscriminatedUnion(transform, schemas, opts) {
|
|
20
|
+
const errors = [];
|
|
21
|
+
for (const [index, schema] of schemas.entries()) {
|
|
22
|
+
const transformed = transform(schema, { ...opts, skipValidation: false });
|
|
23
|
+
if (transformed.ok) {
|
|
24
|
+
return transformed;
|
|
25
|
+
}
|
|
26
|
+
else {
|
|
27
|
+
for (const error of transformed.errors) {
|
|
28
|
+
errors.push({
|
|
29
|
+
path: error.path,
|
|
30
|
+
message: `[Variant ${index}] ${error.message}`,
|
|
31
|
+
});
|
|
32
|
+
}
|
|
33
|
+
}
|
|
34
|
+
}
|
|
35
|
+
return {
|
|
36
|
+
ok: false,
|
|
37
|
+
errors,
|
|
38
|
+
};
|
|
39
|
+
}
|
|
@@ -0,0 +1,5 @@
|
|
|
1
|
+
export declare function discriminant<RawDiscriminant extends string, ParsedDiscriminant extends string>(parsedDiscriminant: ParsedDiscriminant, rawDiscriminant: RawDiscriminant): Discriminant<RawDiscriminant, ParsedDiscriminant>;
|
|
2
|
+
export interface Discriminant<RawDiscriminant extends string, ParsedDiscriminant extends string> {
|
|
3
|
+
parsedDiscriminant: ParsedDiscriminant;
|
|
4
|
+
rawDiscriminant: RawDiscriminant;
|
|
5
|
+
}
|
|
@@ -0,0 +1,4 @@
|
|
|
1
|
+
export type { Discriminant } from "./discriminant.js";
|
|
2
|
+
export { discriminant } from "./discriminant.js";
|
|
3
|
+
export type { inferParsedDiscriminant, inferParsedUnion, inferRawDiscriminant, inferRawUnion, UnionSubtypes, } from "./types.js";
|
|
4
|
+
export { union } from "./union.js";
|
|
@@ -0,0 +1,13 @@
|
|
|
1
|
+
import type { inferParsedObject, inferRawObject, ObjectSchema } from "../object/index.js";
|
|
2
|
+
import type { Discriminant } from "./discriminant.js";
|
|
3
|
+
export type UnionSubtypes<DiscriminantValues extends string | number | symbol> = {
|
|
4
|
+
[K in DiscriminantValues]: ObjectSchema<any, any>;
|
|
5
|
+
};
|
|
6
|
+
export type inferRawUnion<D extends string | Discriminant<any, any>, U extends UnionSubtypes<keyof U>> = {
|
|
7
|
+
[K in keyof U]: Record<inferRawDiscriminant<D>, K> & inferRawObject<U[K]>;
|
|
8
|
+
}[keyof U];
|
|
9
|
+
export type inferParsedUnion<D extends string | Discriminant<any, any>, U extends UnionSubtypes<keyof U>> = {
|
|
10
|
+
[K in keyof U]: Record<inferParsedDiscriminant<D>, K> & inferParsedObject<U[K]>;
|
|
11
|
+
}[keyof U];
|
|
12
|
+
export type inferRawDiscriminant<D extends string | Discriminant<any, any>> = D extends string ? D : D extends Discriminant<infer Raw, any> ? Raw : never;
|
|
13
|
+
export type inferParsedDiscriminant<D extends string | Discriminant<any, any>> = D extends string ? D : D extends Discriminant<any, infer Parsed> ? Parsed : never;
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
export {};
|
|
@@ -0,0 +1,4 @@
|
|
|
1
|
+
import { type ObjectLikeSchema } from "../object-like/index.js";
|
|
2
|
+
import type { Discriminant } from "./discriminant.js";
|
|
3
|
+
import type { inferParsedUnion, inferRawUnion, UnionSubtypes } from "./types.js";
|
|
4
|
+
export declare function union<D extends string | Discriminant<any, any>, U extends UnionSubtypes<any>>(discriminant: D, union: U): ObjectLikeSchema<inferRawUnion<D, U>, inferParsedUnion<D, U>>;
|
|
@@ -0,0 +1,127 @@
|
|
|
1
|
+
import { SchemaType } from "../../Schema.js";
|
|
2
|
+
import { getErrorMessageForIncorrectType } from "../../utils/getErrorMessageForIncorrectType.js";
|
|
3
|
+
import { isPlainObject } from "../../utils/isPlainObject.js";
|
|
4
|
+
import { keys } from "../../utils/keys.js";
|
|
5
|
+
import { maybeSkipValidation } from "../../utils/maybeSkipValidation.js";
|
|
6
|
+
import { enum_ } from "../enum/index.js";
|
|
7
|
+
import { getObjectLikeUtils } from "../object-like/index.js";
|
|
8
|
+
import { getSchemaUtils } from "../schema-utils/index.js";
|
|
9
|
+
// eslint-disable-next-line @typescript-eslint/unbound-method
|
|
10
|
+
const _hasOwn = Object.prototype.hasOwnProperty;
|
|
11
|
+
export function union(discriminant, union) {
|
|
12
|
+
const rawDiscriminant = typeof discriminant === "string" ? discriminant : discriminant.rawDiscriminant;
|
|
13
|
+
const parsedDiscriminant = typeof discriminant === "string"
|
|
14
|
+
? discriminant
|
|
15
|
+
: discriminant.parsedDiscriminant;
|
|
16
|
+
const discriminantValueSchema = enum_(keys(union));
|
|
17
|
+
const baseSchema = {
|
|
18
|
+
parse: (raw, opts) => {
|
|
19
|
+
return transformAndValidateUnion({
|
|
20
|
+
value: raw,
|
|
21
|
+
discriminant: rawDiscriminant,
|
|
22
|
+
transformedDiscriminant: parsedDiscriminant,
|
|
23
|
+
transformDiscriminantValue: (discriminantValue) => discriminantValueSchema.parse(discriminantValue, {
|
|
24
|
+
allowUnrecognizedEnumValues: opts?.allowUnrecognizedUnionMembers,
|
|
25
|
+
breadcrumbsPrefix: [...(opts?.breadcrumbsPrefix ?? []), rawDiscriminant],
|
|
26
|
+
}),
|
|
27
|
+
getAdditionalPropertiesSchema: (discriminantValue) => union[discriminantValue],
|
|
28
|
+
allowUnrecognizedUnionMembers: opts?.allowUnrecognizedUnionMembers,
|
|
29
|
+
transformAdditionalProperties: (additionalProperties, additionalPropertiesSchema) => additionalPropertiesSchema.parse(additionalProperties, opts),
|
|
30
|
+
breadcrumbsPrefix: opts?.breadcrumbsPrefix,
|
|
31
|
+
});
|
|
32
|
+
},
|
|
33
|
+
json: (parsed, opts) => {
|
|
34
|
+
return transformAndValidateUnion({
|
|
35
|
+
value: parsed,
|
|
36
|
+
discriminant: parsedDiscriminant,
|
|
37
|
+
transformedDiscriminant: rawDiscriminant,
|
|
38
|
+
transformDiscriminantValue: (discriminantValue) => discriminantValueSchema.json(discriminantValue, {
|
|
39
|
+
allowUnrecognizedEnumValues: opts?.allowUnrecognizedUnionMembers,
|
|
40
|
+
breadcrumbsPrefix: [...(opts?.breadcrumbsPrefix ?? []), parsedDiscriminant],
|
|
41
|
+
}),
|
|
42
|
+
getAdditionalPropertiesSchema: (discriminantValue) => union[discriminantValue],
|
|
43
|
+
allowUnrecognizedUnionMembers: opts?.allowUnrecognizedUnionMembers,
|
|
44
|
+
transformAdditionalProperties: (additionalProperties, additionalPropertiesSchema) => additionalPropertiesSchema.json(additionalProperties, opts),
|
|
45
|
+
breadcrumbsPrefix: opts?.breadcrumbsPrefix,
|
|
46
|
+
});
|
|
47
|
+
},
|
|
48
|
+
getType: () => SchemaType.UNION,
|
|
49
|
+
};
|
|
50
|
+
return {
|
|
51
|
+
...maybeSkipValidation(baseSchema),
|
|
52
|
+
...getSchemaUtils(baseSchema),
|
|
53
|
+
...getObjectLikeUtils(baseSchema),
|
|
54
|
+
};
|
|
55
|
+
}
|
|
56
|
+
function transformAndValidateUnion({ value, discriminant, transformedDiscriminant, transformDiscriminantValue, getAdditionalPropertiesSchema, allowUnrecognizedUnionMembers = false, transformAdditionalProperties, breadcrumbsPrefix = [], }) {
|
|
57
|
+
if (!isPlainObject(value)) {
|
|
58
|
+
return {
|
|
59
|
+
ok: false,
|
|
60
|
+
errors: [
|
|
61
|
+
{
|
|
62
|
+
path: breadcrumbsPrefix,
|
|
63
|
+
message: getErrorMessageForIncorrectType(value, "object"),
|
|
64
|
+
},
|
|
65
|
+
],
|
|
66
|
+
};
|
|
67
|
+
}
|
|
68
|
+
const discriminantValue = value[discriminant];
|
|
69
|
+
const additionalProperties = {};
|
|
70
|
+
for (const key in value) {
|
|
71
|
+
if (_hasOwn.call(value, key) && key !== discriminant) {
|
|
72
|
+
additionalProperties[key] = value[key];
|
|
73
|
+
}
|
|
74
|
+
}
|
|
75
|
+
if (discriminantValue == null) {
|
|
76
|
+
return {
|
|
77
|
+
ok: false,
|
|
78
|
+
errors: [
|
|
79
|
+
{
|
|
80
|
+
path: breadcrumbsPrefix,
|
|
81
|
+
message: `Missing discriminant ("${discriminant}")`,
|
|
82
|
+
},
|
|
83
|
+
],
|
|
84
|
+
};
|
|
85
|
+
}
|
|
86
|
+
const transformedDiscriminantValue = transformDiscriminantValue(discriminantValue);
|
|
87
|
+
if (!transformedDiscriminantValue.ok) {
|
|
88
|
+
return {
|
|
89
|
+
ok: false,
|
|
90
|
+
errors: transformedDiscriminantValue.errors,
|
|
91
|
+
};
|
|
92
|
+
}
|
|
93
|
+
const additionalPropertiesSchema = getAdditionalPropertiesSchema(transformedDiscriminantValue.value);
|
|
94
|
+
if (additionalPropertiesSchema == null) {
|
|
95
|
+
if (allowUnrecognizedUnionMembers) {
|
|
96
|
+
return {
|
|
97
|
+
ok: true,
|
|
98
|
+
value: {
|
|
99
|
+
[transformedDiscriminant]: transformedDiscriminantValue.value,
|
|
100
|
+
...additionalProperties,
|
|
101
|
+
},
|
|
102
|
+
};
|
|
103
|
+
}
|
|
104
|
+
else {
|
|
105
|
+
return {
|
|
106
|
+
ok: false,
|
|
107
|
+
errors: [
|
|
108
|
+
{
|
|
109
|
+
path: [...breadcrumbsPrefix, discriminant],
|
|
110
|
+
message: "Unexpected discriminant value",
|
|
111
|
+
},
|
|
112
|
+
],
|
|
113
|
+
};
|
|
114
|
+
}
|
|
115
|
+
}
|
|
116
|
+
const transformedAdditionalProperties = transformAdditionalProperties(additionalProperties, additionalPropertiesSchema);
|
|
117
|
+
if (!transformedAdditionalProperties.ok) {
|
|
118
|
+
return transformedAdditionalProperties;
|
|
119
|
+
}
|
|
120
|
+
return {
|
|
121
|
+
ok: true,
|
|
122
|
+
value: {
|
|
123
|
+
[transformedDiscriminant]: discriminantValue,
|
|
124
|
+
...transformedAdditionalProperties.value,
|
|
125
|
+
},
|
|
126
|
+
};
|
|
127
|
+
}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
export * from "./builders/index.js";
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
export type MaybePromise<T> = T | Promise<T>;
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
export {};
|
|
@@ -0,0 +1,7 @@
|
|
|
1
|
+
export type addQuestionMarksToNullableProperties<T> = {
|
|
2
|
+
[K in OptionalKeys<T>]?: T[K];
|
|
3
|
+
} & Pick<T, RequiredKeys<T>>;
|
|
4
|
+
export type OptionalKeys<T> = {
|
|
5
|
+
[K in keyof T]-?: undefined extends T[K] ? K : never;
|
|
6
|
+
}[keyof T];
|
|
7
|
+
export type RequiredKeys<T> = Exclude<keyof T, OptionalKeys<T>>;
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
export {};
|
|
@@ -0,0 +1,15 @@
|
|
|
1
|
+
import { getSchemaUtils } from "../builders/schema-utils/index.js";
|
|
2
|
+
import { maybeSkipValidation } from "./maybeSkipValidation.js";
|
|
3
|
+
export function createIdentitySchemaCreator(schemaType, validate) {
|
|
4
|
+
return () => {
|
|
5
|
+
const baseSchema = {
|
|
6
|
+
parse: validate,
|
|
7
|
+
json: validate,
|
|
8
|
+
getType: () => schemaType,
|
|
9
|
+
};
|
|
10
|
+
return {
|
|
11
|
+
...maybeSkipValidation(baseSchema),
|
|
12
|
+
...getSchemaUtils(baseSchema),
|
|
13
|
+
};
|
|
14
|
+
};
|
|
15
|
+
}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
export declare function entries<T extends object>(object: T): [keyof T, T[keyof T]][];
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
export declare function filterObject<T extends object, K extends keyof T>(obj: T, keysToInclude: K[]): Pick<T, K>;
|
|
@@ -0,0 +1,10 @@
|
|
|
1
|
+
export function filterObject(obj, keysToInclude) {
|
|
2
|
+
const keysToIncludeSet = new Set(keysToInclude);
|
|
3
|
+
return Object.entries(obj).reduce((acc, [key, value]) => {
|
|
4
|
+
if (keysToIncludeSet.has(key)) {
|
|
5
|
+
acc[key] = value;
|
|
6
|
+
}
|
|
7
|
+
return acc;
|
|
8
|
+
// eslint-disable-next-line @typescript-eslint/prefer-reduce-type-parameter
|
|
9
|
+
}, {});
|
|
10
|
+
}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
export declare function getErrorMessageForIncorrectType(value: unknown, expectedType: string): string;
|
|
@@ -0,0 +1,24 @@
|
|
|
1
|
+
export function getErrorMessageForIncorrectType(value, expectedType) {
|
|
2
|
+
return `Expected ${expectedType}. Received ${getTypeAsString(value)}.`;
|
|
3
|
+
}
|
|
4
|
+
function getTypeAsString(value) {
|
|
5
|
+
if (Array.isArray(value)) {
|
|
6
|
+
return "list";
|
|
7
|
+
}
|
|
8
|
+
if (value === null) {
|
|
9
|
+
return "null";
|
|
10
|
+
}
|
|
11
|
+
if (value instanceof BigInt) {
|
|
12
|
+
return "BigInt";
|
|
13
|
+
}
|
|
14
|
+
switch (typeof value) {
|
|
15
|
+
case "string":
|
|
16
|
+
return `"${value}"`;
|
|
17
|
+
case "bigint":
|
|
18
|
+
case "number":
|
|
19
|
+
case "boolean":
|
|
20
|
+
case "undefined":
|
|
21
|
+
return `${value}`;
|
|
22
|
+
}
|
|
23
|
+
return typeof value;
|
|
24
|
+
}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
export declare function isPlainObject(value: unknown): value is Record<string, unknown>;
|
|
@@ -0,0 +1,12 @@
|
|
|
1
|
+
// borrowed from https://github.com/lodash/lodash/blob/master/isPlainObject.js
|
|
2
|
+
export function isPlainObject(value) {
|
|
3
|
+
if (typeof value !== "object" || value === null) {
|
|
4
|
+
return false;
|
|
5
|
+
}
|
|
6
|
+
const proto = Object.getPrototypeOf(value);
|
|
7
|
+
if (proto === null) {
|
|
8
|
+
return true;
|
|
9
|
+
}
|
|
10
|
+
// Check that the prototype chain has exactly one level (i.e., proto is Object.prototype)
|
|
11
|
+
return Object.getPrototypeOf(proto) === null;
|
|
12
|
+
}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
export declare function keys<T extends object>(object: T): (keyof T)[];
|
|
@@ -0,0 +1,28 @@
|
|
|
1
|
+
export function maybeSkipValidation(schema) {
|
|
2
|
+
return {
|
|
3
|
+
...schema,
|
|
4
|
+
json: transformAndMaybeSkipValidation(schema.json),
|
|
5
|
+
parse: transformAndMaybeSkipValidation(schema.parse),
|
|
6
|
+
};
|
|
7
|
+
}
|
|
8
|
+
function transformAndMaybeSkipValidation(transform) {
|
|
9
|
+
return (value, opts) => {
|
|
10
|
+
const transformed = transform(value, opts);
|
|
11
|
+
const { skipValidation = false } = opts ?? {};
|
|
12
|
+
if (!transformed.ok && skipValidation) {
|
|
13
|
+
// biome-ignore lint/suspicious/noConsole: allow console
|
|
14
|
+
console.warn([
|
|
15
|
+
"Failed to validate.",
|
|
16
|
+
...transformed.errors.map((error) => " - " +
|
|
17
|
+
(error.path.length > 0 ? `${error.path.join(".")}: ${error.message}` : error.message)),
|
|
18
|
+
].join("\n"));
|
|
19
|
+
return {
|
|
20
|
+
ok: true,
|
|
21
|
+
value: value,
|
|
22
|
+
};
|
|
23
|
+
}
|
|
24
|
+
else {
|
|
25
|
+
return transformed;
|
|
26
|
+
}
|
|
27
|
+
};
|
|
28
|
+
}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
export declare function partition<T>(items: readonly T[], predicate: (item: T) => boolean): [T[], T[]];
|
package/dist/index.d.ts
CHANGED
|
@@ -4,3 +4,4 @@ export { PredictorSDKClient } from "./Client.js";
|
|
|
4
4
|
export { PredictorSDKEnvironment } from "./environments.js";
|
|
5
5
|
export { PredictorSDKError, PredictorSDKTimeoutError } from "./errors/index.js";
|
|
6
6
|
export * from "./exports.js";
|
|
7
|
+
export * as serialization from "./serialization/index.js";
|
package/dist/index.js
CHANGED
|
@@ -3,3 +3,4 @@ export { PredictorSDKClient } from "./Client.js";
|
|
|
3
3
|
export { PredictorSDKEnvironment } from "./environments.js";
|
|
4
4
|
export { PredictorSDKError, PredictorSDKTimeoutError } from "./errors/index.js";
|
|
5
5
|
export * from "./exports.js";
|
|
6
|
+
export * as serialization from "./serialization/index.js";
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
export * from "./types/index.js";
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
export * from "./types/index.js";
|
|
@@ -0,0 +1,10 @@
|
|
|
1
|
+
import type * as PredictorSDK from "../../api/index.js";
|
|
2
|
+
import * as core from "../../core/index.js";
|
|
3
|
+
import type * as serializers from "../index.js";
|
|
4
|
+
export declare const ErrorResponse: core.serialization.ObjectSchema<serializers.ErrorResponse.Raw, PredictorSDK.ErrorResponse>;
|
|
5
|
+
export declare namespace ErrorResponse {
|
|
6
|
+
interface Raw {
|
|
7
|
+
error: string;
|
|
8
|
+
status_code: number;
|
|
9
|
+
}
|
|
10
|
+
}
|
|
@@ -0,0 +1,6 @@
|
|
|
1
|
+
// This file was auto-generated by Fern from our API Definition.
|
|
2
|
+
import * as core from "../../core/index.js";
|
|
3
|
+
export const ErrorResponse = core.serialization.object({
|
|
4
|
+
error: core.serialization.string(),
|
|
5
|
+
statusCode: core.serialization.property("status_code", core.serialization.number()),
|
|
6
|
+
});
|
|
@@ -0,0 +1,16 @@
|
|
|
1
|
+
import type * as PredictorSDK from "../../api/index.js";
|
|
2
|
+
import * as core from "../../core/index.js";
|
|
3
|
+
import type * as serializers from "../index.js";
|
|
4
|
+
import { PlatformMarketPlatform } from "./PlatformMarketPlatform.js";
|
|
5
|
+
export declare const PlatformMarket: core.serialization.ObjectSchema<serializers.PlatformMarket.Raw, PredictorSDK.PlatformMarket>;
|
|
6
|
+
export declare namespace PlatformMarket {
|
|
7
|
+
interface Raw {
|
|
8
|
+
platform: PlatformMarketPlatform.Raw;
|
|
9
|
+
event_ticker?: string | null;
|
|
10
|
+
market_tickers?: string[] | null;
|
|
11
|
+
market_slug?: string | null;
|
|
12
|
+
token_ids?: string[] | null;
|
|
13
|
+
market_id?: string | null;
|
|
14
|
+
outcome_ids?: string[] | null;
|
|
15
|
+
}
|
|
16
|
+
}
|
|
@@ -0,0 +1,12 @@
|
|
|
1
|
+
// This file was auto-generated by Fern from our API Definition.
|
|
2
|
+
import * as core from "../../core/index.js";
|
|
3
|
+
import { PlatformMarketPlatform } from "./PlatformMarketPlatform.js";
|
|
4
|
+
export const PlatformMarket = core.serialization.object({
|
|
5
|
+
platform: PlatformMarketPlatform,
|
|
6
|
+
eventTicker: core.serialization.property("event_ticker", core.serialization.string().optional()),
|
|
7
|
+
marketTickers: core.serialization.property("market_tickers", core.serialization.list(core.serialization.string()).optional()),
|
|
8
|
+
marketSlug: core.serialization.property("market_slug", core.serialization.string().optional()),
|
|
9
|
+
tokenIds: core.serialization.property("token_ids", core.serialization.list(core.serialization.string()).optional()),
|
|
10
|
+
marketId: core.serialization.property("market_id", core.serialization.string().optional()),
|
|
11
|
+
outcomeIds: core.serialization.property("outcome_ids", core.serialization.list(core.serialization.string()).optional()),
|
|
12
|
+
});
|
|
@@ -0,0 +1,7 @@
|
|
|
1
|
+
import type * as PredictorSDK from "../../api/index.js";
|
|
2
|
+
import * as core from "../../core/index.js";
|
|
3
|
+
import type * as serializers from "../index.js";
|
|
4
|
+
export declare const PlatformMarketPlatform: core.serialization.Schema<serializers.PlatformMarketPlatform.Raw, PredictorSDK.PlatformMarketPlatform>;
|
|
5
|
+
export declare namespace PlatformMarketPlatform {
|
|
6
|
+
type Raw = "KALSHI" | "POLYMARKET" | "PREDICT" | "SXBET";
|
|
7
|
+
}
|
|
@@ -0,0 +1,10 @@
|
|
|
1
|
+
import type * as PredictorSDK from "../../api/index.js";
|
|
2
|
+
import * as core from "../../core/index.js";
|
|
3
|
+
import type * as serializers from "../index.js";
|
|
4
|
+
import { PlatformMarket } from "./PlatformMarket.js";
|
|
5
|
+
export declare const SportsMatchingResponse: core.serialization.ObjectSchema<serializers.SportsMatchingResponse.Raw, PredictorSDK.SportsMatchingResponse>;
|
|
6
|
+
export declare namespace SportsMatchingResponse {
|
|
7
|
+
interface Raw {
|
|
8
|
+
markets: Record<string, PlatformMarket.Raw[]>;
|
|
9
|
+
}
|
|
10
|
+
}
|
|
@@ -0,0 +1,6 @@
|
|
|
1
|
+
// This file was auto-generated by Fern from our API Definition.
|
|
2
|
+
import * as core from "../../core/index.js";
|
|
3
|
+
import { PlatformMarket } from "./PlatformMarket.js";
|
|
4
|
+
export const SportsMatchingResponse = core.serialization.object({
|
|
5
|
+
markets: core.serialization.record(core.serialization.string(), core.serialization.list(PlatformMarket)),
|
|
6
|
+
});
|
package/package.json
CHANGED
|
@@ -1,8 +1,17 @@
|
|
|
1
1
|
{
|
|
2
2
|
"name": "@predictorsdk/client",
|
|
3
|
-
"version": "0.1.
|
|
3
|
+
"version": "0.1.2",
|
|
4
4
|
"description": "The official TypeScript/JavaScript client for the PredictorSDK matching markets API",
|
|
5
5
|
"license": "MIT",
|
|
6
|
+
"keywords": [
|
|
7
|
+
"predictorsdk",
|
|
8
|
+
"sports",
|
|
9
|
+
"betting",
|
|
10
|
+
"prediction-markets",
|
|
11
|
+
"kalshi",
|
|
12
|
+
"polymarket",
|
|
13
|
+
"sdk"
|
|
14
|
+
],
|
|
6
15
|
"type": "module",
|
|
7
16
|
"main": "./dist/index.js",
|
|
8
17
|
"types": "./dist/index.d.ts",
|
|
@@ -18,8 +27,10 @@
|
|
|
18
27
|
"default": "./dist/index.js"
|
|
19
28
|
}
|
|
20
29
|
},
|
|
30
|
+
"sideEffects": false,
|
|
21
31
|
"files": [
|
|
22
|
-
"dist"
|
|
32
|
+
"dist",
|
|
33
|
+
"README.md"
|
|
23
34
|
],
|
|
24
35
|
"repository": {
|
|
25
36
|
"type": "git",
|