dibbo
dibbo
Aarktype
Created by dibbo on 12/18/2024 in #questions
Best way of sharing/compiling types?
I have two applications, in one I have defined types like
const loginPayload = type({
email: email,
password: "string",
"+": "delete",
});
const loginPayload = type({
email: email,
password: "string",
"+": "delete",
});
I can make use of this type throughout the application by inferring i.e.
type LoginPayload = typeof loginPayload.infer;
type LoginPayload = typeof loginPayload.infer;
What would be the best way of sharing this type with the other (separate) application? I've previously been able to use tsc to correctly compile the types into a single file, but with recent versions of ArkType/TS (I'm not sure which updated to impact this), the types compile to any. I came across the following approach in another thread which results in correctly compiled types
const loginPayload = type({
email: email,
password: "string",
"+": "delete",
});

const inferred = loginPayload.infer;

export type LoginPayload = typeof inferred;
const loginPayload = type({
email: email,
password: "string",
"+": "delete",
});

const inferred = loginPayload.infer;

export type LoginPayload = typeof inferred;
Is this the recommended approach for this use case or has something better been introduced since? Thanks!
7 replies
Aarktype
Created by dibbo on 11/3/2024 in #questions
Generic middleware validator
Hello, I'm trying to write a middleware in my app that handles validating the incoming request body. It currently looks like this
export function validateBody<T extends Type>(
validator: T
): MiddlewareObj<ValidatedBody<T["infer"]>> {
return {
before: async ({ event }: Request) => {
if (!event.body) return { statusCode: 400 };
const result = validator(event.body);
if (result instanceof type.errors) {
throw new ClientError(result.summary);
}
event.body = result;
},
};
}
export function validateBody<T extends Type>(
validator: T
): MiddlewareObj<ValidatedBody<T["infer"]>> {
return {
before: async ({ event }: Request) => {
if (!event.body) return { statusCode: 400 };
const result = validator(event.body);
if (result instanceof type.errors) {
throw new ClientError(result.summary);
}
event.body = result;
},
};
}
The return type means that in my handler body comes through with the correct type definition given by the validator, e.g.
const schema = type({name:"string"}}
const handleRequest = middy()
.use(validateBody(schema))
.handler(async ({ body }) => {
// body.name === string!
});
const schema = type({name:"string"}}
const handleRequest = middy()
.use(validateBody(schema))
.handler(async ({ body }) => {
// body.name === string!
});
This has worked nicely so far, but unfortunately with larger schemas I'm getting a Type instantiation is excessively deep and possibly infinite error when calling validateBody. I've read answers to similar questions here and here, and tried out some of the suggestions, but I haven't been able to come up with a solution so far. Is there any way to get this working as expected, or is it not possible with the current limitations of Typescript? Am I safer just casting body in the handler to the expected type (since at that point it has passed validation and I know that it conforms to the expected type)? Any help or suggestions would be greatly appreciated, thanks!
10 replies
Aarktype
Created by dibbo on 8/29/2024 in #questions
Optional property with const string array
Hello, the following
const x = ["a", "b", "c"] as const;
const myType = type({
"optional?": type("===", ...x),
});
const x = ["a", "b", "c"] as const;
const myType = type({
"optional?": type("===", ...x),
});
is giving a
Only required keys may specify default values
Only required keys may specify default values
error. It's not really clear to me why - I assume the === operator is doing more than what I think. Is there a way to have an optional property be one of a string array in arktype? Or is what I'm after effectively indexed access expressions? Thanks
6 replies
Aarktype
Created by dibbo on 8/27/2024 in #questions
Indexed Access Types
Hello, is it possible to recreate the SizeValues type below in arktype?
const sizes = [
{ label: "Big", value: "100kg" },
{ label: "Medium", value: "50kg" },
{ label: "Small", value: "10kg" },
] as const;

type SizeValues = typeof sizes[number]['value'][]
const sizes = [
{ label: "Big", value: "100kg" },
{ label: "Medium", value: "50kg" },
{ label: "Small", value: "10kg" },
] as const;

type SizeValues = typeof sizes[number]['value'][]
9 replies
Aarktype
Created by dibbo on 8/16/2024 in #questions
Latest "keys:distilled" equivalent?
Hello, I started using ArkType a back in v1 and it has obviously come on leaps and bounds since then which is great to see. However, back in v1 you could do something like
export const loginPayload = type(
{
email: 'email',
password: '1<string<999',
},
{ keys: 'distilled' }
);
export const loginPayload = type(
{
email: 'email',
password: '1<string<999',
},
{ keys: 'distilled' }
);
and once you validated a payload against this you would only ever get an object with email/password keys. I'm wondering how to achieve a similar result with the latest version of the library. Thanks.
11 replies