* Update scripts
* update the base dep in uv deps
* update nightly scripts
* Add uv creds for publish
* skip tests for now
* fix version
* only build the wheel
* try again
* add uv to python run
* [autofix.ci] apply automated fixes
* use uv cache
* more version fixe
* fixing versions
* fix base version
* Try no frozen?
* skip everything to try docker build
* tag
* frozen
* separate script for updating uv dep
* [autofix.ci] apply automated fixes
* hardcoded versions
* hardcoded versions
* add version to editable package
* build project before docker file runs
* try again
* fix uv patht o build
* don't know why this would mkae a difference
* debug statements
* debug statements
* debug statements
* change path to whl 🤷
* manually move the wheel...
* make dir
* try no sources
* add back tests
* refactor uv to action
* add uv action
* Update nightly build workflow to include uv lock files in version update commit
* Update lint-py workflow to use specific ref for setup-uv action
* Add checkout step to style-check-py GitHub Actions workflow
* Remove redundant GitHub ref syntax in lint-py.yml workflow
* Update lint-py.yml to use specific ref for setup-uv action
* Update action.yml: standardize quotes and remove redundant checkout step
* Add checkout step to GitHub Actions workflows for specific ref handling
- Introduced `actions/checkout@v4` step to multiple workflows to ensure code is checked out at a specific ref.
- Updated `.github/workflows/docker-build.yml`, `.github/workflows/release_nightly.yml`, `.github/workflows/lint-py.yml`, and `.github/workflows/style-check-py.yml` to include the new checkout step.
- Ensured credentials are persisted during the checkout process.
* Add checkout step to Python test workflow with specific ref
---------
Co-authored-by: autofix-ci[bot] <114827586+autofix-ci[bot]@users.noreply.github.com>
Co-authored-by: Gabriel Luiz Freitas Almeida <gabriel@langflow.org>
313 lines
13 KiB
YAML
313 lines
13 KiB
YAML
name: Docker Build and Push
|
|
on:
|
|
workflow_call:
|
|
inputs:
|
|
version:
|
|
required: false
|
|
type: string
|
|
release_type:
|
|
required: true
|
|
type: string
|
|
pre_release:
|
|
required: false
|
|
type: boolean
|
|
default: false
|
|
nightly_tag_main:
|
|
description: "Tag for the nightly main build"
|
|
required: false
|
|
type: string
|
|
default: ''
|
|
nightly_tag_base:
|
|
description: "Tag for the nightly base build"
|
|
required: false
|
|
type: string
|
|
default: ''
|
|
|
|
workflow_dispatch:
|
|
inputs:
|
|
version:
|
|
description: "Version to build"
|
|
required: false
|
|
type: string
|
|
release_type:
|
|
description: "Type of release"
|
|
required: true
|
|
type: string
|
|
pre_release:
|
|
description: "Pre-release"
|
|
required: false
|
|
type: boolean
|
|
default: false
|
|
nightly_tag_main:
|
|
description: "Tag for the nightly main build"
|
|
required: false
|
|
type: string
|
|
default: ''
|
|
nightly_tag_base:
|
|
description: "Tag for the nightly base build"
|
|
required: false
|
|
type: string
|
|
default: ''
|
|
|
|
env:
|
|
POETRY_VERSION: "1.8.2"
|
|
TEST_TAG: "langflowai/langflow:test"
|
|
|
|
jobs:
|
|
get-version:
|
|
name: Get Version
|
|
runs-on: ubuntu-latest
|
|
outputs:
|
|
version: ${{ steps.get-version-input.outputs.version || steps.get-version-base.outputs.version || steps.get-version-main.outputs.version }}
|
|
nightly-tag: ${{ steps.resolve-nightly-tag.outputs.nightly_tag }}
|
|
nightly-build: ${{ steps.resolve-nightly-tag.outputs.nightly_build }}
|
|
steps:
|
|
- name: Resolve nightly tag
|
|
id: resolve-nightly-tag
|
|
run: |
|
|
# Note - this is more complex than I'd like. For `main` builds, we just pass the `main` tag.
|
|
# For `base` builds, we pass both the `base` and `main` tags. This is because the `main` tag is the
|
|
# version we need to check out for the build, but the `base` tag is the version we need to build.
|
|
#
|
|
# So, you need to check for `base` existence before `main`.
|
|
|
|
if [[ "${{ inputs.nightly_tag_base }}" != '' ]]; then
|
|
if [[ "${{ inputs.release_type }}" != "base" ]]; then
|
|
echo "Release type is not 'base'. Exiting the workflow."
|
|
exit 1
|
|
fi
|
|
|
|
# Main tag must not be empty, otherwise we have no valid tag to check out.
|
|
if [[ "${{ inputs.nightly_tag_main }}" == '' ]]; then
|
|
echo "Nightly tag main is empty. Exiting the workflow."
|
|
exit 1
|
|
fi
|
|
|
|
echo "nightly_tag=${{ inputs.nightly_tag_base }}" >> $GITHUB_OUTPUT
|
|
echo "nightly_build=true" >> $GITHUB_OUTPUT
|
|
elif [[ "${{ inputs.nightly_tag_main }}" != '' ]]; then
|
|
if [[ "${{ inputs.release_type }}" != "main" ]]; then
|
|
echo "Release type is not 'main'. Exiting the workflow."
|
|
exit 1
|
|
fi
|
|
echo "nightly_tag=${{ inputs.nightly_tag_main }}" >> $GITHUB_OUTPUT
|
|
echo "nightly_build=true" >> $GITHUB_OUTPUT
|
|
else
|
|
echo "nightly_tag=" >> $GITHUB_OUTPUT
|
|
echo "nightly_build=false" >> $GITHUB_OUTPUT
|
|
fi
|
|
- name: Check out the code at a specific ref
|
|
uses: actions/checkout@v4
|
|
with:
|
|
ref: ${{ inputs.nightly_tag_main || github.ref }}
|
|
persist-credentials: true
|
|
- name: "Setup Environment"
|
|
uses: ./.github/actions/setup-uv
|
|
with:
|
|
ref: ${{ inputs.nightly_tag_main || github.ref }}
|
|
|
|
- name: Install the project
|
|
run: uv sync --dev
|
|
|
|
- name: Get Version from Input
|
|
if: ${{ inputs.version != '' }}
|
|
id: get-version-input
|
|
run: |
|
|
version=${{ inputs.version }}
|
|
echo version=$version
|
|
echo version=$version >> $GITHUB_OUTPUT
|
|
- name: Get Version Base
|
|
if: ${{ inputs.version == '' && inputs.release_type == 'base' }}
|
|
id: get-version-base
|
|
run: |
|
|
version=$(uv tree | grep 'langflow-base' | awk '{print $3}' | sed 's/^v//')
|
|
echo version=$version
|
|
echo version=$version >> $GITHUB_OUTPUT
|
|
- name: Get Version Main
|
|
if: ${{ inputs.version == '' && inputs.release_type == 'main' }}
|
|
id: get-version-main
|
|
run: |
|
|
version=$(uv tree | grep 'langflow' | grep -v 'langflow-base' | awk '{print $2}' | sed 's/^v//')
|
|
echo version=$version
|
|
echo version=$version >> $GITHUB_OUTPUT
|
|
setup:
|
|
runs-on: ubuntu-latest
|
|
needs: get-version
|
|
outputs:
|
|
docker_tags: ${{ steps.set-vars.outputs.docker_tags }}
|
|
ghcr_tags: ${{ steps.set-vars.outputs.ghcr_tags }}
|
|
file: ${{ steps.set-vars.outputs.file }}
|
|
steps:
|
|
- name: Check out the code at a specific ref
|
|
uses: actions/checkout@v4
|
|
with:
|
|
ref: ${{ inputs.nightly_tag_main || github.ref }}
|
|
|
|
- name: Set Dockerfile and Tags
|
|
id: set-vars
|
|
run: |
|
|
nightly_suffix=''
|
|
if [[ "${{ needs.get-version.outputs.nightly-build }}" == "true" ]]; then
|
|
nightly_suffix="-nightly"
|
|
fi
|
|
|
|
if [[ "${{ inputs.release_type }}" == "base" ]]; then
|
|
echo "docker_tags=langflowai/langflow${nightly_suffix}:base-${{ needs.get-version.outputs.version }},langflowai/langflow${nightly_suffix}:base-latest" >> $GITHUB_OUTPUT
|
|
echo "ghcr_tags=ghcr.io/langflow-ai/langflow${nightly_suffix}:base-${{ needs.get-version.outputs.version }},ghcr.io/langflow-ai/langflow${nightly_suffix}:base-latest" >> $GITHUB_OUTPUT
|
|
echo "file=./docker/build_and_push_base.Dockerfile" >> $GITHUB_OUTPUT
|
|
else
|
|
if [[ "${{ inputs.pre_release }}" == "true" ]]; then
|
|
echo "docker_tags=langflowai/langflow${nightly_suffix}:${{ needs.get-version.outputs.version }}" >> $GITHUB_OUTPUT
|
|
echo "ghcr_tags=ghcr.io/langflow-ai/langflow${nightly_suffix}:${{ needs.get-version.outputs.version }}" >> $GITHUB_OUTPUT
|
|
else
|
|
echo "docker_tags=langflowai/langflow${nightly_suffix}:${{ needs.get-version.outputs.version }},langflowai/langflow${nightly_suffix}:latest" >> $GITHUB_OUTPUT
|
|
echo "ghcr_tags=ghcr.io/langflow-ai/langflow${nightly_suffix}:${{ needs.get-version.outputs.version }},ghcr.io/langflow-ai/langflow${nightly_suffix}:latest" >> $GITHUB_OUTPUT
|
|
fi
|
|
echo "file=./docker/build_and_push.Dockerfile" >> $GITHUB_OUTPUT
|
|
fi
|
|
build:
|
|
runs-on: ubuntu-latest
|
|
needs: [get-version, setup]
|
|
steps:
|
|
- name: Check out the code at a specific ref
|
|
uses: actions/checkout@v4
|
|
with:
|
|
ref: ${{ inputs.ref }}
|
|
persist-credentials: true
|
|
- name: "Setup Environment"
|
|
uses: ./.github/actions/setup-uv
|
|
with:
|
|
ref: ${{ inputs.nightly_tag_main || github.ref }}
|
|
|
|
- name: Install the project
|
|
run: |
|
|
if [[ "${{ inputs.release_type }}" == "base" ]]; then
|
|
cd src/backend/base && uv sync --no-dev --no-sources
|
|
else
|
|
uv sync --no-dev --no-sources
|
|
fi
|
|
|
|
- name: Set up Docker Buildx
|
|
uses: docker/setup-buildx-action@v3
|
|
|
|
- name: Login to Docker Hub
|
|
uses: docker/login-action@v3
|
|
with:
|
|
username: ${{ secrets.DOCKERHUB_USERNAME }}
|
|
password: ${{ secrets.DOCKERHUB_TOKEN }}
|
|
- name: Build and Push to Docker Hub
|
|
uses: docker/build-push-action@v6
|
|
with:
|
|
context: .
|
|
push: true
|
|
file: ${{ needs.setup.outputs.file }}
|
|
tags: ${{ needs.setup.outputs.docker_tags }}
|
|
# provenance: false will result in a single manifest for all platforms which makes the image pullable from arm64 machines via the emulation (e.g. Apple Silicon machines)
|
|
provenance: false
|
|
|
|
- name: Login to Github Container Registry
|
|
uses: docker/login-action@v3
|
|
with:
|
|
registry: ghcr.io
|
|
username: ${{ github.actor }}
|
|
password: ${{ secrets.TEMP_GHCR_TOKEN}}
|
|
- name: Build and push to Github Container Registry
|
|
uses: docker/build-push-action@v6
|
|
with:
|
|
context: .
|
|
push: true
|
|
file: ${{ needs.setup.outputs.file }}
|
|
tags: ${{ needs.setup.outputs.ghcr_tags }}
|
|
# provenance: false will result in a single manifest for all platforms which makes the image pullable from arm64 machines via the emulation (e.g. Apple Silicon machines)
|
|
provenance: false
|
|
|
|
build_components:
|
|
if: ${{ inputs.release_type == 'main' }}
|
|
runs-on: ubuntu-latest
|
|
permissions:
|
|
packages: write
|
|
needs: [build, get-version]
|
|
strategy:
|
|
matrix:
|
|
component: [docker-backend, docker-frontend, ghcr-backend, ghcr-frontend]
|
|
include:
|
|
- component: docker-backend
|
|
dockerfile: ./docker/build_and_push_backend.Dockerfile
|
|
tags: ${{ inputs.pre_release == 'true' && format('langflowai/langflow-backend{0}:{1}', needs.get-version.outputs.nightly-build && '-nightly' || '', needs.get-version.outputs.version) || format('langflowai/langflow-backend{0}:{1},langflowai/langflow-backend{0}:latest', needs.get-version.outputs.nightly-build && '-nightly' || '', needs.get-version.outputs.version) }}
|
|
langflow_image: langflowai/langflow${{ needs.get-version.outputs.nightly-build && '-nightly' || '' }}:${{ needs.get-version.outputs.version }}
|
|
- component: docker-frontend
|
|
dockerfile: ./docker/frontend/build_and_push_frontend.Dockerfile
|
|
tags: ${{ inputs.pre_release == 'true' && format('langflowai/langflow-frontend{0}:{1}', needs.get-version.outputs.nightly-build && '-nightly' || '', needs.get-version.outputs.version) || format('langflowai/langflow-frontend{0}:{1},langflowai/langflow-frontend{0}:latest', needs.get-version.outputs.nightly-build && '-nightly' || '', needs.get-version.outputs.version) }}
|
|
langflow_image: langflowai/langflow${{ needs.get-version.outputs.nightly-build && '-nightly' || '' }}:${{ needs.get-version.outputs.version }}
|
|
- component: ghcr-backend
|
|
dockerfile: ./docker/build_and_push_backend.Dockerfile
|
|
tags: ${{ format('ghcr.io/langflow-ai/langflow-backend{0}:{1},ghcr.io/langflow-ai/langflow-backend{0}:latest', needs.get-version.outputs.nightly-build && '-nightly' || '', needs.get-version.outputs.version) }}
|
|
langflow_image: ghcr.io/langflow-ai/langflow${{ needs.get-version.outputs.nightly-build && '-nightly' || '' }}:${{ needs.get-version.outputs.version }}
|
|
- component: ghcr-frontend
|
|
dockerfile: ./docker/frontend/build_and_push_frontend.Dockerfile
|
|
tags: ${{ format('ghcr.io/langflow-ai/langflow-frontend{0}:{1},ghcr.io/langflow-ai/langflow-frontend{0}:latest', needs.get-version.outputs.nightly-build && '-nightly' || '', needs.get-version.outputs.version) }}
|
|
langflow_image: ghcr.io/langflow-ai/langflow${{ needs.get-version.outputs.nightly-build && '-nightly' || '' }}:${{ needs.get-version.outputs.version }}
|
|
steps:
|
|
- name: Check out the code at a specific ref
|
|
uses: actions/checkout@v4
|
|
with:
|
|
ref: ${{ inputs.nightly_tag_main || github.ref }}
|
|
|
|
- name: Set up Docker Buildx
|
|
uses: docker/setup-buildx-action@v3
|
|
|
|
- name: Login to Docker Hub
|
|
if: ${{ matrix.component == 'docker-backend' }} || ${{ matrix.component == 'docker-frontend' }}
|
|
uses: docker/login-action@v3
|
|
with:
|
|
username: ${{ secrets.DOCKERHUB_USERNAME }}
|
|
password: ${{ secrets.DOCKERHUB_TOKEN }}
|
|
|
|
- name: Login to Github Container Registry
|
|
if: ${{ matrix.component == 'ghcr-backend' }} || ${{ matrix.component == 'ghcr-frontend' }}
|
|
uses: docker/login-action@v3
|
|
with:
|
|
registry: ghcr.io
|
|
username: ${{ github.actor }}
|
|
password: ${{ secrets.TEMP_GHCR_TOKEN}}
|
|
|
|
- name: Wait for propagation (for backend)
|
|
run: sleep 120
|
|
|
|
- name: Build and push ${{ matrix.component }}
|
|
uses: docker/build-push-action@v6
|
|
with:
|
|
context: .
|
|
push: true
|
|
build-args: |
|
|
LANGFLOW_IMAGE=${{ matrix.langflow_image }}
|
|
file: ${{ matrix.dockerfile }}
|
|
tags: ${{ matrix.tags }}
|
|
# provenance: false will result in a single manifest for all platforms which makes the image pullable from arm64 machines via the emulation (e.g. Apple Silicon machines)
|
|
provenance: false
|
|
|
|
restart-space:
|
|
name: Restart HuggingFace Spaces
|
|
if: ${{ inputs.release_type == 'main' && inputs.nightly_build == 'false' }}
|
|
runs-on: ubuntu-latest
|
|
needs: build
|
|
strategy:
|
|
matrix:
|
|
python-version:
|
|
- "3.12"
|
|
steps:
|
|
- uses: actions/checkout@v4
|
|
- name: Set up Python ${{ matrix.python-version }} + Poetry ${{ env.POETRY_VERSION }}
|
|
uses: "./.github/actions/poetry_caching"
|
|
with:
|
|
python-version: ${{ matrix.python-version }}
|
|
poetry-version: ${{ env.POETRY_VERSION }}
|
|
cache-key: ${{ runner.os }}-poetry-${{ env.POETRY_VERSION }}-${{ hashFiles('**/poetry.lock') }}
|
|
- name: Install Python dependencies
|
|
run: |
|
|
poetry env use ${{ matrix.python-version }}
|
|
poetry install
|
|
|
|
- name: Restart HuggingFace Spaces Build
|
|
run: |
|
|
poetry run python ./scripts/factory_restart_space.py --space "Langflow/Langflow" --token ${{ secrets.HUGGINGFACE_API_TOKEN }}
|