Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

Validation Error: "startTime" Property Fails to Match Expected "time" Format #899

Open
K4leri opened this issue Oct 26, 2024 · 2 comments
Open
Labels
bug Something isn't working

Comments

@K4leri
Copy link

K4leri commented Oct 26, 2024

What version of Elysia is running?

"elysia": "^1.1.23"

What platform is your computer?

Microsoft Windows NT 10.0.19045.0 x64

What steps can reproduce the bug?

he schema defines the timePeriod type as a string with a format of time, which is expected to be in the format HH:MM:SS.
The error message returned is: "Expected string to match 'time' format".

The issue occurs consistently when providing values for startTime in the format HH:MM:SS.

const timePeriod = t.String({
  format: "time",
  description: "Time in HH:MM:SS format",
  examples: ["08:00:00", "12:00:00"],
});

export const getFilteredActivitiesSchema = t.Object({
  startTime: t.Optional(timePeriod),
  endTime: t.Optional(timePeriod),
  limit: t.Optional(t.Number({ minimum: 1, maximum: 50, default: 50 })),
  offset: t.Optional(t.Numeric({ default: 0 })),
});

new Elysia().get("/hi", ({ query }) => query, {
  query: getFilteredActivitiesSchema,
});

What is the expected behavior?

When providing a value for the startTime property in the query, it should be validated against the expected format of HH:MM:SS (24-hour time format). If the value matches this format, the validation should pass, and the query should be processed successfully.

What do you see instead?

{
  "type": "validation",
  "on": "query",
  "summary": "Property 'startTime' should be time",
  "property": "/startTime",
  "message": "Expected string to match 'time' format",
  "expected": {},
  "found": {
    "startTime": "10:30:00",
    "limit": 50,
    "offset": 0,
  },
  "errors": [
    {
      "type": 50,
      "schema": {
        "format": "time",
        "description": "Time in HH:MM:SS format",
        "examples": [
          "08:00:00",
          "12:00:00"
        ],
        "type": "string"
      },
      "path": "/startTime",
      "value": "10:30:00",
      "message": "Expected string to match 'time' format",
      "summary": "Property 'startTime' should be time"
    }
  ]
}

Additional information

No response

Have you try removing the node_modules and bun.lockb and try again yet?

no

@K4leri K4leri added the bug Something isn't working label Oct 26, 2024
@lteacher
Copy link

lteacher commented Oct 28, 2024

It looks to me like the code copies the logic from typebox, which takes the requirement from AJV that the time value must have a timezone. Obviously that doesn't align with ISO8601 though... I thought it would be fun to fix it but since that is done on purpose I dunno what the authors would like to do about that as fixing it involves dealing with the strictTimeZone argument as whilst true included for the time value the !tz check will fail.

I also wasn't convinced the regex was correct per the spec if this is supposed to match JSON schema since the regex does allow some exclusion of timezone minutes.

AJV Docs that says the timezone is required
https://ajv.js.org/packages/ajv-formats.html#formats

Codebase issue location (strictTimeZone is always true)
https://github.com/elysiajs/elysia/blob/main/src/formats.ts#L125

JSON Schema ref:
https://datatracker.ietf.org/doc/html/rfc3339#section-5.6

Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
bug Something isn't working
Projects
None yet
Development

No branches or pull requests

3 participants
@lteacher @K4leri and others