-
Notifications
You must be signed in to change notification settings - Fork 137
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
Readonly modifier is being ignored #193
Comments
Sorry, but we focus on implementing standard specification. |
@luisfpg thanks for responding. Isn't readOnly standard since it is described in the openAPI sepcification doc? |
Sorry, I've misunderstood your question. |
No problem! I checked and I don't think typescript's Basically if something like this was generated: export interface TestSchema {
readonly id: number;
prop: string;
} typescript complier would throw an error when trying to do this: //apiTestPost(id: number, body: TestSchema): : Observable<TestSchema>
this.service.apiTestPost(id, {prop: 'test string'}) because id is not present in the body. TLDR; I think openAPI's The first one is to generate an analogous interface without readonly properties. The other is basically the same thing but using ts type checker by declaring: type KeysOfType<T, SelectedType> = {
[key in keyof T]: SelectedType extends T[key] ? key : never;
}[keyof T];
type Optional<T> = Partial<Pick<T, KeysOfType<T, undefined>>>;
type IfEquals<X, Y, A=X, B=never> =
(<T>() => T extends X ? 1 : 2) extends
(<T>() => T extends Y ? 1 : 2) ? A : B;
type WritableKeys<T> = {
[P in keyof T]: IfEquals<{ [Q in P]: T[P] }, { -readonly [Q in P]: T[P] }, P>
}[keyof T];
type WritableObject<T> = {
[K in WritableKeys<T>]: T[K]
};
type WriteableNoOptional<T> = Omit<WritableObject<T>, KeysOfType<T, undefined>>
// and then generating something like this:
export interface TestSchema {
readonly id: number;
prop: string;
}
export type WriteableTestSchema = WriteableNoOptional<TestSchema> & Optional<TestSchema>;
//apiTestPost(id: number, body: WriteableTestSchema ): : Observable<TestSchema> |
Any thoughts on this @luisfpg ? |
Generating 2 interfaces from a single input is out of question, because the way the generator is done. |
I don't understand the limitations of the generator and I won't debate you on that for sure. Since 2 interfaces are out of question the method I wrote above might work. You only generate one interface (with the type WriteableSchema<T> = WriteableNoOptional<T> & Optional<T>
//method
apiTestPost(id: number, body: WriteableSchema<TestSchema>) : Observable<TestSchema> I know it looks cumbersome for a low reward, and it might slow the ts compiler / linter a bit , and for that reason a flag could be added ( --experimental or something), but I think it works without compromising any part of the generator. |
I'm sorry, but I really have no time to work on the generator nowadays... |
No problem. I'll try to make a PR for it.
About this I'll take it into consideration. I'll probably use some flag, since I've seen that pattern before in the generator code. |
Hi, not sure if this is a bug, it's looking more like a feature request, but I wanted to know if I could use the readonly property modifier to generate different types for creation requests ( POST, PUT) and read requests (GET) using the same schema.
My use case is:
My schema has an id, and when creating the entity via post I don't want to provide an id. But also I don't want to duplicate every schema, or use extension just for this.
Could someone look into this? Should I dive into a possible PR?
The text was updated successfully, but these errors were encountered: