Skip to content

Commit

Permalink
create github workflow that clones code-interpreter api ref to merge …
Browse files Browse the repository at this point in the history
…it with web app ref
  • Loading branch information
0div committed Nov 25, 2024
1 parent 4ab9cdb commit 4d2880a
Showing 1 changed file with 121 additions and 0 deletions.
121 changes: 121 additions & 0 deletions .github/workflows/generate_api_ref.yml
Original file line number Diff line number Diff line change
@@ -0,0 +1,121 @@
name: Generate SDK API references

on:
workflow_dispatch:
push:
branches:
- improved-api-refs
# - main

concurrency: ${{ github.workflow }}-${{ github.ref }}

permissions:
contents: write

jobs:
is_new_api_ref:
name: Is new API reference?
runs-on: ubuntu-latest
outputs:
new_api_ref: ${{ steps.sdk-changes.outputs.new_api_ref }}
steps:
- name: Checkout Repo
uses: actions/checkout@v3
with:
fetch-depth: 2

- name: Check if SDK changes
id: sdk-changes
run: |
IS_NEW_API_REF=$(./.github/scripts/is_new_api_ref.sh)
echo "new_api_ref=$IS_NEW_API_REF" >> "$GITHUB_OUTPUT"
sdk-changes:
name: SDK changes
needs: [is_new_api_ref]
if: always()
runs-on: ubuntu-latest
steps:
- name: Checkout repository
uses: actions/checkout@v3
with:
fetch-depth: 0

- name: Install pnpm
uses: pnpm/action-setup@v3
id: pnpm-install
with:
version: 9.5

- name: Setup Node
uses: actions/setup-node@v3
with:
node-version: "20.x"
registry-url: "https://registry.npmjs.org"
cache: pnpm
cache-dependency-path: pnpm-lock.yaml

- name: Configure pnpm
run: |
pnpm config set auto-install-peers true
pnpm config set exclude-links-from-lockfile true
- name: Install dependencies
run: pnpm install --frozen-lockfile

- name: Set up Python
id: setup-python
uses: actions/setup-python@v5
with:
python-version: "3.8"

- name: Install and configure Poetry
uses: snok/install-poetry@v1
with:
version: 1.5.1
virtualenvs-create: true
virtualenvs-in-project: true
installer-parallel: true

- name: Install dependencies
working-directory: ./packages/python-sdk
run: poetry install --no-interaction --no-root

- name: Generate Python SDK API reference
id: python-sdk-api-ref
working-directory: ./packages/python-sdk
run: |
source .venv/bin/activate
./scripts/generate_api_ref.sh
- name: Generate JS SDK API reference
id: js-sdk-api-ref
working-directory: packages/js-sdk
run: ./scripts/generate_api_ref.sh

- name: Generate CLI API reference
id: cli-api-ref
working-directory: packages/cli
run: ./scripts/generate_api_ref.sh

- name: Show docs file structure
run: tree apps/web/src/app/\(docs\)/docs/api-reference

- name: Clone code-interpreter API reference
run: |
git clone --depth 1 --filter=blob:none --sparse https://github.com/e2b-dev/code-interpreter -b generate-api-reference-for-code-interpreter-sdk-e2b-1235
cd code-interpreter
git sparse-checkout set api-reference
cp -r api-reference/* ../apps/web/src/app/\(docs\)/docs/api-reference/
cd ..
rm -rf code-interpreter
- name: Commit new SDK API reference versions
env:
GITHUB_TOKEN: ${{ secrets.GITHUB_TOKEN }}
run: |
git config user.name "github-actions[bot]"
git config user.email "github-actions[bot]@users.noreply.github.com"
git add apps/web/src/app/\(docs\)/docs/api-reference
git commit -m "[skip ci] Release new SDK API reference doc versions" || exit 0
git push

0 comments on commit 4d2880a

Please sign in to comment.