image: name: cirrusci/flutter variables: GIT_SUBMODULE_STRATEGY: recursive .shared_windows_runners: tags: - shared-windows - windows - windows-1809 stages: - coverage - release - deploy code_analyze: stage: coverage script: [./scripts/code_analyze.sh] code_analyze_beta: extends: code_analyze image: name: cirrusci/flutter:beta allow_failure: true test: stage: coverage script: [flutter test] build_web: stage: coverage before_script: [sudo apt update && sudo apt install curl -y, ./scripts/prepare-web.sh] script: [./scripts/build-web.sh] artifacts: paths: - build/web/ build_web_beta: extends: build_web image: name: cirrusci/flutter:beta allow_failure: true build_windows: extends: - .shared_windows_runners stage: coverage before_script: [./scripts/prepare-windows.ps1] script: [./scripts/build-windows.ps1] artifacts: paths: - build/windows/runner/Release allow_failure: true build_android_debug: stage: coverage script: [./scripts/build-android-debug.sh] artifacts: when: on_success paths: - build/app/outputs/apk/debug/app-debug.apk except: - main - tags build_android_apk: stage: coverage before_script: [./scripts/prepare-android-release.sh] script: [./scripts/build-android-apk.sh] artifacts: when: on_success paths: - build/android/app-release.apk only: - main - tags build_android_appbundle: stage: coverage before_script: [./scripts/prepare-android-release.sh] script: [./scripts/release-playstore-beta.sh] artifacts: when: on_success paths: - build/android/app-release.aab resource_group: playstore_release only: - main upload-fdroid: stage: release before_script: - "which ssh-agent || (sudo apt-get update -y && sudo apt-get install openssh-client -y )" - "which rsync || (sudo apt-get update -y && sudo apt-get install rsync -y )" - "which pcregrep || (sudo apt-get update -y && sudo apt-get install pcregrep -y )" - eval $(ssh-agent -s) - echo "$SSH_PRIVATE_KEY" | tr -d '\r' | ssh-add - - mkdir -p ~/.ssh - chmod 700 ~/.ssh - ssh-keyscan -t rsa fdroid.nordgedanken.dev >> ~/.ssh/known_hosts script: - cd build/android/ - export UPDATE_VERSION=$(pcregrep -o1 'version:\s([0-9]*\.[0-9]*\.[0-9]*)\+[0-9]*' ../../pubspec.yaml) && mv app-release.apk "${UPDATE_VERSION}.apk" - rsync -rav -e ssh ./ fluffy@fdroid.nordgedanken.dev:/opt/fdroid/fluffychat/repo - ssh fluffy@fdroid.nordgedanken.dev -t '/bin/bash -i -l -c "cd /opt/fdroid/fluffychat && source ../fdroidserver-env/bin/activate && fdroid update --verbose && deactivate"' needs: ["build_android_apk"] resource_group: playstore_release allow_failure: true only: - tags upload-fdroid-nightly: stage: release before_script: - "which ssh-agent || (sudo apt-get update -y && sudo apt-get install openssh-client -y )" - "which rsync || (sudo apt-get update -y && sudo apt-get install rsync -y )" - "which pcregrep || (sudo apt-get update -y && sudo apt-get install pcregrep -y )" - eval $(ssh-agent -s) - echo "$SSH_PRIVATE_KEY" | tr -d '\r' | ssh-add - - mkdir -p ~/.ssh - chmod 700 ~/.ssh - ssh-keyscan -t rsa fdroid.nordgedanken.dev >> ~/.ssh/known_hosts script: - cd build/android/ - export UPDATE_VERSION=$(pcregrep -o1 'version:\s([0-9]*\.[0-9]*\.[0-9]*)\+[0-9]*' ../../pubspec.yaml) && mv app-release.apk "${UPDATE_VERSION}_$(date +%s).apk" - rsync -rav -e ssh ./ fluffy@fdroid.nordgedanken.dev:/opt/fdroid/fluffychat-nightly/repo - ssh fluffy@fdroid.nordgedanken.dev -t '/bin/bash -i -l -c "cd /opt/fdroid/fluffychat-nightly && source ../fdroidserver-env/bin/activate && fdroid update --verbose && deactivate"' needs: ["build_android_apk"] resource_group: playstore_release allow_failure: true only: - main pages: needs: ["build_web"] stage: deploy image: ruby:latest script: - cp PRIVACY.md docs/_includes/privacy.md - cp CHANGELOG.md docs/_includes/changelog.md - cd docs - gem install bundler - bundle install - bundle exec jekyll build -d public - cd .. - mv docs/public/ ./ - mv build/web/ public/web/ artifacts: paths: - public only: - main build_linux_x86: stage: coverage before_script: [ sudo apt update && sudo apt install curl clang cmake ninja-build pkg-config libgtk-3-dev libblkid-dev liblzma-dev libjsoncpp-dev cmake-data libjsoncpp1 libsecret-1-dev libsecret-1-0 librhash0 -y, ] script: [./scripts/build-linux.sh] artifacts: when: on_success paths: - build/linux/x64/release/bundle/ build_linux_arm64: stage: coverage script: [./scripts/build-linux.sh] tags: [docker_arm64] only: - main - tags allow_failure: true artifacts: when: on_success paths: - build/linux/arm64/release/bundle/ update-dependencies: stage: coverage needs: [] tags: - docker only: - schedules variables: HOST: ${CI_PROJECT_URL} UPDATE_BRANCH: ci-bot/dependency-updates PRIVATE_TOKEN: ${GITLAB_API_TOKEN} before_script: - eval $(ssh-agent -s) - echo "$SSH_PRIVATE_BOT_KEY" | tr -d '\r' | ssh-add - > /dev/null - mkdir -p ~/.ssh - chmod 700 ~/.ssh - ssh-keyscan -t rsa gitlab.com >> ~/.ssh/known_hosts - chmod 644 ~/.ssh/known_hosts - git config --global user.email "bot@fluffy.chat" - git config --global user.name "Dependency Update Bot" - sudo apt-get update && sudo apt-get install -y curl script: - ./scripts/update-dependencies.sh - git remote set-url --push origin git@gitlab.com:$CI_PROJECT_PATH - 'git diff --exit-code || (git checkout -B ${UPDATE_BRANCH} && git add . && git commit -m "chore: Update dependencies" && git push -f origin ${UPDATE_BRANCH} && ./scripts/open-mr.sh)' .release: stage: release image: curlimages/curl:latest rules: - if: '$CI_COMMIT_TAG =~ /^v\d+\.\d+\.\d+$/' before_script: - export RELEASE_VERSION=$(echo $CI_COMMIT_TAG | grep -oE "\d+\.\d+\.\d+") - export PACKAGE_REGISTRY_URL="${CI_API_V4_URL}/projects/${CI_PROJECT_ID}/packages/generic/fluffychat/${RELEASE_VERSION}" upload-android: extends: .release script: - | curl --header "JOB-TOKEN: ${CI_JOB_TOKEN}" --upload-file build/android/app-release.apk ${PACKAGE_REGISTRY_URL}/fluffychat.apk upload-web: extends: .release script: - tar czf package.tar.gz -C build/web/ . - | curl --header "JOB-TOKEN: ${CI_JOB_TOKEN}" --upload-file package.tar.gz ${PACKAGE_REGISTRY_URL}/fluffychat-web.tar.gz upload-linux-x86: extends: .release script: - tar czf package.tar.gz -C build/linux/x64/release/bundle/ . - | curl --header "JOB-TOKEN: ${CI_JOB_TOKEN}" --upload-file package.tar.gz ${PACKAGE_REGISTRY_URL}/fluffychat-linux-x86.tar.gz upload-linux-arm64: extends: .release script: - tar czf package.tar.gz -C build/linux/arm64/release/bundle/ . - | curl --header "JOB-TOKEN: ${CI_JOB_TOKEN}" --upload-file package.tar.gz ${PACKAGE_REGISTRY_URL}/fluffychat-linux-arm64.tar.gz upload-windows: extends: .release image: alpine:latest script: - apk add --no-cache curl zip - cd build/windows/runner/Release; zip -r ../../../../package.zip . ; cd - - | curl --header "JOB-TOKEN: ${CI_JOB_TOKEN}" --upload-file package.zip ${PACKAGE_REGISTRY_URL}/fluffychat-windows.zip upload-playstore: stage: release before_script: [./scripts/prepare-android-release.sh] script: [./scripts/release-playstore.sh] resource_group: playstore_release only: - tags release: extends: .release image: registry.gitlab.com/gitlab-org/release-cli:latest script: - | release-cli create --name "Release ${CI_COMMIT_TAG}" --tag-name $CI_COMMIT_TAG \ --assets-link "{\"name\":\"fluffychat.apk\",\"url\":\"${PACKAGE_REGISTRY_URL}/fluffychat.apk\"}" \ --assets-link "{\"name\":\"fluffychat-linux-x86.tar.gz\",\"url\":\"${PACKAGE_REGISTRY_URL}/fluffychat-linux-x86.tar.gz\"}" \ --assets-link "{\"name\":\"fluffychat-linux-arm64.tar.gz\",\"url\":\"${PACKAGE_REGISTRY_URL}/fluffychat-linux-arm64.tar.gz\"}" \ --assets-link "{\"name\":\"fluffychat-windows.zip\",\"url\":\"${PACKAGE_REGISTRY_URL}/fluffychat-windows.zip\"}" \ --assets-link "{\"name\":\"fluffychat-web.tar.gz\",\"url\":\"${PACKAGE_REGISTRY_URL}/fluffychat-web.tar.gz\"}" .docker: &docker_template image: docker:latest tags: - docker - famedly stage: deploy services: - docker:dind docker-releases: <<: *docker_template script: - docker build --pull -t "${CI_REGISTRY_IMAGE}:latest" -t "${CI_REGISTRY_IMAGE}:${CI_COMMIT_TAG}" . - docker push "${CI_REGISTRY_IMAGE}:latest" - docker push "${CI_REGISTRY_IMAGE}:${CI_COMMIT_TAG}" rules: - if: '$CI_COMMIT_TAG && $CI_COMMIT_TAG =~ /^v\d+\.\d+\.\d+$/' before_script: - docker login -u "$CI_REGISTRY_USER" -p "$CI_REGISTRY_PASSWORD" $CI_REGISTRY docker-tags: <<: *docker_template script: - docker build --pull -t "${CI_REGISTRY_IMAGE}:${CI_COMMIT_TAG}" . - docker push "${CI_REGISTRY_IMAGE}:${CI_COMMIT_TAG}" rules: - if: '$CI_COMMIT_TAG && $CI_COMMIT_TAG !~ /^v\d+\.\d+\.\d+$/' before_script: - docker login -u "$CI_REGISTRY_USER" -p "$CI_REGISTRY_PASSWORD" $CI_REGISTRY docker-branches: <<: *docker_template script: - docker build --pull -t "${CI_REGISTRY_IMAGE}:${CI_COMMIT_REF_SLUG}" -t "${CI_REGISTRY_IMAGE}:${CI_COMMIT_SHA}" . - docker push "${CI_REGISTRY_IMAGE}:${CI_COMMIT_REF_SLUG}" rules: - if: $CI_COMMIT_TAG == null before_script: - docker login -u "$CI_REGISTRY_USER" -p "$CI_REGISTRY_PASSWORD" $CI_REGISTRY allow_failure: true