|
|
||
|---|---|---|
| .. | ||
| hack | ||
| v1beta1 | ||
| v2beta1 | ||
| .gitignore | ||
| Dockerfile | ||
| Makefile | ||
| README.md | ||
| build_kfp_server_api_python_package.sh | ||
README.md
Kubeflow Pipelines backend API
Before you begin
Tools needed:
Set the environment variable API_VERSION to the version that you want to generate. We use v1beta1 as example here.
export API_VERSION="v1beta1"
Compiling .proto files to Go client and swagger definitions
Use make generate command to generate clients using a pre-built api-generator image:
make generate
Go client library will be placed into:
./${API_VERSION}/go_client./${API_VERSION}/go_http_client./${API_VERSION}/swagger
Note
./${API_VERSION}/swagger/pipeline.upload.swagger.jsonis manually created, while the rest of./${API_VERSION}/swagger/*.swagger.jsonare compiled from./${API_VERSION}/*.protofiles.
Compiling Python client
To generate the Python client, run the following bash script (requires java and python3).
./build_kfp_server_api_python_package.sh
Python client will be placed into ./${API_VERSION}/python_http_client.
Updating of API reference documentation
Note Whenever the API definition changes (i.e., the file
kfp_api_single_file.swagger.jsonchanges), the API reference documentation needs to be updated.
API definitions in this folder are used to generate v1beta1 and v2beta1 API reference documentation on kubeflow.org. Follow the steps below to update the documentation:
-
Install bootprint-openapi and html-inline packages using
npm:npm install -g bootprint npm install -g bootprint-openapi npm -g install html-inline -
Generate self-contained html file(s) with API reference documentation from
./${API_VERSION}/swagger/kfp_api_single_file.swagger.json:Fov
v1beta1:bootprint openapi ./v1beta1/swagger/kfp_api_single_file.swagger.json ./temp/v1 html-inline ./temp/v1/index.html > ./temp/v1/kubeflow-pipeline-api-spec.htmlFor
v2beta1:bootprint openapi ./v2beta1/swagger/kfp_api_single_file.swagger.json ./temp/v2 html-inline ./temp/v2/index.html > ./temp/v2/kubeflow-pipeline-api-spec.html -
Use the above generated html file(s) to replace the relevant section(s) on kubeflow.org. When copying th content, make sure to preserve the original headers.
v1beta1: file kubeflow-pipeline-api-spec.html.v2beta1: file kubeflow-pipeline-api-spec.html.
-
Create a PR with the changes in kubeflow.org website repository. See an example here.
Updating API generator image
API generator image is defined in Dockerfile. If you need to update the container, follow these steps:
- Update the Dockerfile and build the image by running
docker build -t gcr.io/ml-pipeline-test/api-generator:latest . - Push the new container by running
docker push gcr.io/ml-pipeline-test/api-generator:latest(requires to be authenticated). - Update the
PREBUILT_REMOTE_IMAGEvariable in the Makefile to point to your new image. - Similarly, push a new version of the release tools image to
gcr.io/ml-pipeline-test/release:latestand runmake pushin test/release/Makefile.