Comments (6)
@SzHeJason Hi, this might be an issue with fast-json-stringify
(the JSON serializer Fastify uses). As a quick test, can you try the following.
//-------------------------------------------
// replace this
//-------------------------------------------
export const responseSchema = Type.Object({
code: Type.Number(),
subcode: Type.Number(),
message: Type.String(),
data: Type.Dict(Type.Any()) ,
})
//-------------------------------------------
// ... with (raw JSONSchema from TypeBox)
//-------------------------------------------
export const responseSchema = {
type: 'object',
properties: {
code: { type: 'number' },
subcode: { type: 'number' },
message: { type: 'string' },
data: { type: 'object', additionalProperties: {} } // possible 'any' issue here.
},
required: [ 'code', 'subcode', 'message', 'data' ]
}
Give this a try and see if the problem still exists. Note you can also print this schema with console.log(Type.Strict(responseSchema))
.
I've actually submitted a few PR's to fast-json-stringify
to resolve a couple of issues with any
type schemas. It's possible the empty schema on additionalProperties: {}
may have been overlooked. If so, you can submit the raw JSONSchema as an issue on fast-json-stringify
and link back to this issue.
Let me know how you go
S
from typebox.
Get same error after replace.
But change additionalProperties
to true
is working
const Controller: FastifyPluginCallback = (server, options, next) => {
server.post(
'/:moduleName/:action',
{
schema: {
body: bodySchema,
params: paramsSchema,
response: {
'2xx': {
type: 'object',
properties: {
code: { type: 'number' },
subcode: { type: 'number' },
message: { type: 'string' },
data: { type: 'object', additionalProperties: true }, // possible 'any' issue here.
},
required: ['code', 'subcode', 'message', 'data'],
},
},
},
},
async (request, reply) => {
reply.send({
code: 0,
subcode: 0,
message: 'ok',
data: {
a: '123',
},
})
}
)
next()
}
from typebox.
@SzHeJason Looks like an issue with {}
schemas in fast-json-stringify
when applied to additionalProperties
. Would you be able to create an issue on that repository and link back to this issue?
For reference, there is information about the objects applied to additionalProperties
noted here. Specifically the section that reads.
If additionalProperties is an object, that object is a schema that will be used to validate
any additional properties not listed in properties.
For example, one can allow additional properties, but only if they are each a string:
{
"type": "object",
"properties": {
"number": { "type": "number" },
"street_name": { "type": "string" },
"street_type": { "type": "string",
"enum": ["Street", "Avenue", "Boulevard"]
}
},
"additionalProperties": { "type": "string" }
}
So essentially if additionalProperties
is an object
then that object schema is used to validate any unknown properties found on the object. The expectation here is that {}
should allow any property to be assigned to the object (satisfying the Type.Dict(..)
schema type). This is most likely an oversight.
from typebox.
@SzHeJason Have submitted a PR that should resolve this issue. Will need to wait on the fast-json-stringify
maintainers to give the green light however. Will close off this issue once things go through.
from typebox.
@SzHeJason This should be all resolved. Ensure to pull the latest dependency of fast-json-stringify
to get the latest updates. Will close off this issue.
Cheers
S
from typebox.
Awesome , Thank you
from typebox.
Related Issues (20)
- JsonTypeBuilder#Record not passing on options HOT 1
- No implicit defaults on Value.Create() HOT 5
- [BUG] Value.create caches the default date HOT 1
- Feature request: Value.Assert and TypeCheck.Assert HOT 3
- [Feature Request?] allow more flexible input for string pattern HOT 3
- Individual types imports naming conflict with native classes HOT 4
- Strict error: Unknown type HOT 2
- Maximum call stack size exceeded. HOT 2
- TUnion of literals from const array HOT 2
- "Value.Clean" doesn't work with Unions of objects with prohibited additionalProperties HOT 3
- JS floating point precision bug causes multipleOf validation to fail HOT 4
- Tuple with rest items (or Array with prefixedItems) HOT 2
- useDefaults HOT 3
- Support for discriminator HOT 1
- Support for self-referencing fields of recursive type HOT 2
- Property '[Kind]' is missing in type 'TObject' but required in type 'TObject<TProperties>' HOT 3
- [feat] Bail / Early Cancel Mode HOT 1
- Setting Description HOT 1
- Schema dependency using Typebox HOT 3
- Composite working uncorrect HOT 5
Recommend Projects
-
React
A declarative, efficient, and flexible JavaScript library for building user interfaces.
-
Vue.js
🖖 Vue.js is a progressive, incrementally-adoptable JavaScript framework for building UI on the web.
-
Typescript
TypeScript is a superset of JavaScript that compiles to clean JavaScript output.
-
TensorFlow
An Open Source Machine Learning Framework for Everyone
-
Django
The Web framework for perfectionists with deadlines.
-
Laravel
A PHP framework for web artisans
-
D3
Bring data to life with SVG, Canvas and HTML. 📊📈🎉
-
Recommend Topics
-
javascript
JavaScript (JS) is a lightweight interpreted programming language with first-class functions.
-
web
Some thing interesting about web. New door for the world.
-
server
A server is a program made to process requests and deliver data to clients.
-
Machine learning
Machine learning is a way of modeling and interpreting data that allows a piece of software to respond intelligently.
-
Visualization
Some thing interesting about visualization, use data art
-
Game
Some thing interesting about game, make everyone happy.
Recommend Org
-
Facebook
We are working to build community through open source technology. NB: members must have two-factor auth.
-
Microsoft
Open source projects and samples from Microsoft.
-
Google
Google ❤️ Open Source for everyone.
-
Alibaba
Alibaba Open Source for everyone
-
D3
Data-Driven Documents codes.
-
Tencent
China tencent open source team.
from typebox.