-
Notifications
You must be signed in to change notification settings - Fork 15.9k
Commit
This commit does not belong to any branch on this repository, and may belong to a fork outside of the repository.
infra: build api docs from package listing (#27774)
- Loading branch information
Showing
4 changed files
with
272 additions
and
126 deletions.
There are no files selected for viewing
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,81 @@ | ||
#!/usr/bin/env python | ||
"""Script to sync libraries from various repositories into the main langchain repository.""" | ||
|
||
import os | ||
import shutil | ||
import yaml | ||
from pathlib import Path | ||
from typing import Dict, Any | ||
|
||
|
||
def load_packages_yaml() -> Dict[str, Any]: | ||
"""Load and parse the packages.yml file.""" | ||
with open("langchain/libs/packages.yml", "r") as f: | ||
return yaml.safe_load(f) | ||
|
||
|
||
def clean_target_directories(packages: Dict[str, Any]) -> None: | ||
"""Remove old directories that will be replaced.""" | ||
base_path = Path("langchain/libs/partners") | ||
for package in packages["packages"]: | ||
if package["repo"] != "langchain-ai/langchain": | ||
package_name = package["name"].replace("langchain-", "") | ||
target_dir = base_path / package_name | ||
if target_dir.exists(): | ||
print(f"Removing {target_dir}") | ||
shutil.rmtree(target_dir) | ||
|
||
|
||
def move_libraries(packages: Dict[str, Any]) -> None: | ||
"""Move libraries from their source locations to the target directories.""" | ||
for package in packages["packages"]: | ||
# Skip if it's the main langchain repo or disabled | ||
if package["repo"] == "langchain-ai/langchain" or package.get( | ||
"disabled", False | ||
): | ||
continue | ||
|
||
repo_name = package["repo"].split("/")[1] | ||
package_name = package["name"].replace("langchain-", "") | ||
source_path = package["path"] | ||
target_dir = f"langchain/libs/partners/{package_name}" | ||
|
||
# Handle root path case | ||
if source_path == ".": | ||
source_dir = repo_name | ||
else: | ||
source_dir = f"{repo_name}/{source_path}" | ||
|
||
print(f"Moving {source_dir} to {target_dir}") | ||
|
||
# Ensure target directory exists | ||
os.makedirs(os.path.dirname(target_dir), exist_ok=True) | ||
|
||
try: | ||
# Move the directory | ||
shutil.move(source_dir, target_dir) | ||
except Exception as e: | ||
print(f"Error moving {source_dir} to {target_dir}: {e}") | ||
|
||
|
||
def main(): | ||
"""Main function to orchestrate the library sync process.""" | ||
try: | ||
# Load packages configuration | ||
packages = load_packages_yaml() | ||
|
||
# Clean target directories | ||
clean_target_directories(packages) | ||
|
||
# Move libraries to their new locations | ||
move_libraries(packages) | ||
|
||
print("Library sync completed successfully!") | ||
|
||
except Exception as e: | ||
print(f"Error during library sync: {e}") | ||
raise | ||
|
||
|
||
if __name__ == "__main__": | ||
main() |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
|
@@ -22,133 +22,27 @@ jobs: | |
repository: langchain-ai/langchain-api-docs-html | ||
path: langchain-api-docs-html | ||
token: ${{ secrets.TOKEN_GITHUB_API_DOCS_HTML }} | ||
- uses: actions/checkout@v4 | ||
with: | ||
repository: langchain-ai/langchain-google | ||
path: langchain-google | ||
- uses: actions/checkout@v4 | ||
with: | ||
repository: langchain-ai/langchain-datastax | ||
path: langchain-datastax | ||
- uses: actions/checkout@v4 | ||
with: | ||
repository: langchain-ai/langchain-nvidia | ||
path: langchain-nvidia | ||
- uses: actions/checkout@v4 | ||
with: | ||
repository: langchain-ai/langchain-cohere | ||
path: langchain-cohere | ||
- uses: actions/checkout@v4 | ||
with: | ||
repository: langchain-ai/langchain-elastic | ||
path: langchain-elastic | ||
- uses: actions/checkout@v4 | ||
with: | ||
repository: langchain-ai/langchain-postgres | ||
path: langchain-postgres | ||
- uses: actions/checkout@v4 | ||
with: | ||
repository: langchain-ai/langchain-aws | ||
path: langchain-aws | ||
- uses: actions/checkout@v4 | ||
with: | ||
repository: langchain-ai/langchain-weaviate | ||
path: langchain-weaviate | ||
- uses: actions/checkout@v4 | ||
with: | ||
repository: langchain-ai/langchain-ai21 | ||
path: langchain-ai21 | ||
- uses: actions/checkout@v4 | ||
with: | ||
repository: langchain-ai/langchain-together | ||
path: langchain-together | ||
- uses: actions/checkout@v4 | ||
with: | ||
repository: langchain-ai/langchain-experimental | ||
path: langchain-experimental | ||
- uses: actions/checkout@v4 | ||
with: | ||
repository: langchain-ai/langchain-milvus | ||
path: langchain-milvus | ||
- uses: actions/checkout@v4 | ||
with: | ||
repository: langchain-ai/langchain-unstructured | ||
path: langchain-unstructured | ||
- uses: actions/checkout@v4 | ||
with: | ||
repository: langchain-ai/langchain-databricks | ||
path: langchain-databricks | ||
- uses: actions/checkout@v4 | ||
with: | ||
repository: langchain-ai/langchain-ibm | ||
path: langchain-ibm | ||
- uses: actions/checkout@v4 | ||
with: | ||
repository: langchain-ai/langchain-azure | ||
path: langchain-azure | ||
- uses: actions/checkout@v4 | ||
with: | ||
repository: langchain-ai/langchain-mongodb | ||
path: langchain-mongodb | ||
- uses: actions/checkout@v4 | ||
with: | ||
repository: langchain-ai/langchain-redis | ||
path: langchain-redis | ||
|
||
|
||
- name: Install yq | ||
run: | | ||
sudo wget -qO /usr/local/bin/yq https://github.com/mikefarah/yq/releases/latest/download/yq_linux_amd64 | ||
sudo chmod a+x /usr/local/bin/yq | ||
- name: Set Git config | ||
working-directory: langchain | ||
- name: Parse YAML and checkout repos | ||
run: | | ||
git config --local user.email "[email protected]" | ||
git config --local user.name "Github Actions" | ||
# Get unique repositories | ||
REPOS=$(yq '.packages[].repo' langchain/libs/packages.yml | sort -u) | ||
- name: Move libs | ||
run: | | ||
rm -rf \ | ||
langchain/libs/partners/google-genai \ | ||
langchain/libs/partners/google-vertexai \ | ||
langchain/libs/partners/astradb \ | ||
langchain/libs/partners/nvidia-trt \ | ||
langchain/libs/partners/nvidia-ai-endpoints \ | ||
langchain/libs/partners/cohere \ | ||
langchain/libs/partners/elasticsearch \ | ||
langchain/libs/partners/upstage \ | ||
langchain/libs/partners/ai21 \ | ||
langchain/libs/partners/together \ | ||
langchain/libs/standard-tests \ | ||
langchain/libs/experimental \ | ||
langchain/libs/partners/milvus \ | ||
langchain/libs/partners/unstructured \ | ||
langchain/libs/partners/databricks \ | ||
langchain/libs/partners/ibm \ | ||
langchain/libs/partners/azure-dynamic-sessions \ | ||
langchain/libs/partners/mongodb \ | ||
langchain/libs/partners/redis | ||
mv langchain-google/libs/genai langchain/libs/partners/google-genai | ||
mv langchain-google/libs/vertexai langchain/libs/partners/google-vertexai | ||
mv langchain-google/libs/community langchain/libs/partners/google-community | ||
mv langchain-datastax/libs/astradb langchain/libs/partners/astradb | ||
mv langchain-nvidia/libs/ai-endpoints langchain/libs/partners/nvidia-ai-endpoints | ||
mv langchain-cohere/libs/cohere langchain/libs/partners/cohere | ||
mv langchain-elastic/libs/elasticsearch langchain/libs/partners/elasticsearch | ||
mv langchain-postgres langchain/libs/partners/postgres | ||
mv langchain-aws/libs/aws langchain/libs/partners/aws | ||
mv langchain-weaviate/libs/weaviate langchain/libs/partners/weaviate | ||
mv langchain-ai21/libs/ai21 langchain/libs/partners/ai21 | ||
mv langchain-together/libs/together langchain/libs/partners/together | ||
mv langchain-experimental/libs/experimental langchain/libs/experimental | ||
mv langchain-milvus/libs/milvus langchain/libs/partners/milvus | ||
mv langchain-unstructured/libs/unstructured langchain/libs/partners/unstructured | ||
mv langchain-databricks/libs/databricks langchain/libs/partners/databricks | ||
mv langchain-ibm/libs/ibm langchain/libs/partners/ibm | ||
mv langchain-azure/libs/azure-dynamic-sessions langchain/libs/partners/azure-dynamic-sessions | ||
mv langchain-mongodb/libs/mongodb langchain/libs/partners/mongodb | ||
mv langchain-redis/libs/redis langchain/libs/partners/redis | ||
- name: Rm old html | ||
run: | ||
rm -rf langchain-api-docs-html/api_reference_build/html | ||
# Checkout each unique repository | ||
for repo in $REPOS; do | ||
if [ "$repo" != "langchain-ai/langchain" ]; then | ||
REPO_NAME=$(echo $repo | cut -d'/' -f2) | ||
echo "Checking out $repo to $REPO_NAME" | ||
git clone --depth 1 https://github.com/$repo.git $REPO_NAME | ||
fi | ||
done | ||
env: | ||
GITHUB_TOKEN: ${{ secrets.GITHUB_TOKEN }} | ||
|
||
- name: Set up Python ${{ env.PYTHON_VERSION }} + Poetry ${{ env.POETRY_VERSION }} | ||
uses: "./langchain/.github/actions/poetry_setup" | ||
|
@@ -158,16 +52,36 @@ jobs: | |
cache-key: api-docs | ||
working-directory: langchain | ||
|
||
- name: Install dependencies | ||
- name: Install initial py deps | ||
working-directory: langchain | ||
run: | | ||
python -m pip install -U uv | ||
python -m uv pip install --upgrade --no-cache-dir pip setuptools | ||
python -m uv pip install --upgrade --no-cache-dir pip setuptools pyyaml | ||
- name: Move libs with script | ||
run: python langchain/.github/scripts/prep_api_docs_build.py | ||
env: | ||
GITHUB_TOKEN: ${{ secrets.GITHUB_TOKEN }} | ||
|
||
- name: Rm old html | ||
run: | ||
rm -rf langchain-api-docs-html/api_reference_build/html | ||
|
||
- name: Install dependencies | ||
working-directory: langchain | ||
run: | | ||
# skip airbyte due to pandas dependency issue | ||
python -m uv pip install $(ls ./libs/partners | grep -vE "airbyte" | xargs -I {} echo "./libs/partners/{}") | ||
python -m uv pip install libs/core libs/langchain libs/text-splitters libs/community libs/experimental | ||
python -m uv pip install -r docs/api_reference/requirements.txt | ||
- name: Set Git config | ||
working-directory: langchain | ||
run: | | ||
git config --local user.email "[email protected]" | ||
git config --local user.name "Github Actions" | ||
- name: Build docs | ||
working-directory: langchain | ||
run: | | ||
|
@@ -182,4 +96,4 @@ jobs: | |
- uses: EndBug/add-and-commit@v9 | ||
with: | ||
cwd: langchain-api-docs-html | ||
message: 'Update API docs build' | ||
message: 'Update API docs build' |
Oops, something went wrong.