mirror of
https://github.com/searxng/searxng
synced 2024-11-09 01:10:26 +00:00
b5ce39b536
Restrict the GitHub token permissions only to the required ones; this way, even if the attackers will succeed in compromising your workflow, they won’t be able to do much. - Included permissions for the action. https://github.com/ossf/scorecard/blob/main/docs/checks.md#token-permissions https://docs.github.com/en/actions/using-workflows/workflow-syntax-for-github-actions#permissions https://docs.github.com/en/actions/using-jobs/assigning-permissions-to-jobs [Keeping your GitHub Actions and workflows secure Part 1: Preventing pwn requests](https://securitylab.github.com/research/github-actions-preventing-pwn-requests/) Signed-off-by: nathannaveen <42319948+nathannaveen@users.noreply.github.com>
215 lines
6.2 KiB
YAML
215 lines
6.2 KiB
YAML
name: Integration
|
|
|
|
on:
|
|
push:
|
|
branches: ["master"]
|
|
pull_request:
|
|
branches: ["master"]
|
|
|
|
permissions:
|
|
contents: read
|
|
|
|
jobs:
|
|
python:
|
|
name: Python ${{ matrix.python-version }}
|
|
runs-on: ubuntu-20.04
|
|
strategy:
|
|
matrix:
|
|
os: [ubuntu-20.04]
|
|
python-version: ["3.7", "3.8", "3.9", "3.10", "3.11"]
|
|
steps:
|
|
- name: Checkout
|
|
uses: actions/checkout@v2
|
|
- name: Install Ubuntu packages
|
|
run: |
|
|
sudo ./utils/searxng.sh install packages
|
|
sudo apt install firefox
|
|
- name: Set up Python
|
|
uses: actions/setup-python@v4
|
|
with:
|
|
python-version: ${{ matrix.python-version }}
|
|
architecture: 'x64'
|
|
- name: Cache Python dependencies
|
|
id: cache-python
|
|
uses: actions/cache@v3
|
|
with:
|
|
path: |
|
|
./local
|
|
./.nvm
|
|
./node_modules
|
|
key: python-${{ matrix.os }}-${{ matrix.python-version }}-${{ hashFiles('requirements*.txt', 'setup.py') }}
|
|
- name: Install Python dependencies
|
|
if: steps.cache-python.outputs.cache-hit != 'true'
|
|
run: |
|
|
make V=1 install
|
|
make V=1 gecko.driver
|
|
- name: Run tests
|
|
run: make V=1 ci.test
|
|
- name: Test coverage
|
|
run: make V=1 test.coverage
|
|
- name: Store coverage result
|
|
uses: actions/upload-artifact@v2
|
|
with:
|
|
name: coverage-${{ matrix.python-version }}
|
|
path: coverage/
|
|
retention-days: 60
|
|
|
|
themes:
|
|
name: Themes
|
|
runs-on: ubuntu-20.04
|
|
steps:
|
|
- name: Checkout
|
|
uses: actions/checkout@v2
|
|
- name: Install Ubuntu packages
|
|
run: sudo ./utils/searxng.sh install buildhost
|
|
- name: Set up Python
|
|
uses: actions/setup-python@v4
|
|
with:
|
|
python-version: '3.9'
|
|
architecture: 'x64'
|
|
- name: Cache Python dependencies
|
|
id: cache-python
|
|
uses: actions/cache@v3
|
|
with:
|
|
path: |
|
|
./local
|
|
./.nvm
|
|
./node_modules
|
|
key: python-ubuntu-20.04-3.9-${{ hashFiles('requirements*.txt', 'setup.py','.nvmrc', 'package.json') }}
|
|
- name: Install node dependencies
|
|
run: make V=1 node.env
|
|
- name: Build themes
|
|
run: make V=1 themes.all
|
|
|
|
documentation:
|
|
name: Documentation
|
|
runs-on: ubuntu-20.04
|
|
permissions:
|
|
contents: write # for JamesIves/github-pages-deploy-action to push changes in repo
|
|
steps:
|
|
- name: Checkout
|
|
uses: actions/checkout@v2
|
|
with:
|
|
fetch-depth: '0'
|
|
persist-credentials: false
|
|
- name: Install Ubuntu packages
|
|
run: sudo ./utils/searxng.sh install buildhost
|
|
- name: Set up Python
|
|
uses: actions/setup-python@v4
|
|
with:
|
|
python-version: '3.9'
|
|
architecture: 'x64'
|
|
- name: Cache Python dependencies
|
|
id: cache-python
|
|
uses: actions/cache@v3
|
|
with:
|
|
path: |
|
|
./local
|
|
./.nvm
|
|
./node_modules
|
|
key: python-ubuntu-20.04-3.9-${{ hashFiles('requirements*.txt', 'setup.py','.nvmrc', 'package.json') }}
|
|
- name: Build documentation
|
|
run: |
|
|
make V=1 docs.clean docs.html
|
|
- name: Deploy
|
|
if: github.ref == 'refs/heads/master'
|
|
uses: JamesIves/github-pages-deploy-action@3.7.1
|
|
with:
|
|
GITHUB_TOKEN: ${{ github.token }}
|
|
BRANCH: gh-pages
|
|
FOLDER: dist/docs
|
|
CLEAN: true # Automatically remove deleted files from the deploy branch
|
|
SINGLE_COMMIT: True
|
|
COMMIT_MESSAGE: build from commit ${{ github.sha }}
|
|
|
|
babel:
|
|
name: Update translations branch
|
|
runs-on: ubuntu-20.04
|
|
if: ${{ github.repository_owner == 'searxng' && github.ref == 'refs/heads/master' }}
|
|
needs:
|
|
- python
|
|
- themes
|
|
- documentation
|
|
permissions:
|
|
contents: write # for make V=1 weblate.push.translations
|
|
steps:
|
|
- name: Checkout
|
|
uses: actions/checkout@v2
|
|
with:
|
|
fetch-depth: '0'
|
|
token: ${{ secrets.WEBLATE_GITHUB_TOKEN }}
|
|
- name: Set up Python
|
|
uses: actions/setup-python@v4
|
|
with:
|
|
python-version: '3.9'
|
|
architecture: 'x64'
|
|
- name: Cache Python dependencies
|
|
id: cache-python
|
|
uses: actions/cache@v3
|
|
with:
|
|
path: |
|
|
./local
|
|
./.nvm
|
|
./node_modules
|
|
key: python-ubuntu-20.04-3.9-${{ hashFiles('requirements*.txt', 'setup.py','.nvmrc', 'package.json') }}
|
|
- name: weblate & git setup
|
|
env:
|
|
WEBLATE_CONFIG: ${{ secrets.WEBLATE_CONFIG }}
|
|
run: |
|
|
mkdir -p ~/.config
|
|
echo "${WEBLATE_CONFIG}" > ~/.config/weblate
|
|
git config --global user.email "searxng-bot@users.noreply.github.com"
|
|
git config --global user.name "searxng-bot"
|
|
- name: Update transations
|
|
id: update
|
|
run: |
|
|
git restore utils/brand.env
|
|
make V=1 weblate.push.translations
|
|
|
|
dockers:
|
|
name: Docker
|
|
if: github.ref == 'refs/heads/master'
|
|
needs:
|
|
- python
|
|
- themes
|
|
- documentation
|
|
env:
|
|
DOCKERHUB_USERNAME: ${{ secrets.DOCKERHUB_USERNAME }}
|
|
runs-on: ubuntu-20.04
|
|
steps:
|
|
- name: Checkout
|
|
if: env.DOCKERHUB_USERNAME != null
|
|
uses: actions/checkout@v2
|
|
with:
|
|
# make sure "make docker.push" can get the git history
|
|
fetch-depth: '0'
|
|
- name: Set up Python
|
|
uses: actions/setup-python@v4
|
|
with:
|
|
python-version: '3.9'
|
|
architecture: 'x64'
|
|
- name: Cache Python dependencies
|
|
id: cache-python
|
|
uses: actions/cache@v3
|
|
with:
|
|
path: |
|
|
./local
|
|
./.nvm
|
|
./node_modules
|
|
key: python-ubuntu-20.04-3.9-${{ hashFiles('requirements*.txt', 'setup.py','.nvmrc', 'package.json') }}
|
|
- name: Set up QEMU
|
|
if: env.DOCKERHUB_USERNAME != null
|
|
uses: docker/setup-qemu-action@v1
|
|
- name: Set up Docker Buildx
|
|
if: env.DOCKERHUB_USERNAME != null
|
|
uses: docker/setup-buildx-action@v1
|
|
- name: Login to DockerHub
|
|
if: env.DOCKERHUB_USERNAME != null
|
|
uses: docker/login-action@v1
|
|
with:
|
|
username: ${{ secrets.DOCKERHUB_USERNAME }}
|
|
password: ${{ secrets.DOCKERHUB_TOKEN }}
|
|
- name: Build and push
|
|
if: env.DOCKERHUB_USERNAME != null
|
|
run: make -e GIT_URL=$(git remote get-url origin) docker.buildx
|