Skip to content

Latest commit

 

History

History
84 lines (56 loc) · 3.32 KB

README.md

File metadata and controls

84 lines (56 loc) · 3.32 KB

Instill AI Protobufs

This repository is a fork of instill-ai/protobufs that serves as a playground for developing a GitHub action that syncs the public API reference, hosted in ReadMe, with the Instill Core.

Current status

There are 3 public OpenAPI references (Core, Model and VDP), which version points to the latest Instill Core version (perhaps model should have a different release version.

Every time a new Instill Core release is published, a GitHub action creates a PR updating the version in the OpenAPI documents. Once this is merged, we have to manually re-sync the public documentation.

🎉 Changes were merged in instill-ai#270

Goals

  • Having a private version of the API references that we can keep in sync with the main branch in the protobufs repo in order to QA the documentation before syncing the public version.
  • Syncing the public version automatically when the version update PR is merged.

✅ Step 1: with a single public and private version

  • On main branch merge: update staging docs
  • On version PR merge: update production docs

ReadMe setup

2 versions per (major) Core release: public and private.

ReadMe versions

As we have 3 docs per version, we can either keep the IDs as variables in our workflow or obtain them from the ReadMe API.

✅ Step 2: one public version per release + a staging version for the next release.

  • On main branch merge: update staging docs
  • On version PR merge: create new (main, beta, public) version with staging one as base.

ReadMe setup

  • 1 public version per Core release.
  • 1 private version per major Core release.

ReadMe versions

We can keep the private API IDs constant, then create new main versions from them as releases occur.

✅ Step 2.1: back to single versions

ReadMe limits the number of versions a subscription plan can have, so adding a new version each release cycle does not scale. We'll go back to one public version and a private one. The name of the private version will point to the latest Core release and if we need to support several major versions we can have different endpoint collections (e.g. VDP v2) within the same version.

ReadMe setup

  • 1 public version e.g. v0.12.0-beta (version will point to Core release)
  • 1 staging version v0-beta-staging (we might change the name when Core is at 1.x.x but we shouldn't create a new version. The IDs of this version will be tied to the workflow).

ReadMe versions ReadMe versions

We'll keep the private API IDs constant, then create new main versions from them as releases occur.

⏭️ Additional feature: display diff on version update PR

  • On version PR merge: create tag with version
  • On Core GitHub action PR: generate link with diff.