CI/CD Integration
I-automate ang mga translations sa inyong build pipeline.
GitHub Actions: Sync on Push
Idagdag ang translation sync sa inyong existing na build pipeline:
.github/workflows/deploy.yml
jobs:
build:
steps:
- uses: actions/checkout@v4
- run: npm ci
- name: Sync translations
env:
OPENROUTER_API_KEY: ${{ secrets.OPENROUTER_API_KEY }}
run: npx i18n-rosetta sync
- run: npm run build
GitHub Actions: Scheduled Sync
I-run ang mga translations on a schedule at mag-auto-commit:
.github/workflows/i18n-sync.yml
name: Sync translations
on:
schedule:
- cron: '0 6 * * *'
workflow_dispatch:
jobs:
sync:
runs-on: ubuntu-latest
steps:
- uses: actions/checkout@v4
- uses: actions/setup-node@v4
with:
node-version: 20
- run: npm ci
- name: Sync translations
env:
OPENROUTER_API_KEY: ${{ secrets.OPENROUTER_API_KEY }}
run: npx i18n-rosetta sync
- name: Commit updated translations
run: |
git config user.name "i18n-rosetta"
git config user.email "bot@example.com"
git add i18n/ content/ locales/ messages/
git diff --staged --quiet || git commit -m "chore: sync translations"
git push
Google Translate Method
Kung ginagamit ang built-in na Google Translate method sa halip na OpenRouter:
- name: Sync translations
env:
GOOGLE_TRANSLATE_API_KEY: ${{ secrets.GOOGLE_TRANSLATE_API_KEY }}
run: npx i18n-rosetta sync
Direct LLM Providers
Kung direktang ginagamit ang openai, anthropic, o gemini methods:
# OpenAI
- name: Sync translations
env:
OPENAI_API_KEY: ${{ secrets.OPENAI_API_KEY }}
run: npx i18n-rosetta sync --method openai
# Anthropic
- name: Sync translations
env:
ANTHROPIC_API_KEY: ${{ secrets.ANTHROPIC_API_KEY }}
run: npx i18n-rosetta sync --method anthropic
# Gemini (free tier available)
- name: Sync translations
env:
GEMINI_API_KEY: ${{ secrets.GEMINI_API_KEY }}
run: npx i18n-rosetta sync --method gemini
DeepL
- name: Sync translations
env:
DEEPL_API_KEY: ${{ secrets.DEEPL_API_KEY }}
run: npx i18n-rosetta sync --method deepl
Remote Translation API
Kung gumagamit ng remote translation endpoint (halimbawa, isang hosted translation service):
- name: Sync translations
env:
ROSETTA_API_KEY: ${{ secrets.ROSETTA_API_KEY }}
run: npx i18n-rosetta sync
Three-Layer CI Pipeline
Para sa maximum na i18n coverage, i-gate ang inyong pipeline gamit ang lahat ng tatlong tools:
jobs:
i18n:
steps:
- uses: actions/checkout@v4
- run: npm ci
# 1. Catch hardcoded strings before they ship
- run: npx i18n-rosetta lint
# 2. Translate missing keys
- run: npx i18n-rosetta sync
env:
OPENROUTER_API_KEY: ${{ secrets.OPENROUTER_API_KEY }}
# 3. Fail if any locale is incomplete
- run: npx i18n-rosetta audit
| Layer | Command | Kailan | Purpose |
|---|---|---|---|
| Lint | lint | Pre-commit | I-block ang mga commits na may hardcoded strings |
| Sync | sync | Post-commit / CI | I-translate ang mga missing at changed keys |
| Audit | audit | Build step | I-fail ang deployment kung may incomplete na locale |
Tingnan Din
- CLI Reference — buong command reference
- How Sync Works — pag-intindi sa incremental sync
- Translation Methods — pagpili ng method per pair
- Quality Gate — ano ang mangyayari kapag nag-fail ang translations
- Configuration — config reference