A
arktype5mo ago
Möhre

Is there a way to parse Dates and date iso strings without losing toJsonSchema capabilities.

I'm trying to parse dates and also allow for date objects, but I also require toJsonSchema to work without exceptions.
const dateParse = type("string.date.iso.parse");
const date = new Date();
dateParse(date) // error
dateParse(date.toISOString()) // works
dateParse.in.toJsonSchema() // works

const dateParse2 = type("string.date.iso.parse | Date");
const date = new Date();
dateParse2(date) // works
dateParse2(date.toISOString()) // works
dateParse.in.toJsonSchema() // errors
const dateParse = type("string.date.iso.parse");
const date = new Date();
dateParse(date) // error
dateParse(date.toISOString()) // works
dateParse.in.toJsonSchema() // works

const dateParse2 = type("string.date.iso.parse | Date");
const date = new Date();
dateParse2(date) // works
dateParse2(date.toISOString()) // works
dateParse.in.toJsonSchema() // errors
Is there a way to have all three functionalities combined? It is fine if the json schema only shows the string input. I don't want to convert date -> string -> date if possible and also keep only one schema.
13 Replies
ssalbdivad
ssalbdivad5mo ago
Can you just define the string part first, convert that to JSON schema, then .or it with Date for use in the rest of your app? If not, another less efficient way would be to extract out the string part after with dateParse2.extract("string").in.toJsonSchema()
Möhre
MöhreOP5mo ago
It is sadly not really possible for me to convert it first and than adding date. Is it possible to target the extract in a nested obj and not loose other definitions i.e.
const foo = type({date:"string.date.iso.parse | Date", bar:"number"});

//to
// {date:"string.date.iso.parse", bar:"number"}
// ?
const foo = type({date:"string.date.iso.parse | Date", bar:"number"});

//to
// {date:"string.date.iso.parse", bar:"number"}
// ?
or in generally edit a nested obj? That would kinda solve my problem I think.
// somthing like
foo.date = "string.date.iso.parse"
// somthing like
foo.date = "string.date.iso.parse"
ssalbdivad
ssalbdivad5mo ago
I mean you could .merge it and replace the date and I'm actually publish a map API that will allow you to easily change one key in the next release
Möhre
MöhreOP5mo ago
Merge should work, have not thought about that yet, good idea This is another case where a loose or lax mode could be helpful for converting to json schema i.e. when multiple types are given only use the valid ones.
ssalbdivad
ssalbdivad5mo ago
Yeah I can see that, but I'm pretty wary of implicitly clobbering a bunch of stuff that could be important Like if someone defines a symbol type, should I just delete it? Seems pretty bad I do think more options though around what you're describing would be good But e.g. I don't think I would just randomly remove branches from a union
Möhre
MöhreOP5mo ago
Yeah I see that. Maybe it should just be an optional parameter for the .toJsonSchema({lax:true}). Which is false by default and has some warnings in the docs 🤷‍♂️ Would have to think about this a bit more too
ssalbdivad
ssalbdivad5mo ago
Yeah I just mean even if you have that enabled, where is the line? E.g. if my object is [symbol], there is nothing valid I can really say about that Symbols are totally impossible to represent in JSON or JSON schema and it's a single required element
Möhre
MöhreOP5mo ago
I totally see that. Maybe the lax mode only works on optional types but again this is highly confusing imo
ssalbdivad
ssalbdivad5mo ago
Yeah sadly a lot of the time you just want a particular thing for your use case but when you have to define it at a library level in a cohesive way that won't cause problems it becomes way more complex. But there are some easy wins like a lax mode that could strip out constraints on your type like .narrow that were not serializable is pretty easy to define and would still be a win
Möhre
MöhreOP5mo ago
I guess the most problems regarding this stem from dates anyways. Maybe just handling them a bit differently would solve like 95% of problems people run into. Again thanks for your input! I will think about this a bit more and create an issue the next days.
Josher8a
Josher8a2d ago
Hi David! I'm mashing v2, awesome btw! I encountered that same issue, but I believe a more straightforward approach for being spec compatible is to expose the format meta tag to strings and use .narrow in userland. https://json-schema.org/understanding-json-schema/reference/type#built-in-formats
For example, because JSON doesn't have a "DateTime" type, dates need to be encoded as strings. format allows the schema author to indicate that the string value should be interpreted as a date. By default, format is just an annotation and does not affect validation.
Josher8a
Josher8a2d ago
it works XD
No description
ssalbdivad
ssalbdivad2d ago
Yeah there is actually an open issue for this: https://github.com/arktypeio/arktype/issues/1110 I think it would be a great addition!

Did you find this page helpful?