diff --git a/.github/labels.yml b/.github/labels.yml deleted file mode 100644 index ff8ca8d..0000000 --- a/.github/labels.yml +++ /dev/null @@ -1,78 +0,0 @@ ---- -- name: "breaking-change" - color: ee0701 - description: "A breaking change for existing users." -- name: "bugfix" - color: ee0701 - description: "Inconsistencies or issues which will cause a problem for users or implementors." -- name: "documentation" - color: 0052cc - description: "Solely about the documentation of the project." -- name: "enhancement" - color: 1d76db - description: "Enhancement of the code, not introducing new features." -- name: "refactor" - color: 1d76db - description: "Improvement of existing code, not introducing new features." -- name: "performance" - color: 1d76db - description: "Improving performance, not introducing new features." -- name: "new-feature" - color: 0e8a16 - description: "New features or options." -- name: "maintenance" - color: 2af79e - description: "Generic maintenance tasks." -- name: "ci" - color: 1d76db - description: "Work that improves the continue integration." -- name: "dependencies" - color: 1d76db - description: "Upgrade or downgrade of project dependencies." - -- name: "in-progress" - color: fbca04 - description: "Issue is currently being resolved by a developer." -- name: "stale" - color: fef2c0 - description: "There has not been activity on this issue or PR for quite some time." -- name: "no-stale" - color: fef2c0 - description: "This issue or PR is exempted from the stable bot." - -- name: "security" - color: ee0701 - description: "Marks a security issue that needs to be resolved asap." -- name: "incomplete" - color: fef2c0 - description: "Marks a PR or issue that is missing information." -- name: "invalid" - color: fef2c0 - description: "Marks a PR or issue that is missing information." - -- name: "beginner-friendly" - color: 0e8a16 - description: "Good first issue for people wanting to contribute to the project." -- name: "help-wanted" - color: 0e8a16 - description: "We need some extra helping hands or expertise in order to resolve this." - -- name: "priority-critical" - color: ee0701 - description: "This should be dealt with ASAP. Not fixing this issue would be a serious error." -- name: "priority-high" - color: b60205 - description: "After critical issues are fixed, these should be dealt with before any further issues." -- name: "priority-medium" - color: 0e8a16 - description: "This issue may be useful, and needs some attention." -- name: "priority-low" - color: e4ea8a - description: "Nice addition, maybe... someday..." - -- name: "major" - color: b60205 - description: "This PR causes a major version bump in the version number." -- name: "minor" - color: 0e8a16 - description: "This PR causes a minor version bump in the version number." diff --git a/.github/release-drafter.yml b/.github/release-drafter.yml deleted file mode 100644 index 445a16a..0000000 --- a/.github/release-drafter.yml +++ /dev/null @@ -1,56 +0,0 @@ ---- -name-template: "v$RESOLVED_VERSION" -tag-template: "v$RESOLVED_VERSION" -change-template: "- $TITLE @$AUTHOR (#$NUMBER)" -sort-direction: ascending - -categories: - - title: "🚨 Breaking changes" - labels: - - "breaking-change" - - title: "✨ New features" - labels: - - "new-feature" - - title: "πŸ› Bug fixes" - labels: - - "bugfix" - - title: "πŸš€ Enhancements" - labels: - - "enhancement" - - "refactor" - - "performance" - - title: "🧰 Maintenance" - labels: - - "maintenance" - - "ci" - - title: "πŸ“š Documentation" - labels: - - "documentation" - - title: "⬆️ Dependency updates" - labels: - - "dependencies" - -version-resolver: - major: - labels: - - "major" - - "breaking-change" - minor: - labels: - - "minor" - - "new-feature" - patch: - labels: - - "bugfix" - - "chore" - - "ci" - - "dependencies" - - "documentation" - - "enhancement" - - "performance" - - "refactor" - default: patch - -template: | - ## What’s changed - $CHANGES diff --git a/.github/workflows/ci.yaml b/.github/workflows/ci.yaml index cd130dd..5d1632d 100644 --- a/.github/workflows/ci.yaml +++ b/.github/workflows/ci.yaml @@ -16,176 +16,7 @@ on: workflow_dispatch: jobs: - information: - name: Gather add-on information - runs-on: ubuntu-latest - outputs: - architectures: ${{ steps.information.outputs.architectures }} - build: ${{ steps.information.outputs.build }} - description: ${{ steps.information.outputs.description }} - name: ${{ steps.information.outputs.name }} - slug: ${{ steps.information.outputs.slug }} - target: ${{ steps.information.outputs.target }} - steps: - - name: ‡️ Check out code from GitHub - uses: actions/checkout@v2.4.0 - - name: πŸš€ Run add-on information action - id: information - uses: frenck/action-addon-information@v1.3 - - lint-addon: - name: Lint Add-on - needs: - - information - runs-on: ubuntu-latest - steps: - - name: ‡️ Check out code from GitHub - uses: actions/checkout@v2.4.0 - - name: πŸš€ Run Add-on Lint - uses: frenck/action-addon-linter@v2.5 - with: - path: "./${{ needs.information.outputs.target }}" - - lint-hadolint: - name: Hadolint - needs: - - information - runs-on: ubuntu-latest - steps: - - name: ‡️ Check out code from GitHub - uses: actions/checkout@v2.4.0 - - name: πŸš€ Run Hadolint - uses: brpaz/hadolint-action@v1.5.0 - with: - dockerfile: "./${{ needs.information.outputs.target }}/Dockerfile" - - lint-json: - name: JSON Lint - runs-on: ubuntu-latest - steps: - - name: ‡️ Check out code from GitHub - uses: actions/checkout@v2.4.0 - - name: πŸš€ Run JQ - run: | - shopt -s globstar - cat **/*.json | jq '.' - lint-markdown: - name: MarkdownLint - runs-on: ubuntu-latest - steps: - - name: ‡️ Check out code from GitHub - uses: actions/checkout@v2.4.0 - - name: πŸš€ Run mdl - uses: actionshub/markdownlint@2.0.2 - - lint-shellcheck: - name: Shellcheck - runs-on: ubuntu-latest - steps: - - name: ‡️ Check out code from GitHub - uses: actions/checkout@v2.4.0 - - name: πŸš€ Run Shellcheck - uses: ludeeus/action-shellcheck@1.1.0 - env: - SHELLCHECK_OPTS: -s bash - - lint-yamllint: - name: YAMLLint - runs-on: ubuntu-latest - steps: - - name: ‡️ Check out code from GitHub - uses: actions/checkout@v2.4.0 - - name: πŸš€ Run YAMLLint - uses: frenck/action-yamllint@v1.1 - - lint-prettier: - name: Prettier - runs-on: ubuntu-latest - steps: - - name: ‡️ Check out code from GitHub - uses: actions/checkout@v2.4.0 - - name: πŸš€ Run Prettier - uses: creyD/prettier_action@v4.0 - with: - prettier_options: --write **/*.{json,js,md,yaml} - env: - GITHUB_TOKEN: ${{ secrets.GITHUB_TOKEN }} - - build: - name: Build ${{ matrix.architecture }} - needs: - - information - - lint-addon - - lint-hadolint - - lint-json - - lint-markdown - - lint-prettier - - lint-shellcheck - - lint-yamllint - runs-on: ubuntu-latest - strategy: - matrix: - architecture: ${{ fromJson(needs.information.outputs.architectures) }} - steps: - - name: ‡️ Check out code from GitHub - uses: actions/checkout@v2.4.0 - - name: πŸ— Set up build cache - id: cache - uses: actions/cache@v2.1.6 - with: - path: /tmp/.docker-cache - key: docker-${{ github.ref }}-${{ matrix.architecture }}-${{ github.sha }} - restore-keys: | - docker-${{ github.ref }}-${{ matrix.architecture }} - - name: πŸ— Set up QEMU - uses: docker/setup-qemu-action@v1.2.0 - - name: πŸ— Set up Docker Buildx - uses: docker/setup-buildx-action@v1.6.0 - - name: ℹ️ Compose build flags - id: flags - run: | - echo "::set-output name=date::$(date +"%Y-%m-%dT%H:%M:%SZ")" - from=$(yq --no-colors eval ".build_from.${{ matrix.architecture }}" "${{ needs.information.outputs.build }}") - echo "::set-output name=from::${from}" - if [[ "${{ matrix.architecture}}" = "amd64" ]]; then - echo "::set-output name=platform::linux/amd64" - elif [[ "${{ matrix.architecture }}" = "i386" ]]; then - echo "::set-output name=platform::linux/386" - elif [[ "${{ matrix.architecture }}" = "armhf" ]]; then - echo "::set-output name=platform::linux/arm/v6" - elif [[ "${{ matrix.architecture }}" = "armv7" ]]; then - echo "::set-output name=platform::linux/arm/v7" - elif [[ "${{ matrix.architecture }}" = "aarch64" ]]; then - echo "::set-output name=platform::linux/arm64/v8" - else - echo "::error ::Could not determine platform for architecture ${{ matrix.architecture }}" - exit 1 - fi - - name: πŸš€ Build - uses: docker/build-push-action@v2.7.0 - with: - push: false - context: ${{ needs.information.outputs.target }} - file: ${{ needs.information.outputs.target }}/Dockerfile - cache-from: | - type=local,src=/tmp/.docker-cache - ghcr.io/mdegat01/${{ needs.information.outputs.slug }}/${{ matrix.architecture }}:edge - cache-to: type=local,mode=max,dest=/tmp/.docker-cache-new - platforms: ${{ steps.flags.outputs.platform }} - build-args: | - BUILD_ARCH=${{ matrix.architecture }} - BUILD_DATE=${{ steps.flags.outputs.date }} - BUILD_DESCRIPTION=${{ needs.information.outputs.description }} - BUILD_FROM=${{ steps.flags.outputs.from }} - BUILD_NAME=${{ needs.information.outputs.name }} - BUILD_REF=${{ github.sha }} - BUILD_REPOSITORY=${{ github.repository }} - BUILD_VERSION=edge - # This ugly bit is necessary, or our cache will grow forever... - # Well until we hit GitHub's limit of 5GB :) - # https://github.com/docker/build-push-action/issues/252 - # https://github.com/moby/buildkit/issues/1896 - - name: 🚚 Swap build cache - run: | - rm -rf /tmp/.docker-cache - mv /tmp/.docker-cache-new /tmp/.docker-cache + workflows: + uses: mdegat01/addon-workflows/.github/workflows/addon-ci.yaml@main + secrets: + GITHUB_TOKEN: ${{ secrets.GITHUB_TOKEN }} diff --git a/.github/workflows/deploy.yaml b/.github/workflows/deploy.yaml index 30e9a7b..8e259c2 100644 --- a/.github/workflows/deploy.yaml +++ b/.github/workflows/deploy.yaml @@ -13,200 +13,8 @@ on: - completed jobs: - information: - if: | - github.event_name == 'release' - || ( - github.event_name == 'workflow_run' - && github.event.workflow_run.conclusion == 'success' - ) - name: ℹ️ Gather add-on information - runs-on: ubuntu-latest - outputs: - architectures: ${{ steps.information.outputs.architectures }} - build: ${{ steps.information.outputs.build }} - description: ${{ steps.information.outputs.description }} - environment: ${{ steps.release.outputs.environment }} - name: ${{ steps.information.outputs.name }} - slug: ${{ steps.information.outputs.slug }} - target: ${{ steps.information.outputs.target }} - version: ${{ steps.release.outputs.version }} - steps: - - name: ‡️ Check out code from GitHub - uses: actions/checkout@v2.4.0 - - name: πŸš€ Run add-on information action - id: information - uses: frenck/action-addon-information@v1.3 - - name: ℹ️ Gather version and environment - id: release - run: | - sha="${{ github.sha }}" - environment="edge" - version="${sha:0:7}" - if [[ "${{ github.event_name }}" = "release" ]]; then - version="${{ github.event.release.tag_name }}" - version="${version,,}" - version="${version#v}" - environment="stable" - if [[ "${{ github.event.release.prerelease }}" = "true" ]]; then - environment="beta" - fi - fi - echo "::set-output name=environment::${environment}" - echo "::set-output name=version::${version}" - deploy: - name: πŸ‘· Build & Deploy ${{ matrix.architecture }} - needs: information - runs-on: ubuntu-latest - strategy: - matrix: - architecture: ${{ fromJson(needs.information.outputs.architectures) }} - steps: - - name: πŸ”‚ Wait for other runs to complete - uses: softprops/turnstyle@v1 - env: - GITHUB_TOKEN: ${{ secrets.GITHUB_TOKEN }} - - name: ‡️ Check out code from GitHub - uses: actions/checkout@v2.4.0 - - name: πŸ— Set up build cache - id: cache - uses: actions/cache@v2.1.6 - with: - path: /tmp/.docker-cache - key: docker-${{ github.ref }}-${{ matrix.architecture }}-${{ github.sha }} - restore-keys: | - docker-${{ github.ref }}-${{ matrix.architecture }} - - name: πŸ— Set up QEMU - uses: docker/setup-qemu-action@v1.2.0 - - name: πŸ— Set up Docker Buildx - uses: docker/setup-buildx-action@v1.6.0 - - name: ℹ️ Compose build flags - id: flags - run: | - echo "::set-output name=date::$(date +"%Y-%m-%dT%H:%M:%SZ")" - from=$(yq --no-colors eval ".build_from.${{ matrix.architecture }}" "${{ needs.information.outputs.build }}") - echo "::set-output name=from::${from}" - if [[ "${{ matrix.architecture}}" = "amd64" ]]; then - echo "::set-output name=platform::linux/amd64" - elif [[ "${{ matrix.architecture }}" = "i386" ]]; then - echo "::set-output name=platform::linux/386" - elif [[ "${{ matrix.architecture }}" = "armhf" ]]; then - echo "::set-output name=platform::linux/arm/v6" - elif [[ "${{ matrix.architecture }}" = "armv7" ]]; then - echo "::set-output name=platform::linux/arm/v7" - elif [[ "${{ matrix.architecture }}" = "aarch64" ]]; then - echo "::set-output name=platform::linux/arm64/v8" - else - echo "::error ::Could not determine platform for architecture ${{ matrix.architecture }}" - exit 1 - fi - - name: πŸ— Login to GitHub Container Registry - uses: docker/login-action@v1.10.0 - with: - registry: ghcr.io - username: ${{ secrets.GHCR_USERNAME }} - password: ${{ secrets.GHCR_TOKEN }} - - name: πŸš€ Build and push - uses: docker/build-push-action@v2.7.0 - with: - push: true - # yamllint disable rule:line-length - tags: | - ghcr.io/mdegat01/${{ needs.information.outputs.slug }}/${{ matrix.architecture }}:${{ needs.information.outputs.environment }} - ghcr.io/mdegat01/${{ needs.information.outputs.slug }}/${{ matrix.architecture }}:${{ needs.information.outputs.version }} - # yamllint enable rule:line-length - context: ${{ needs.information.outputs.target }} - file: ${{ needs.information.outputs.target }}/Dockerfile - cache-from: | - type=local,src=/tmp/.docker-cache - ghcr.io/mdegat01/${{ needs.information.outputs.slug }}/${{ matrix.architecture }}:edge - cache-to: type=local,mode=max,dest=/tmp/.docker-cache-new - platforms: ${{ steps.flags.outputs.platform }} - build-args: | - BUILD_ARCH=${{ matrix.architecture }} - BUILD_DATE=${{ steps.flags.outputs.date }} - BUILD_DESCRIPTION=${{ needs.information.outputs.description }} - BUILD_FROM=${{ steps.flags.outputs.from }} - BUILD_NAME=${{ needs.information.outputs.name }} - BUILD_REF=${{ github.sha }} - BUILD_REPOSITORY=${{ github.repository }} - BUILD_VERSION=${{ needs.information.outputs.version }} - # This ugly bit is necessary, or our cache will grow forever... - # Well until we hit GitHub's limit of 5GB :) - # https://github.com/docker/build-push-action/issues/252 - # https://github.com/moby/buildkit/issues/1896 - - name: 🚚 Swap build cache - run: | - rm -rf /tmp/.docker-cache - mv /tmp/.docker-cache-new /tmp/.docker-cache - publish-edge: - name: πŸ“’ Publish to edge repository - if: needs.information.outputs.environment == 'edge' - needs: - - information - - deploy - environment: - name: edge - runs-on: ubuntu-latest - steps: - - name: πŸš€ Dispatch repository updater update signal - uses: peter-evans/repository-dispatch@v1.1.3 - with: - token: ${{ secrets.MY_GITHUB_TOKEN }} - repository: mdegat01/hassio-addons-edge - event-type: update - client-payload: > - { - "addon": "${{ needs.information.outputs.slug }}", - "name": "${{ needs.information.outputs.name }}", - "repository": "${{ github.repository }}", - "version": "${{ needs.information.outputs.version }}" - } - publish-beta: - name: πŸ“’ Publish to beta repository - if: | - needs.information.outputs.environment == 'beta' || - needs.information.outputs.environment == 'stable' - needs: - - information - - deploy - environment: - name: beta - runs-on: ubuntu-latest - steps: - - name: πŸš€ Dispatch repository updater update signal - uses: peter-evans/repository-dispatch@v1.1.3 - with: - token: ${{ secrets.MY_GITHUB_TOKEN }} - repository: mdegat01/hassio-addons-beta - event-type: update - client-payload: > - { - "addon": "${{ needs.information.outputs.slug }}", - "name": "${{ needs.information.outputs.name }}", - "repository": "${{ github.repository }}", - "version": "${{ needs.information.outputs.version }}" - } - publish-stable: - name: πŸ“’ Publish to stable repository - if: needs.information.outputs.environment == 'stable' - needs: - - information - - deploy - environment: - name: stable - runs-on: ubuntu-latest - steps: - - name: πŸš€ Dispatch repository updater update signal - uses: peter-evans/repository-dispatch@v1.1.3 - with: - token: ${{ secrets.MY_GITHUB_TOKEN }} - repository: mdegat01/hassio-addons - event-type: update - client-payload: > - { - "addon": "${{ needs.information.outputs.slug }}", - "name": "${{ needs.information.outputs.name }}", - "repository": "${{ github.repository }}", - "version": "${{ github.event.release.tag_name }}" - } + workflows: + uses: mdegat01/addon-workflows/.github/workflows/addon-deploy.yaml@main + secrets: + DISPATCH_TOKEN: ${{ secrets.DISPATCH_TOKEN }} + GITHUB_TOKEN: ${{ secrets.GITHUB_TOKEN }} diff --git a/.github/workflows/labels.yaml b/.github/workflows/labels.yaml index 81d6bb2..83b045b 100644 --- a/.github/workflows/labels.yaml +++ b/.github/workflows/labels.yaml @@ -3,20 +3,12 @@ name: Sync labels # yamllint disable-line rule:truthy on: - push: - branches: - - main - paths: - - .github/labels.yml + schedule: + - cron: "34 5 * * *" + workflow_dispatch: jobs: - labels: - name: ♻️ Sync labels - runs-on: ubuntu-latest - steps: - - name: ‡️ Check out code from GitHub - uses: actions/checkout@v2.4.0 - - name: πŸš€ Run Label Syncer - uses: micnncim/action-label-syncer@v1.3.0 - env: - GITHUB_TOKEN: ${{ secrets.GITHUB_TOKEN }} + workflows: + uses: mdegat01/addon-workflows/.github/workflows/labels.yaml@main + secrets: + GITHUB_TOKEN: ${{ secrets.GITHUB_TOKEN }} diff --git a/.github/workflows/lock.yaml b/.github/workflows/lock.yaml index cee6e4c..907e9ff 100644 --- a/.github/workflows/lock.yaml +++ b/.github/workflows/lock.yaml @@ -8,14 +8,7 @@ on: workflow_dispatch: jobs: - lock: - name: πŸ”’ Lock closed issues and PRs - runs-on: ubuntu-latest - steps: - - uses: dessant/lock-threads@v3 - with: - github-token: ${{ github.token }} - issue-lock-inactive-days: "30" - issue-lock-reason: "" - pr-lock-inactive-days: "1" - pr-lock-reason: "" + workflows: + uses: mdegat01/addon-workflows/.github/workflows/lock.yaml@main + secrets: + GITHUB_TOKEN: ${{ secrets.GITHUB_TOKEN }} diff --git a/.github/workflows/pr-labels.yaml b/.github/workflows/pr-labels.yaml index 41da9cf..46a932c 100644 --- a/.github/workflows/pr-labels.yaml +++ b/.github/workflows/pr-labels.yaml @@ -4,18 +4,14 @@ name: PR Labels # yamllint disable-line rule:truthy on: pull_request: - types: [opened, labeled, unlabeled, synchronize] + types: + - opened + - labeled + - unlabeled + - synchronize jobs: - pr_labels: - name: Verify - runs-on: ubuntu-latest - steps: - - name: 🏷 Verify PR has a valid label - uses: jesusvasquez333/verify-pr-label-action@v1.4.0 - with: - github-token: "${{ secrets.GITHUB_TOKEN }}" - valid-labels: >- - breaking-change, bugfix, documentation, enhancement, refactor, - performance, new-feature, maintenance, ci, dependencies - disable-reviews: true + workflows: + uses: mdegat01/addon-workflows/.github/workflows/pr-labels.yaml@main + secrets: + GITHUB_TOKEN: ${{ secrets.GITHUB_TOKEN }} diff --git a/.github/workflows/release-drafter.yaml b/.github/workflows/release-drafter.yaml index 06cc26a..b155386 100644 --- a/.github/workflows/release-drafter.yaml +++ b/.github/workflows/release-drafter.yaml @@ -8,11 +8,7 @@ on: - main jobs: - update_release_draft: - name: ✏️ Draft release - runs-on: ubuntu-latest - steps: - - name: πŸš€ Run Release Drafter - uses: release-drafter/release-drafter@v5.15.0 - env: - GITHUB_TOKEN: ${{ secrets.GITHUB_TOKEN }} + workflows: + uses: mdegat01/addon-workflows/.github/workflows/release-drafter.yaml@main + secrets: + GITHUB_TOKEN: ${{ secrets.GITHUB_TOKEN }} diff --git a/.github/workflows/stale.yaml b/.github/workflows/stale.yaml index cccc221..ed8dd41 100644 --- a/.github/workflows/stale.yaml +++ b/.github/workflows/stale.yaml @@ -8,31 +8,7 @@ on: workflow_dispatch: jobs: - stale: - name: 🧹 Clean up stale issues and PRs - runs-on: ubuntu-latest - steps: - - name: πŸš€ Run stale - uses: actions/stale@v4 - with: - repo-token: ${{ secrets.MY_GITHUB_TOKEN }} - days-before-stale: 30 - days-before-close: 7 - remove-stale-when-updated: true - stale-issue-label: "stale" - exempt-issue-labels: "no-stale,help-wanted" - stale-issue-message: > - There hasn't been any activity on this issue recently, so we - clean up some of the older and inactive issues. - Please make sure to update to the latest version and - check if that solves the issue. Let us know if that works for you - by leaving a comment πŸ‘ - This issue has now been marked as stale and will be closed if no - further activity occurs. Thanks! - stale-pr-label: "stale" - exempt-pr-labels: "no-stale" - stale-pr-message: > - There hasn't been any activity on this pull request recently. This - pull request has been automatically marked as stale because of that - and will be closed if no further activity occurs within 7 days. - Thank you for your contributions. + workflows: + uses: mdegat01/addon-workflows/.github/workflows/stale.yaml@main + secrets: + GITHUB_TOKEN: ${{ secrets.GITHUB_TOKEN }} diff --git a/amridm2mqtt/config.yaml b/amridm2mqtt/config.yaml index 8d9411c..d5e79aa 100644 --- a/amridm2mqtt/config.yaml +++ b/amridm2mqtt/config.yaml @@ -1,7 +1,7 @@ --- name: AMRIDM2MQTT url: https://github.com/mdegat01/addon-amridm2mqtt -version: edge +version: dev slug: amridm2mqtt arch: - aarch64