Produce front-end interface code for OpenAPI-based backend services with a single click. This tool is designed to generate TypeScript code for API clients and request methods from OpenAPI specifications. It can be used as a command line tool or as a Node.js module that is integrated into your build process. It supports both OpenAPI 2.0 and 3.0 specifications.
This tool is a wrapper of the swagger-typescript-api
Install as a global command:
$ npm install -g swagger-api-hub
Install as a project-wide dependency:
$ npm install -D swagger-api-hub
It reads the default configuration file ./swagger-api-hub.config.ts
, you can also specify a custom configuration file.
$ swagger-api-hub # read default config file
$ swagger-api-hub ./configs/custom-config.ts # specify a custom config file
The configuration file should export an array of ServiceConfig
objects. If you export only one object, it will generate the code directly without prompting.
The config file can be either local path or npm module path, and the file extension can be .ts
, .js
, .json
, or any other module types supported by Node.js.
The file should look like this:
swagger-api-hub.config.ts
import type { ServiceConfig } from 'swagger-api-hub';
const services: ServiceConfig[] = [
{
id: 'iam',
name: 'User Management Service',
url: 'https://api.example.com/iam/swagger/v3',
output: './src/api/iam',
},
{
id: 'asset',
name: 'Asset Management Service',
url: 'https://api.example.com/public-api/asset/swagger/v3',
apiBase: '/public-api',
output: './src/api/asset',
},
];
export default services;
The ServiceConfig
object has the following fields:
id
: [required] A unique identifier for the service.name
: A human-readable name for the service.url
: [required] The URL of the OpenAPI specification file. If you have a local file, you can useinput
instead ofurl
to specify the file path. Or you can even usespec
to provide the OpenAPI specification object directly. Either url, input, or spec is required.apiBase
: The base path of all API endpoints. The service may be hosted on a subpath of the main domain, e.g.,/public-api/iam/v3
, then the apiBase is/public-api
in this case. If the original api path from the OpenAPI specification is acceptable, you don't need this field.crossOrigin
: Whether to use the absolute api path when calling the service. This is useful when the service is hosted on a different domain and you need to set theAccess-Control-Allow-Origin
header. Default isfalse
.dataTypeMappings
: A map of some special data types to TypeScript types. Default is{ int64: 'BigInt', object: 'Record<string, any>' }
.output
: The output directory for the generated code. Default is./src/api/{id}
.httpClientFile
: Change the default path ofhttp-client.ts
file, so you can use your own http client. Default is./http-client
of each service directory.createApiInstance
: Whether to create an instance of each API class. The instance can only be created with an empty constructor, if you want to set different options for some api classes, you can set this tofalse
and create the instance manually. Default istrue
.
For more options, please refer to the swagger-typescript-api#options documentation.
import { generate, promptToGenerate } from 'swagger-api-hub';
import type { ServiceConfig } from 'swagger-api-hub';
import serviceConfigs from './swagger-api-hub.config';
// Usage1: generate multiple services with prompts
promptToGenerate(serviceConfigs);
// Usage2: generate a single service directly
generate(serviceConfigs[0]);