Build Search Index #680
  
    
      This file contains hidden or 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
    
  
  
    
  | name: Build Search Index | |
| permissions: | |
| packages: write | |
| contents: write | |
| actions: write | |
| on: | |
| schedule: | |
| # Run once a day | |
| - cron: '10 0 * * *' | |
| workflow_dispatch: | |
| inputs: | |
| noop: | |
| description: 'noop' | |
| required: false | |
| default: 'noop' | |
| jobs: | |
| build: | |
| runs-on: ubuntu-latest | |
| outputs: | |
| run_update: ${{ steps.date_check.outputs.run_update }} | |
| steps: | |
| - uses: actions/checkout@v1 | |
| - uses: actions/setup-node@v4 | |
| with: | |
| node-version: 20 | |
| - name: Check commit date | |
| id: date_check | |
| run: | | |
| chmod +x ./search-server/commit-date-check.sh | |
| echo "$(./search-server/commit-date-check.sh)" | |
| echo "run_update=$(./search-server/commit-date-check.sh)" >> $GITHUB_ENV | |
| - name: GH script check | |
| uses: actions/github-script@v7 | |
| id: check | |
| with: | |
| script: | | |
| const { owner, repo } = context.repo | |
| const update = ${{ env.run_update == 'update' }} | |
| if (!update) { | |
| console.log('Cancelling ...'); | |
| const run_id = "${{ github.run_id }}"; | |
| await github.rest.actions.cancelWorkflowRun({ owner, repo, run_id }); | |
| return 'stop' | |
| } else { | |
| return 'build' | |
| } | |
| result-encoding: string | |
| - name: Waiting for cancellation | |
| run: sleep 60 | |
| if: steps.check.outputs.result == 'stop' | |
| - name: Create search index | |
| run: | | |
| echo "TYPESENSE_API_KEY=${{ secrets.TYPESENSE_API_KEY }}" >> $GITHUB_ENV | |
| export TYPESENSE_API_KEY=${{ secrets.TYPESENSE_API_KEY }} | |
| mkdir -p ${GITHUB_WORKSPACE}/typesense-data | |
| cp ./search-server/typesense-server/Dockerfile ${GITHUB_WORKSPACE}/typesense-data/Dockerfile | |
| cp ./search-server/typesense-scraper/typesense-scraper-config.json typesense-scraper-config.json | |
| envsubst < "./search-server/typesense-scraper/typesense-scraper.env" > "typesense-scraper-updated.env" | |
| docker run -d -p 8108:8108 -v ${GITHUB_WORKSPACE}/typesense-data/data:/data typesense/typesense:0.21.0 --data-dir /data --api-key=${TYPESENSE_API_KEY} --enable-cors & | |
| sleep 5 | |
| docker run -i --env-file typesense-scraper-updated.env -e "CONFIG=$(cat typesense-scraper-config.json | jq -r tostring)" typesense/docsearch-scraper | |
| curl 'http://172.17.0.2:8108/keys' -X POST -H "X-TYPESENSE-API-KEY: ${TYPESENSE_API_KEY}" -H 'Content-Type: application/json' -d '{"value": "N4N8bF0XwyvzwCGwm3CKB0QcnwyWtygo","description": "Search only","actions": ["documents:search"],"collections":["*"]}' | |
| - name: repository name fix and env | |
| run: | | |
| echo "letsencrypt_email=${{ secrets.LETSENCRYPT_EMAIL }}" >> $GITHUB_ENV | |
| echo "TAG_NAME=latest" >> $GITHUB_ENV | |
| if [ "${{ github.event.release.tag_name }}" != "" ]; then | |
| echo "TAG_NAME=${{ github.event.release.tag_name }}" >> $GITHUB_ENV | |
| fi; | |
| if [ "${{ github.event.inputs.version }}" != "" ]; then | |
| echo "TAG_NAME=${{ github.event.inputs.version }}" >> $GITHUB_ENV | |
| fi; | |
| echo "image_repository_name=servicestack/docs-search" >> $GITHUB_ENV | |
| echo "domain=search.docs.servicestack.net" >> $GITHUB_ENV | |
| echo "letsencrypt_email=${{ secrets.LETSENCRYPT_EMAIL }}" >> $GITHUB_ENV | |
| echo "app_name=servicestack-docs-search" >> $GITHUB_ENV | |
| echo "typesense_api_key=${{ secrets.TYPESENSE_API_KEY }}" >> $GITHUB_ENV | |
| - name: Write .env file | |
| run: | | |
| echo "HOST_DOMAIN=${{ env.domain }}" > .env | |
| echo "LETSENCRYPT_EMAIL=${{ env.letsencrypt_email }}" >> .env | |
| echo "TYPESENSE_API_KEY=${{ env.typesense_api_key }}" >> .env | |
| cp search-server/typesense-server/docker-compose.yml ./ | |
| - name: Login to GitHub Container Registry | |
| uses: docker/login-action@v2 | |
| with: | |
| registry: ghcr.io | |
| username: ${{ github.actor }} | |
| password: ${{ secrets.GITHUB_TOKEN }} | |
| - name: Build and push Docker images | |
| uses: docker/build-push-action@v3 | |
| if: ${{ github.event.inputs.version == '' || github.event.inputs.version == 'latest' }} | |
| with: | |
| file: ./typesense-data/Dockerfile | |
| context: ./typesense-data/ | |
| push: true | |
| tags: ghcr.io/${{ env.image_repository_name }}:${{ env.TAG_NAME }} | |
| # Copy only the docker-compose.yml to remote server home folder | |
| - name: copy compose file via scp | |
| uses: appleboy/scp-action@v0.1.3 | |
| with: | |
| host: 52.201.116.245 | |
| username: ${{ secrets.DEPLOY_USERNAME }} | |
| port: 22 | |
| key: ${{ secrets.DEPLOY_KEY }} | |
| source: "docker-compose.yml,.env" | |
| target: "~/.deploy/docs-typesense" | |
| # Deploy Docker image with ServiceStack application using `docker compose up` remotely | |
| - name: remote docker-compose up via ssh | |
| uses: appleboy/ssh-action@v0.1.5 | |
| env: | |
| APPTOKEN: ${{ secrets.GITHUB_TOKEN }} | |
| USERNAME: ${{ secrets.DEPLOY_USERNAME }} | |
| with: | |
| host: 52.201.116.245 | |
| username: ${{ secrets.DEPLOY_USERNAME }} | |
| key: ${{ secrets.DEPLOY_KEY }} | |
| port: 22 | |
| envs: APPTOKEN,USERNAME | |
| script: | | |
| echo $APPTOKEN | docker login ghcr.io -u $USERNAME --password-stdin | |
| cd ~/.deploy/docs-typesense | |
| docker-compose pull | |
| docker-compose up -d |