This library is an openapi-fetch clone that uses Angular's HTTPClient API. Thanks, @drwpow!
Caution
This library is still in development. Please report any issues you encounter.
Caution
Currently only supports JSON requests and responses.
In order to get started, generate a specification file using openapi-typescript.
# Local schema...
npx openapi-typescript ./path/to/my/schema.yaml -o ./path/to/my/schem # npm
yarn dlx openapi-typescript ./path/to/my/schema.d.ts -o ./path/to/my/schema.ts # or yarn
pnpm dlx openapi-typescript ./path/to/my/schema.d.ts -o ./path/to/my/schema.ts # or pnpm
# 🚀 ./path/to/my/schema.yaml -> ./path/to/my/schema.d.ts [7ms]
# Remote schema...
npx openapi-typescript https://example.com/schema.yaml -o ./path/to/my/schema # npm
yarn dlx openapi-typescript https://example.com/schema.d.ts -o ./path/to/my/schema.ts # or yarn
pnpm dlx openapi-typescript https://example.com/schema.d.ts -o ./path/to/my/schema.ts # or pnpm
# 🚀 https://example.com/schema.yaml -> ./path/to/my/schema.d.ts [7ms]
Then, utilize the generated specification file to make requests. In order to do this, create a service like so:
@Injectable({
providedIn: "root",
})
export class TestAPIService extends OpenAPIClientService<paths> {
constructor(httpClient: HttpClient) {
super(httpClient, {
baseUrl: "/api",
// ... options
});
}
}
Now, you can use the service to make requests that match the specification:
constructor(private api: TestAPIService) {}
const { data, error /*, response*/ } = await this.api.get("/path/to/endpoint");
For more information, see the openapi-fetch documentation.
Big thanks to @drwpow for creating the original openapi-fetch and openapi-typescript library!