8 Commits

Author SHA1 Message Date
jcabillot 1bc4808204 Merge pull request 'fix: remove obsolete jcabillot/phpapache renovate custom manager' (#14) from fix/remove-phpapache-renovate into master
Main Release / test (push) Successful in 26s
Main Release / hadolint (push) Failing after 13m1s
Main Release / build (push) Successful in 17s
Main Release / tag (push) Successful in 46s
Tag Release / hadolint (push) Successful in 9s
Tag Release / test (push) Successful in 22s
Tag Release / build-push (push) Successful in 3m23s
Reviewed-on: #14
2026-06-29 15:08:11 -04:00
Hermes Agent c4e4cae577 fix: remove obsolete renovate.json
PR Checks / hadolint (pull_request) Successful in 10s
PR Checks / build-test (pull_request) Successful in 58s
With the migration to dunglas/frankenphp, the custom manager
for jcabillot/phpapache is gone. renovate.json had no remaining
config — delete the file entirely.
2026-06-29 18:50:52 +00:00
Hermes Agent bb9c01246c fix: remove obsolete jcabillot/phpapache custom manager from renovate.json
PR Checks / hadolint (pull_request) Successful in 17s
PR Checks / build-test (pull_request) Successful in 1m7s
The Dockerfile already migrated to dunglas/frankenphp, the
ARG VERSION pattern is gone. The custom manager tracking
jcabillot/phpapache is no longer needed.
2026-06-29 18:49:50 +00:00
jcabillot afd279c323 Merge pull request 'fix: ensure cache directory is writable by www-data' (#13) from fix/cache-permissions into master
Main Release / test (push) Successful in 15s
Main Release / build (push) Successful in 12s
Main Release / tag (push) Successful in 13s
Tag Release / hadolint (push) Successful in 9s
Tag Release / test (push) Successful in 16s
Tag Release / build-push (push) Successful in 42s
Main Release / hadolint (push) Successful in 12s
Reviewed-on: #13
2026-06-29 12:11:59 -04:00
Sagent 7900615c0a fix: ensure cache directory is writable by www-data
PR Checks / hadolint (pull_request) Successful in 8s
PR Checks / build-test (pull_request) Successful in 14s
2026-06-29 16:10:20 +00:00
jcabillot 1c2e971560 Merge pull request 'ci: align workflows with mydl pattern' (#12) from fix/ci-align-mydl into master
Main Release / test (push) Successful in 24s
Main Release / build (push) Successful in 11s
Main Release / tag (push) Successful in 13s
Tag Release / hadolint (push) Successful in 8s
Tag Release / test (push) Successful in 14s
Tag Release / build-push (push) Successful in 53s
Main Release / hadolint (push) Successful in 7s
Reviewed-on: #12
2026-06-29 09:50:06 -04:00
Sagent 9ceb562b81 ci: align workflows with mydl + fix Alpine SHELL
PR Checks / hadolint (pull_request) Successful in 9s
PR Checks / build-test (pull_request) Successful in 20s
2026-06-29 13:45:50 +00:00
jcabillot 07c24eed7c Merge pull request 'fix: migrate from jcabillot/phpapache to dunglas/frankenphp' (#10) from fix/frankenphp-migration into master
Main Release / hadolint (push) Successful in 11s
Tag Release / tag (push) Failing after 14s
Main Release / build-push (push) Failing after 40s
Reviewed-on: #10
2026-06-29 09:32:53 -04:00
6 changed files with 95 additions and 68 deletions
+18 -7
View File
@@ -1,38 +1,49 @@
name: Nightly Rebuild name: Nightly Rebuild
on: on:
schedule: schedule:
- cron: '0 0 * * *' - cron: '0 0 * * *'
jobs: jobs:
hadolint: hadolint:
runs-on: ubuntu-latest runs-on: ubuntu-latest
continue-on-error: true
steps: steps:
- uses: actions/checkout@9c091bb21b7c1c1d1991bb908d89e4e9dddfe3e0 # v7 - uses: actions/checkout@9c091bb21b7c1c1d1991bb908d89e4e9dddfe3e0 # v7
- uses: hadolint/hadolint-action@2332a7b74a6de0dda2e2221d575162eba76ba5e5 # v3.3.0 - uses: hadolint/hadolint-action@2332a7b74a6de0dda2e2221d575162eba76ba5e5 # v3.3.0
continue-on-error: true
with: with:
dockerfile: Dockerfile dockerfile: Dockerfile
test:
build-push:
runs-on: ubuntu-latest runs-on: ubuntu-latest
steps: steps:
- uses: actions/checkout@9c091bb21b7c1c1d1991bb908d89e4e9dddfe3e0 # v7 - uses: actions/checkout@9c091bb21b7c1c1d1991bb908d89e4e9dddfe3e0 # v7
- uses: docker/setup-buildx-action@d7f5e7f509e45cec5c76c4d5afdd7de93d0b3df5 # v4 - uses: docker/setup-buildx-action@d7f5e7f509e45cec5c76c4d5afdd7de93d0b3df5 # v4
- run: docker build --load -t ci-image:${{ github.sha }} .
- run: bash tests/test.sh ci-image:${{ github.sha }}
build-push:
needs: [test]
runs-on: ubuntu-latest
steps:
- uses: actions/checkout@9c091bb21b7c1c1d1991bb908d89e4e9dddfe3e0 # v7
with:
fetch-depth: 0
- uses: docker/setup-buildx-action@d7f5e7f509e45cec5c76c4d5afdd7de93d0b3df5 # v4
- uses: docker/login-action@650006c6eb7dba73a995cc03b0b2d7f5ca915bee # v4 - uses: docker/login-action@650006c6eb7dba73a995cc03b0b2d7f5ca915bee # v4
with: with:
username: ${{ secrets.DOCKERHUB_USERNAME }} username: ${{ secrets.DOCKERHUB_USERNAME }}
password: ${{ secrets.DOCKERHUB_TOKEN }} password: ${{ secrets.DOCKERHUB_TOKEN }}
- id: get-latest-tag
run: |
TAG=$(git describe --tags --abbrev=0 2>/dev/null || echo "")
echo "tag=$TAG" >> $GITHUB_OUTPUT
- id: meta - id: meta
uses: docker/metadata-action@80c7e94dd9b9319bd5eb7a0e0fe9291e23a2a2e9 # v6 uses: docker/metadata-action@80c7e94dd9b9319bd5eb7a0e0fe9291e23a2a2e9 # v6
with: with:
images: jcabillot/rssbridge images: jcabillot/rssbridge
tags: | tags: |
type=raw,value=nightly type=raw,value=${{ steps.get-latest-tag.outputs.tag }}-latest,enable=${{ steps.get-latest-tag.outputs.tag != '' }}
type=sha
- uses: docker/build-push-action@f9f3042f7e2789586610d6e8b85c8f03e5195baf # v7.2.0 - uses: docker/build-push-action@f9f3042f7e2789586610d6e8b85c8f03e5195baf # v7.2.0
with: with:
context: . context: .
push: true push: true
tags: ${{ steps.meta.outputs.tags }} tags: ${{ steps.meta.outputs.tags }}
labels: ${{ steps.meta.outputs.labels }} labels: ${{ steps.meta.outputs.labels }}
pull: true
+27 -21
View File
@@ -1,38 +1,44 @@
name: Main Release name: Main Release
on: on:
push: push:
branches: [master] branches: [master]
jobs: jobs:
hadolint: hadolint:
runs-on: ubuntu-latest runs-on: ubuntu-latest
continue-on-error: true
steps: steps:
- uses: actions/checkout@9c091bb21b7c1c1d1991bb908d89e4e9dddfe3e0 # v7 - uses: actions/checkout@9c091bb21b7c1c1d1991bb908d89e4e9dddfe3e0 # v7
- uses: hadolint/hadolint-action@2332a7b74a6de0dda2e2221d575162eba76ba5e5 # v3.3.0 - uses: hadolint/hadolint-action@2332a7b74a6de0dda2e2221d575162eba76ba5e5 # v3.3.0
continue-on-error: true
with: with:
dockerfile: Dockerfile dockerfile: Dockerfile
test:
build-push:
runs-on: ubuntu-latest runs-on: ubuntu-latest
steps: steps:
- uses: actions/checkout@9c091bb21b7c1c1d1991bb908d89e4e9dddfe3e0 # v7 - uses: actions/checkout@9c091bb21b7c1c1d1991bb908d89e4e9dddfe3e0 # v7
- uses: docker/setup-buildx-action@d7f5e7f509e45cec5c76c4d5afdd7de93d0b3df5 # v4 - uses: docker/setup-buildx-action@d7f5e7f509e45cec5c76c4d5afdd7de93d0b3df5 # v4
- uses: docker/login-action@650006c6eb7dba73a995cc03b0b2d7f5ca915bee # v4 - run: docker build --load -t ci-image:${{ github.sha }} .
- run: bash tests/test.sh ci-image:${{ github.sha }}
build:
needs: [test]
runs-on: ubuntu-latest
steps:
- uses: actions/checkout@9c091bb21b7c1c1d1991bb908d89e4e9dddfe3e0 # v7
- uses: docker/setup-buildx-action@d7f5e7f509e45cec5c76c4d5afdd7de93d0b3df5 # v4
- run: docker build -t jcabillot/rssbridge:${{ github.sha }} .
tag:
needs: [build]
runs-on: ubuntu-latest
steps:
- uses: actions/checkout@9c091bb21b7c1c1d1991bb908d89e4e9dddfe3e0 # v7
with: with:
username: ${{ secrets.DOCKERHUB_USERNAME }} fetch-depth: 0
password: ${{ secrets.DOCKERHUB_TOKEN }} - name: Configure git auth
- id: meta run: |
uses: docker/metadata-action@80c7e94dd9b9319bd5eb7a0e0fe9291e23a2a2e9 # v6 git remote set-url origin "https://x-access-token:${{ secrets.SA_TOKEN_ACTION_PUSH_TAGS }}@scm.cabillot.eu/web/rssbridge.git"
with: - uses: anothrNick/github-tag-action@4ed44965e0db8dab2b466a16da04aec3cc312fd8 # v1.75.0
images: jcabillot/rssbridge env:
tags: | GITHUB_TOKEN: ${{ secrets.SA_TOKEN_ACTION_PUSH_TAGS }}
type=raw,value=latest,enable=${{ github.ref == 'refs/heads/master' }} DEFAULT_BUMP: patch
type=sha RELEASE_BRANCHES: master
- uses: docker/build-push-action@f9f3042f7e2789586610d6e8b85c8f03e5195baf # v7.2.0 WITH_V: true
with: GIT_API_TAGGING: false
context: .
push: true
tags: ${{ steps.meta.outputs.tags }}
labels: ${{ steps.meta.outputs.labels }}
+8 -3
View File
@@ -1,15 +1,20 @@
name: PR Checks name: PR Checks
on: on:
pull_request: pull_request:
branches: [master] branches: [master]
jobs: jobs:
hadolint: hadolint:
runs-on: ubuntu-latest runs-on: ubuntu-latest
continue-on-error: true
steps: steps:
- uses: actions/checkout@9c091bb21b7c1c1d1991bb908d89e4e9dddfe3e0 # v7 - uses: actions/checkout@9c091bb21b7c1c1d1991bb908d89e4e9dddfe3e0 # v7
- uses: hadolint/hadolint-action@2332a7b74a6de0dda2e2221d575162eba76ba5e5 # v3.3.0 - uses: hadolint/hadolint-action@2332a7b74a6de0dda2e2221d575162eba76ba5e5 # v3.3.0
continue-on-error: true
with: with:
dockerfile: Dockerfile dockerfile: Dockerfile
build-test:
runs-on: ubuntu-latest
steps:
- uses: actions/checkout@9c091bb21b7c1c1d1991bb908d89e4e9dddfe3e0 # v7
- uses: docker/setup-buildx-action@d7f5e7f509e45cec5c76c4d5afdd7de93d0b3df5 # v4
- run: docker build --load -t ci-image:${{ github.sha }} .
- run: bash tests/test.sh ci-image:${{ github.sha }}
+36 -13
View File
@@ -1,21 +1,44 @@
name: Tag Release name: Tag Release
on: on:
push: push:
branches: [master] tags: ['*']
jobs: jobs:
tag: hadolint:
runs-on: ubuntu-latest runs-on: ubuntu-latest
steps: steps:
- uses: actions/checkout@9c091bb21b7c1c1d1991bb908d89e4e9dddfe3e0 # v7 - uses: actions/checkout@9c091bb21b7c1c1d1991bb908d89e4e9dddfe3e0 # v7
- uses: hadolint/hadolint-action@2332a7b74a6de0dda2e2221d575162eba76ba5e5 # v3.3.0
continue-on-error: true
with: with:
fetch-depth: 0 dockerfile: Dockerfile
- name: Bump version and push tag test:
uses: anothrNick/github-tag-action@4ed44965e0db8dab2b466a16da04aec3cc312fd8 # v1 runs-on: ubuntu-latest
env: steps:
GITHUB_TOKEN: ${{ secrets.GITHUB_TOKEN }} - uses: actions/checkout@9c091bb21b7c1c1d1991bb908d89e4e9dddfe3e0 # v7
DEFAULT_BUMP: patch - uses: docker/setup-buildx-action@d7f5e7f509e45cec5c76c4d5afdd7de93d0b3df5 # v4
RELEASE_BRANCHES: master - run: docker build --load -t ci-image:${{ github.sha }} .
WITH_V: true - run: bash tests/test.sh ci-image:${{ github.sha }}
GIT_API_TAGGING: false build-push:
needs: [test]
runs-on: ubuntu-latest
steps:
- uses: actions/checkout@9c091bb21b7c1c1d1991bb908d89e4e9dddfe3e0 # v7
- uses: docker/setup-buildx-action@d7f5e7f509e45cec5c76c4d5afdd7de93d0b3df5 # v4
- uses: docker/login-action@650006c6eb7dba73a995cc03b0b2d7f5ca915bee # v4
with:
username: ${{ secrets.DOCKERHUB_USERNAME }}
password: ${{ secrets.DOCKERHUB_TOKEN }}
- id: meta
uses: docker/metadata-action@80c7e94dd9b9319bd5eb7a0e0fe9291e23a2a2e9 # v6
with:
images: jcabillot/rssbridge
tags: |
type=ref,event=tag
type=ref,event=tag,suffix=-latest
- uses: docker/build-push-action@f9f3042f7e2789586610d6e8b85c8f03e5195baf # v7.2.0
with:
context: .
push: true
tags: ${{ steps.meta.outputs.tags }}
labels: ${{ steps.meta.outputs.labels }}
pull: true
+6 -7
View File
@@ -1,8 +1,6 @@
FROM dunglas/frankenphp:1-php8.5-alpine FROM dunglas/frankenphp:1-php8.5-alpine
LABEL maintainer="Julien Cabillot <dockerimages@cabillot.eu>" LABEL maintainer="Julien Cabillot <dockerimages@cabillot.eu>"
SHELL ["/bin/bash", "-o", "pipefail", "-c"]
WORKDIR /app WORKDIR /app
# Install required PHP extensions for RSS-Bridge # Install required PHP extensions for RSS-Bridge
@@ -10,14 +8,15 @@ RUN install-php-extensions mbstring simplexml curl json iconv
COPY Caddyfile /etc/frankenphp/Caddyfile COPY Caddyfile /etc/frankenphp/Caddyfile
# Download RSS-Bridge # Download RSS-Bridge (two-step to avoid pipefail dependency)
RUN curl -s -L "https://github.com/RSS-Bridge/rss-bridge/tarball/master/" | tar -zx --strip=1 -C /app/public RUN curl -s -L "https://github.com/RSS-Bridge/rss-bridge/tarball/master/" -o /tmp/rssbridge.tar && \
tar -zx --strip=1 -C /app/public -f /tmp/rssbridge.tar && \
rm /tmp/rssbridge.tar
# Configure RSS-Bridge # Configure RSS-Bridge
RUN echo "*" > "/app/public/whitelist.txt" && \ RUN echo "*" > "/app/public/whitelist.txt" && \
mkdir -p /app/public/cache && \ mkdir -p /app/public/cache && \
chown -R www-data:www-data /app/public chown -R www-data:www-data /app/public && \
chmod -R 775 /app/public/cache
RUN chown www-data:www-data /data/caddy && chmod 2770 /data/caddy
USER www-data USER www-data
-17
View File
@@ -1,17 +0,0 @@
{
"$schema": "https://docs.renovatebot.com/renovate-schema.json",
"customManagers": [
{
"customType": "regex",
"description": "Detect ARG VERSION pin for jcabillot/phpapache base image",
"managerFilePatterns": [
"/^Dockerfile$/"
],
"matchStrings": [
"ARG\\s+VERSION=\"(?<currentValue>[^\"]+)\""
],
"depNameTemplate": "jcabillot/phpapache",
"datasourceTemplate": "docker"
}
]
}