InvokeAI/invokeai/frontend/web/docs/API_CLIENT.md
2023-04-06 00:29:56 +10:00

2.8 KiB

Generated axios API client

This API client is generated by an openapi code generator.

All files in invokeai/frontend/web/src/services/api/ are made by the generator.

Generation

The axios client may be generated by from the OpenAPI schema from the nodes web server, or from JSON.

Generate the API client from the nodes web server

We need to start the nodes web server, which serves the OpenAPI schema to the generator.

  1. Start the nodes web server.
# from the repo root
python scripts/invoke-new.py --web
  1. Generate the API client.
# from invokeai/frontend/web/
yarn api:web

Generate the API client from JSON

The JSON can be acquired from the nodes web server, or with a python script.

Getting the JSON from the nodes web server

Start the nodes web server as described above, then download the file.

# from invokeai/frontend/web/
curl http://localhost:9090/openapi.json -o openapi.json

Getting the JSON with a python script

Run this python script from the repo root, so it can access the nodes server modules.

The script will output openapi.json in the repo root. Then we need to move it to invokeai/frontend/web/.

# from the repo root
python invokeai/app/util/generate_openapi_json.py
mv invokeai/app/util/openapi.json invokeai/frontend/web/services/fixtures/

Generate the API client

Now we can generate the API client from the JSON.

# from invokeai/frontend/web/
yarn api:file

The generated client

The client will be written to invokeai/frontend/web/services/api/:

  • axios client
  • TS types
  • An easily parseable schema, which we can use to generate UI

API client customisation

The generator has a default request.ts file that implements a base axios client. The generated client uses this base client.

One shortcoming of this is base client is it does not provide response headers unless the response body is empty. To fix this, we provide our own lightly-patched request.ts.

To access the headers, call getHeaders(response) on any response from the generated api client. This function is exported from invokeai/frontend/web/src/services/util/getHeaders.ts.