GEDOPLAN
Webprogrammierung

OpenAPI- ein eigenes Model

Webprogrammierung
automobile 8078415 640 jpg

OpenAPI ist eine fantastische Möglichkeit, die eigenen Schnittstellen technisch zu beschreiben und Anwendungsteile zu generieren. Ein Generator ist allerdings immer nur so gut wie seine Anpassbarkeit. Ein einfaches Feature in diesem Bereich liefert OpenAPI mit seinen import-mappings.

In einem unserer Projekte ist die Grundlage aller unserer Request Objekte eine Basis-Klasse, die technische Information enthält. Diese Informationen sind verpflichtend und aus Sicht der Schnittstelle damit korrekterweise als „required“ markiert, was die Generierung in ein TypeScript-Model auch honoriert:

export interface BaseRequest {
    transactionId: string;
    clientSoftwareVersion: string;
}

export interface SearchRequest extends BaseRequestType{
    search: string;
}

Diese technischen Informationen werden nun jedoch nicht aus den fachlichen Komponenten oder Services gesetzt, sondern über einen HTTP Interceptor. Eine einfache fachliche Verwendung dieser Request-Objekte ist nun erst einmal ohne weiteres nicht mehr möglich, weil der Compiler die fehlenden technischen Informationen mit einem Fehler markiert:

let searchRequest: SearchRequest = {  // >> missing properties
    search: 'lorem ipsum'
}

Um jetzt unsere Typisierung nicht zu torpedieren („as any“), unsere Schnittstelle aufzuweichen („required“ entfernen) oder boilerplate zu schreiben (Platzhalter Objekte) erlaubt uns OpenAPI über eine entsprechende Konfiguration eigene Objekte in die generierten Models zu integrieren. In unserem Beispiel ist die Lösung denkbar einfach: Wir definieren die Attribute in unserem Fall als optional, da wir über den HTTP Interceptor sicherstellen, dass diese Attribute ohnehin gesetzt werden und ersetzen den generierten BasisTyp durch unseren eigenen:

<pre class="wp-block-syntaxhighlighter-code">export interface BaseRequest {
 transactionId?: string; <br /> clientSoftwareVersion?: string;
}</pre>
{
  "importMappings": {
    "BaseRequestType": "src/app/api/importMappings/baseRequestType"
  }
}

(openapi.config.json, beim Aufruf des OpenAPI generators mit zu geben)

Ende Gut. Alles Gut.

 

Schreibe einen Kommentar

Deine E-Mail-Adresse wird nicht veröffentlicht. Erforderliche Felder sind mit * markiert

Bitte füllen Sie dieses Feld aus.
Bitte füllen Sie dieses Feld aus.
Bitte gib eine gültige E-Mail-Adresse ein.
Sie müssen den Bedingungen zustimmen, um fortzufahren.

Autor

Diesen Artikel teilen

LinkedIn
Xing

Gibt es noch Fragen?

Fragen beantworten wir sehr gerne! Schreibe uns einfach per Kontaktformular.

Kurse

weitere Blogbeiträge

IT-Training - GEDOPLAN
Jakarta EE (Java EE)

Lifecycle-Events der CDI-Scopes

Beim Aktivieren und Deaktivieren von CDI-Scopes sendet der Container Events, die von der Anwendung bspw. zur Initialisierung genutzt werden können.…
needle 4854847 640 jpg
Spring

Spring Data REST

Klassischerweise gliedern wir REST basierte Anwendung unter anderem in 3 Teile: Controller (Definition der REST Schnittstelle), Service (Businesslogik und Konvertierungen)…
match 1899824 640
Jakarta EE (Java EE)

CDI 4.0: Events mit BeanManager feuern

CDI Events können mit Hilfe einer Event Source gefeuert werden, z. B. @Inject @Urgent Event<Message> urgentMessageEventSource; ... urgentMessageEventSource.fire(new Message(...)); Im…

Work Life Balance. Jobs bei Gedoplan

We are looking for you!

Lust bei GEDOPLAN mitzuarbeiten? Wir suchen immer Verstärkung – egal ob Entwickler, Dozent, Trainerberater oder für unser IT-Marketing! Schau doch einfach mal auf unsere Jobseiten! Wir freuen uns auf Dich!

Work Life Balance. Jobs bei Gedoplan

We are looking for you!

Lust bei GEDOPLAN mitzuarbeiten? Wir suchen immer Verstärkung – egal ob Entwickler, Dozent, Trainerberater oder für unser IT-Marketing! Schau doch einfach mal auf unsere Jobseiten! Wir freuen uns auf Dich!