mirror of
https://github.com/linuxserver/docker-heimdall.git
synced 2026-04-05 11:06:33 +09:00
Compare commits
198 Commits
developmen
...
developmen
| Author | SHA1 | Date | |
|---|---|---|---|
|
|
99167880f4 | ||
|
|
194148f8bd | ||
|
|
9dfb57d19a | ||
|
|
3d23197670 | ||
|
|
39ae72645c | ||
|
|
531a251720 | ||
|
|
83c73029f6 | ||
|
|
d43ebded70 | ||
|
|
5d6fbcd004 | ||
|
|
0b9fc0396a | ||
|
|
24b8da221c | ||
|
|
bc944c0b75 | ||
|
|
efcb43e748 | ||
|
|
99020d7ba6 | ||
|
|
d18723b1c3 | ||
|
|
d2ea4012ff | ||
|
|
5975a7fc09 | ||
|
|
aaebd68d2b | ||
|
|
fede19fabe | ||
|
|
ec06dfbb1f | ||
|
|
27246bd4b0 | ||
|
|
90150e342a | ||
|
|
e4241eece8 | ||
|
|
41d4456605 | ||
|
|
5a10d8f3c0 | ||
|
|
dc4e1a3283 | ||
|
|
6a0e955c37 | ||
|
|
a57c4aacc8 | ||
|
|
ffdf07fb6c | ||
|
|
6b66c8ad06 | ||
|
|
bf48a950f4 | ||
|
|
33b32112ce | ||
|
|
bfe892c486 | ||
|
|
9e9e2d66e3 | ||
|
|
7ede2d01f9 | ||
|
|
ec8c19d4d0 | ||
|
|
8abdf117bb | ||
|
|
b8a13c24fd | ||
|
|
e1b7ff630a | ||
|
|
85b5c2b49c | ||
|
|
e98fb76b5e | ||
|
|
e14be89a3d | ||
|
|
ad5b8d1055 | ||
|
|
634e06c925 | ||
|
|
e94c72db59 | ||
|
|
dc94aaeb18 | ||
|
|
91094b3d8a | ||
|
|
3b56747736 | ||
|
|
9d0cd0cccb | ||
|
|
dba06dc313 | ||
|
|
f871f9cffb | ||
|
|
cc172f5532 | ||
|
|
f2ab9d7bd4 | ||
|
|
0f518fb2ff | ||
|
|
238962b372 | ||
|
|
6e6011ca83 | ||
|
|
780c98979a | ||
|
|
a0f68066c2 | ||
|
|
dfabf2eede | ||
|
|
9c28a7f738 | ||
|
|
04488583cd | ||
|
|
2c05453937 | ||
|
|
1cc3130021 | ||
|
|
29b552ead4 | ||
|
|
ce8dfe9941 | ||
|
|
f0936015bc | ||
|
|
4861eda2d3 | ||
|
|
a509328395 | ||
|
|
da90a88ddb | ||
|
|
f380906965 | ||
|
|
bf8cad83a2 | ||
|
|
a8bf32ca02 | ||
|
|
ce6b1284df | ||
|
|
dd3a2c1436 | ||
|
|
8dfbfd407b | ||
|
|
97b362c53b | ||
|
|
dc819e40e2 | ||
|
|
481b5eeacb | ||
|
|
43096092e1 | ||
|
|
3c1ed055ad | ||
|
|
d2133e3a45 | ||
|
|
1ff5ea8b10 | ||
|
|
5c49302a39 | ||
|
|
e413bfa5c0 | ||
|
|
8c3587b7c3 | ||
|
|
91d6a63bcf | ||
|
|
23752f9ba4 | ||
|
|
19c606439d | ||
|
|
421a86103b | ||
|
|
740c467147 | ||
|
|
767cc6637f | ||
|
|
2835692143 | ||
|
|
b9c10d0c3f | ||
|
|
3367ea93f0 | ||
|
|
ae633adcd2 | ||
|
|
aff35b0195 | ||
|
|
fd57557021 | ||
|
|
8e6a2394a6 | ||
|
|
ab650ac006 | ||
|
|
3f23522949 | ||
|
|
ed36cb689e | ||
|
|
645959d5a1 | ||
|
|
523d744f8a | ||
|
|
49ec00127e | ||
|
|
b8e058679e | ||
|
|
6ebaf00cb6 | ||
|
|
9f0cb3aa38 | ||
|
|
e10521f93e | ||
|
|
b25194e490 | ||
|
|
475c877c76 | ||
|
|
45367a03b6 | ||
|
|
2f3d7bdd94 | ||
|
|
7166a2b229 | ||
|
|
4ee9ea84b9 | ||
|
|
4d728e90a3 | ||
|
|
ed8c89fc22 | ||
|
|
b2078bfbf6 | ||
|
|
fff281c5b8 | ||
|
|
9aa3cce066 | ||
|
|
09b457bbd4 | ||
|
|
13955c751d | ||
|
|
723df80461 | ||
|
|
3d0d91cad8 | ||
|
|
86015b2bb6 | ||
|
|
9d09f09b65 | ||
|
|
3952031cc4 | ||
|
|
65032223b6 | ||
|
|
c7475c8fe6 | ||
|
|
181d9c4aed | ||
|
|
51ffe0c841 | ||
|
|
e04a704803 | ||
|
|
08127222fa | ||
|
|
0d894f8ca8 | ||
|
|
6ff1368f5f | ||
|
|
65c299b32f | ||
|
|
6aa0b5611d | ||
|
|
fc295cdcad | ||
|
|
d9800ee920 | ||
|
|
5fbe7b8c94 | ||
|
|
450b8c49ae | ||
|
|
d0c3c7fb32 | ||
|
|
18594c2e33 | ||
|
|
27b68856c7 | ||
|
|
9905ef8a45 | ||
|
|
157c18a81a | ||
|
|
80ed370549 | ||
|
|
5544a0e7dd | ||
|
|
74f43c96f6 | ||
|
|
6cb41d570e | ||
|
|
dc1f719285 | ||
|
|
2a6b03eca7 | ||
|
|
5365f6181d | ||
|
|
c91ac478c9 | ||
|
|
369ba1c41b | ||
|
|
88e7e1df09 | ||
|
|
a694621f78 | ||
|
|
0a0c8862f6 | ||
|
|
649f2b09a7 | ||
|
|
1ab60fda12 | ||
|
|
67b8da2a27 | ||
|
|
9da87dc8cf | ||
|
|
1de91cfbd0 | ||
|
|
19c0db5c97 | ||
|
|
5498349626 | ||
|
|
eabd8a6738 | ||
|
|
82f1f4d934 | ||
|
|
7237d6ca9a | ||
|
|
2275a8fb64 | ||
|
|
d545593107 | ||
|
|
34f7492c97 | ||
|
|
134b3e9533 | ||
|
|
8217bd55ea | ||
|
|
1761816c42 | ||
|
|
ab5fc6b23d | ||
|
|
f9d2fca42c | ||
|
|
fbe856fab3 | ||
|
|
5a251cd21c | ||
|
|
19e3093840 | ||
|
|
3e5d65217a | ||
|
|
1e5c88de48 | ||
|
|
44612aa569 | ||
|
|
8706d29fe0 | ||
|
|
136dbe61bf | ||
|
|
5977b7440e | ||
|
|
d04a852a8d | ||
|
|
a636e8534c | ||
|
|
c5693232f4 | ||
|
|
6d7fad2d98 | ||
|
|
204bad5de9 | ||
|
|
3779275528 | ||
|
|
c4ab19e354 | ||
|
|
4ebb4da3fd | ||
|
|
0a2d097510 | ||
|
|
0852efa2bd | ||
|
|
c2ffc6c11d | ||
|
|
29a9ac0088 | ||
|
|
d05fc41a78 | ||
|
|
1ed4b08da3 |
0
.editorconfig
Executable file → Normal file
0
.editorconfig
Executable file → Normal file
6
.github/CONTRIBUTING.md
vendored
Executable file → Normal file
6
.github/CONTRIBUTING.md
vendored
Executable file → Normal file
@@ -6,7 +6,7 @@
|
|||||||
* Read, and fill the Pull Request template
|
* Read, and fill the Pull Request template
|
||||||
* If this is a fix for a typo (in code, documentation, or the README) please file an issue and let us sort it out. We do not need a PR
|
* If this is a fix for a typo (in code, documentation, or the README) please file an issue and let us sort it out. We do not need a PR
|
||||||
* If the PR is addressing an existing issue include, closes #\<issue number>, in the body of the PR commit message
|
* If the PR is addressing an existing issue include, closes #\<issue number>, in the body of the PR commit message
|
||||||
* If you want to discuss changes, you can also bring it up in [#dev-talk](https://discordapp.com/channels/354974912613449730/757585807061155840) in our [Discord server](https://discord.gg/YWrKVTn)
|
* If you want to discuss changes, you can also bring it up in [#dev-talk](https://discordapp.com/channels/354974912613449730/757585807061155840) in our [Discord server](https://linuxserver.io/discord)
|
||||||
|
|
||||||
## Common files
|
## Common files
|
||||||
|
|
||||||
@@ -105,10 +105,10 @@ docker build \
|
|||||||
-t linuxserver/heimdall:latest .
|
-t linuxserver/heimdall:latest .
|
||||||
```
|
```
|
||||||
|
|
||||||
The ARM variants can be built on x86_64 hardware using `multiarch/qemu-user-static`
|
The ARM variants can be built on x86_64 hardware and vice versa using `lscr.io/linuxserver/qemu-static`
|
||||||
|
|
||||||
```bash
|
```bash
|
||||||
docker run --rm --privileged multiarch/qemu-user-static:register --reset
|
docker run --rm --privileged lscr.io/linuxserver/qemu-static --reset
|
||||||
```
|
```
|
||||||
|
|
||||||
Once registered you can define the dockerfile to use with `-f Dockerfile.aarch64`.
|
Once registered you can define the dockerfile to use with `-f Dockerfile.aarch64`.
|
||||||
|
|||||||
0
.github/FUNDING.yml
vendored
Executable file → Normal file
0
.github/FUNDING.yml
vendored
Executable file → Normal file
2
.github/ISSUE_TEMPLATE/config.yml
vendored
Executable file → Normal file
2
.github/ISSUE_TEMPLATE/config.yml
vendored
Executable file → Normal file
@@ -1,7 +1,7 @@
|
|||||||
blank_issues_enabled: false
|
blank_issues_enabled: false
|
||||||
contact_links:
|
contact_links:
|
||||||
- name: Discord chat support
|
- name: Discord chat support
|
||||||
url: https://discord.gg/YWrKVTn
|
url: https://linuxserver.io/discord
|
||||||
about: Realtime support / chat with the community and the team.
|
about: Realtime support / chat with the community and the team.
|
||||||
|
|
||||||
- name: Discourse discussion forum
|
- name: Discourse discussion forum
|
||||||
|
|||||||
5
.github/ISSUE_TEMPLATE/issue.bug.yml
vendored
Executable file → Normal file
5
.github/ISSUE_TEMPLATE/issue.bug.yml
vendored
Executable file → Normal file
@@ -53,7 +53,6 @@ body:
|
|||||||
options:
|
options:
|
||||||
- x86-64
|
- x86-64
|
||||||
- arm64
|
- arm64
|
||||||
- armhf
|
|
||||||
validations:
|
validations:
|
||||||
required: true
|
required: true
|
||||||
- type: textarea
|
- type: textarea
|
||||||
@@ -68,10 +67,10 @@ body:
|
|||||||
- type: textarea
|
- type: textarea
|
||||||
attributes:
|
attributes:
|
||||||
description: |
|
description: |
|
||||||
Provide a full docker log, output of "docker logs linuxserver.io"
|
Provide a full docker log, output of "docker logs heimdall"
|
||||||
label: Container logs
|
label: Container logs
|
||||||
placeholder: |
|
placeholder: |
|
||||||
Output of `docker logs linuxserver.io`
|
Output of `docker logs heimdall`
|
||||||
render: bash
|
render: bash
|
||||||
validations:
|
validations:
|
||||||
required: true
|
required: true
|
||||||
|
|||||||
0
.github/ISSUE_TEMPLATE/issue.feature.yml
vendored
Executable file → Normal file
0
.github/ISSUE_TEMPLATE/issue.feature.yml
vendored
Executable file → Normal file
12
.github/workflows/call_invalid_helper.yml
vendored
12
.github/workflows/call_invalid_helper.yml
vendored
@@ -1,12 +0,0 @@
|
|||||||
name: Comment on invalid interaction
|
|
||||||
on:
|
|
||||||
issues:
|
|
||||||
types:
|
|
||||||
- labeled
|
|
||||||
jobs:
|
|
||||||
add-comment-on-invalid:
|
|
||||||
if: github.event.label.name == 'invalid'
|
|
||||||
permissions:
|
|
||||||
issues: write
|
|
||||||
uses: linuxserver/github-workflows/.github/workflows/invalid-interaction-helper.yml@v1
|
|
||||||
secrets: inherit
|
|
||||||
19
.github/workflows/call_issue_pr_tracker.yml
vendored
Normal file
19
.github/workflows/call_issue_pr_tracker.yml
vendored
Normal file
@@ -0,0 +1,19 @@
|
|||||||
|
name: Issue & PR Tracker
|
||||||
|
|
||||||
|
on:
|
||||||
|
issues:
|
||||||
|
types: [opened,reopened,labeled,unlabeled,closed]
|
||||||
|
pull_request_target:
|
||||||
|
types: [opened,reopened,review_requested,review_request_removed,labeled,unlabeled,closed]
|
||||||
|
pull_request_review:
|
||||||
|
types: [submitted,edited,dismissed]
|
||||||
|
|
||||||
|
permissions:
|
||||||
|
contents: read
|
||||||
|
|
||||||
|
jobs:
|
||||||
|
manage-project:
|
||||||
|
permissions:
|
||||||
|
issues: write
|
||||||
|
uses: linuxserver/github-workflows/.github/workflows/issue-pr-tracker.yml@v1
|
||||||
|
secrets: inherit
|
||||||
16
.github/workflows/call_issues_cron.yml
vendored
Normal file
16
.github/workflows/call_issues_cron.yml
vendored
Normal file
@@ -0,0 +1,16 @@
|
|||||||
|
name: Mark stale issues and pull requests
|
||||||
|
on:
|
||||||
|
schedule:
|
||||||
|
- cron: '14 15 * * *'
|
||||||
|
workflow_dispatch:
|
||||||
|
|
||||||
|
permissions:
|
||||||
|
contents: read
|
||||||
|
|
||||||
|
jobs:
|
||||||
|
stale:
|
||||||
|
permissions:
|
||||||
|
issues: write
|
||||||
|
pull-requests: write
|
||||||
|
uses: linuxserver/github-workflows/.github/workflows/issues-cron.yml@v1
|
||||||
|
secrets: inherit
|
||||||
137
.github/workflows/external_trigger.yml
vendored
Executable file → Normal file
137
.github/workflows/external_trigger.yml
vendored
Executable file → Normal file
@@ -3,24 +3,42 @@ name: External Trigger Main
|
|||||||
on:
|
on:
|
||||||
workflow_dispatch:
|
workflow_dispatch:
|
||||||
|
|
||||||
|
permissions:
|
||||||
|
contents: read
|
||||||
|
|
||||||
jobs:
|
jobs:
|
||||||
external-trigger-development:
|
external-trigger-development:
|
||||||
runs-on: ubuntu-latest
|
runs-on: ubuntu-latest
|
||||||
steps:
|
steps:
|
||||||
- uses: actions/checkout@v3.1.0
|
- uses: actions/checkout@v4.1.1
|
||||||
|
|
||||||
- name: External Trigger
|
- name: External Trigger
|
||||||
if: github.ref == 'refs/heads/development'
|
if: github.ref == 'refs/heads/development'
|
||||||
|
env:
|
||||||
|
SKIP_EXTERNAL_TRIGGER: ${{ vars.SKIP_EXTERNAL_TRIGGER }}
|
||||||
run: |
|
run: |
|
||||||
if [ -n "${{ secrets.PAUSE_EXTERNAL_TRIGGER_HEIMDALL_DEVELOPMENT }}" ]; then
|
printf "# External trigger for docker-heimdall\n\n" >> $GITHUB_STEP_SUMMARY
|
||||||
echo "**** Github secret PAUSE_EXTERNAL_TRIGGER_HEIMDALL_DEVELOPMENT is set; skipping trigger. ****"
|
if grep -q "^heimdall_development_" <<< "${SKIP_EXTERNAL_TRIGGER}"; then
|
||||||
|
echo "> [!NOTE]" >> $GITHUB_STEP_SUMMARY
|
||||||
|
echo "> Github organizational variable \`SKIP_EXTERNAL_TRIGGER\` contains \`heimdall_development_\`; will skip trigger if version matches." >> $GITHUB_STEP_SUMMARY
|
||||||
|
elif grep -q "^heimdall_development" <<< "${SKIP_EXTERNAL_TRIGGER}"; then
|
||||||
|
echo "> [!WARNING]" >> $GITHUB_STEP_SUMMARY
|
||||||
|
echo "> Github organizational variable \`SKIP_EXTERNAL_TRIGGER\` contains \`heimdall_development\`; skipping trigger." >> $GITHUB_STEP_SUMMARY
|
||||||
exit 0
|
exit 0
|
||||||
fi
|
fi
|
||||||
echo "**** External trigger running off of development branch. To disable this trigger, set a Github secret named \"PAUSE_EXTERNAL_TRIGGER_HEIMDALL_DEVELOPMENT\". ****"
|
echo "> [!NOTE]" >> $GITHUB_STEP_SUMMARY
|
||||||
echo "**** Retrieving external version ****"
|
echo "> External trigger running off of development branch. To disable this trigger, add \`heimdall_development\` into the Github organizational variable \`SKIP_EXTERNAL_TRIGGER\`." >> $GITHUB_STEP_SUMMARY
|
||||||
|
printf "\n## Retrieving external version\n\n" >> $GITHUB_STEP_SUMMARY
|
||||||
EXT_RELEASE=$(curl -u "${{ secrets.CR_USER }}:${{ secrets.CR_PAT }}" -sX GET "https://api.github.com/repos/linuxserver/Heimdall/commits/2.x" | jq -r '. | .sha' | cut -c1-8)
|
EXT_RELEASE=$(curl -u "${{ secrets.CR_USER }}:${{ secrets.CR_PAT }}" -sX GET "https://api.github.com/repos/linuxserver/Heimdall/commits/2.x" | jq -r '. | .sha' | cut -c1-8)
|
||||||
|
echo "Type is \`github_commit\`" >> $GITHUB_STEP_SUMMARY
|
||||||
|
if grep -q "^heimdall_development_${EXT_RELEASE}" <<< "${SKIP_EXTERNAL_TRIGGER}"; then
|
||||||
|
echo "> [!WARNING]" >> $GITHUB_STEP_SUMMARY
|
||||||
|
echo "> Github organizational variable \`SKIP_EXTERNAL_TRIGGER\` matches current external release; skipping trigger." >> $GITHUB_STEP_SUMMARY
|
||||||
|
exit 0
|
||||||
|
fi
|
||||||
if [ -z "${EXT_RELEASE}" ] || [ "${EXT_RELEASE}" == "null" ]; then
|
if [ -z "${EXT_RELEASE}" ] || [ "${EXT_RELEASE}" == "null" ]; then
|
||||||
echo "**** Can't retrieve external version, exiting ****"
|
echo "> [!WARNING]" >> $GITHUB_STEP_SUMMARY
|
||||||
|
echo "> Can't retrieve external version, exiting" >> $GITHUB_STEP_SUMMARY
|
||||||
FAILURE_REASON="Can't retrieve external version for heimdall branch development"
|
FAILURE_REASON="Can't retrieve external version for heimdall branch development"
|
||||||
GHA_TRIGGER_URL="https://github.com/linuxserver/docker-heimdall/actions/runs/${{ github.run_id }}"
|
GHA_TRIGGER_URL="https://github.com/linuxserver/docker-heimdall/actions/runs/${{ github.run_id }}"
|
||||||
curl -X POST -H "Content-Type: application/json" --data '{"avatar_url": "https://cdn.discordapp.com/avatars/354986384542662657/df91181b3f1cf0ef1592fbe18e0962d7.png","embeds": [{"color": 16711680,
|
curl -X POST -H "Content-Type: application/json" --data '{"avatar_url": "https://cdn.discordapp.com/avatars/354986384542662657/df91181b3f1cf0ef1592fbe18e0962d7.png","embeds": [{"color": 16711680,
|
||||||
@@ -28,24 +46,43 @@ jobs:
|
|||||||
"username": "Github Actions"}' ${{ secrets.DISCORD_WEBHOOK }}
|
"username": "Github Actions"}' ${{ secrets.DISCORD_WEBHOOK }}
|
||||||
exit 1
|
exit 1
|
||||||
fi
|
fi
|
||||||
EXT_RELEASE=$(echo ${EXT_RELEASE} | sed 's/[~,%@+;:/]//g')
|
EXT_RELEASE_SANITIZED=$(echo ${EXT_RELEASE} | sed 's/[~,%@+;:/]//g')
|
||||||
echo "**** External version: ${EXT_RELEASE} ****"
|
echo "Sanitized external version: \`${EXT_RELEASE_SANITIZED}\`" >> $GITHUB_STEP_SUMMARY
|
||||||
echo "**** Retrieving last pushed version ****"
|
echo "Retrieving last pushed version" >> $GITHUB_STEP_SUMMARY
|
||||||
image="linuxserver/heimdall"
|
image="linuxserver/heimdall"
|
||||||
tag="development"
|
tag="development"
|
||||||
token=$(curl -sX GET \
|
token=$(curl -sX GET \
|
||||||
"https://ghcr.io/token?scope=repository%3Alinuxserver%2Fheimdall%3Apull" \
|
"https://ghcr.io/token?scope=repository%3Alinuxserver%2Fheimdall%3Apull" \
|
||||||
| jq -r '.token')
|
| jq -r '.token')
|
||||||
multidigest=$(curl -s \
|
multidigest=$(curl -s \
|
||||||
|
--header "Accept: application/vnd.docker.distribution.manifest.v2+json" \
|
||||||
|
--header "Accept: application/vnd.oci.image.index.v1+json" \
|
||||||
|
--header "Authorization: Bearer ${token}" \
|
||||||
|
"https://ghcr.io/v2/${image}/manifests/${tag}")
|
||||||
|
if jq -e '.layers // empty' <<< "${multidigest}" >/dev/null 2>&1; then
|
||||||
|
# If there's a layer element it's a single-arch manifest so just get that digest
|
||||||
|
digest=$(jq -r '.config.digest' <<< "${multidigest}")
|
||||||
|
else
|
||||||
|
# Otherwise it's multi-arch or has manifest annotations
|
||||||
|
if jq -e '.manifests[]?.annotations // empty' <<< "${multidigest}" >/dev/null 2>&1; then
|
||||||
|
# Check for manifest annotations and delete if found
|
||||||
|
multidigest=$(jq 'del(.manifests[] | select(.annotations))' <<< "${multidigest}")
|
||||||
|
fi
|
||||||
|
if [[ $(jq '.manifests | length' <<< "${multidigest}") -gt 1 ]]; then
|
||||||
|
# If there's still more than one digest, it's multi-arch
|
||||||
|
multidigest=$(jq -r ".manifests[] | select(.platform.architecture == \"amd64\").digest?" <<< "${multidigest}")
|
||||||
|
else
|
||||||
|
# Otherwise it's single arch
|
||||||
|
multidigest=$(jq -r ".manifests[].digest?" <<< "${multidigest}")
|
||||||
|
fi
|
||||||
|
if digest=$(curl -s \
|
||||||
--header "Accept: application/vnd.docker.distribution.manifest.v2+json" \
|
--header "Accept: application/vnd.docker.distribution.manifest.v2+json" \
|
||||||
|
--header "Accept: application/vnd.oci.image.manifest.v1+json" \
|
||||||
--header "Authorization: Bearer ${token}" \
|
--header "Authorization: Bearer ${token}" \
|
||||||
"https://ghcr.io/v2/${image}/manifests/${tag}" \
|
"https://ghcr.io/v2/${image}/manifests/${multidigest}"); then
|
||||||
| jq -r 'first(.manifests[].digest)')
|
digest=$(jq -r '.config.digest' <<< "${digest}");
|
||||||
digest=$(curl -s \
|
fi
|
||||||
--header "Accept: application/vnd.docker.distribution.manifest.v2+json" \
|
fi
|
||||||
--header "Authorization: Bearer ${token}" \
|
|
||||||
"https://ghcr.io/v2/${image}/manifests/${multidigest}" \
|
|
||||||
| jq -r '.config.digest')
|
|
||||||
image_info=$(curl -sL \
|
image_info=$(curl -sL \
|
||||||
--header "Authorization: Bearer ${token}" \
|
--header "Authorization: Bearer ${token}" \
|
||||||
"https://ghcr.io/v2/${image}/blobs/${digest}")
|
"https://ghcr.io/v2/${image}/blobs/${digest}")
|
||||||
@@ -57,40 +94,54 @@ jobs:
|
|||||||
IMAGE_RELEASE=$(echo ${image_info} | jq -r '.Labels.build_version' | awk '{print $3}')
|
IMAGE_RELEASE=$(echo ${image_info} | jq -r '.Labels.build_version' | awk '{print $3}')
|
||||||
IMAGE_VERSION=$(echo ${IMAGE_RELEASE} | awk -F'-ls' '{print $1}')
|
IMAGE_VERSION=$(echo ${IMAGE_RELEASE} | awk -F'-ls' '{print $1}')
|
||||||
if [ -z "${IMAGE_VERSION}" ]; then
|
if [ -z "${IMAGE_VERSION}" ]; then
|
||||||
echo "**** Can't retrieve last pushed version, exiting ****"
|
echo "> [!WARNING]" >> $GITHUB_STEP_SUMMARY
|
||||||
|
echo "Can't retrieve last pushed version, exiting" >> $GITHUB_STEP_SUMMARY
|
||||||
FAILURE_REASON="Can't retrieve last pushed version for heimdall tag development"
|
FAILURE_REASON="Can't retrieve last pushed version for heimdall tag development"
|
||||||
curl -X POST -H "Content-Type: application/json" --data '{"avatar_url": "https://cdn.discordapp.com/avatars/354986384542662657/df91181b3f1cf0ef1592fbe18e0962d7.png","embeds": [{"color": 16711680,
|
curl -X POST -H "Content-Type: application/json" --data '{"avatar_url": "https://cdn.discordapp.com/avatars/354986384542662657/df91181b3f1cf0ef1592fbe18e0962d7.png","embeds": [{"color": 16711680,
|
||||||
"description": "**Trigger Failed** \n**Reason:** '"${FAILURE_REASON}"' \n"}],
|
"description": "**Trigger Failed** \n**Reason:** '"${FAILURE_REASON}"' \n"}],
|
||||||
"username": "Github Actions"}' ${{ secrets.DISCORD_WEBHOOK }}
|
"username": "Github Actions"}' ${{ secrets.DISCORD_WEBHOOK }}
|
||||||
exit 1
|
exit 1
|
||||||
fi
|
fi
|
||||||
echo "**** Last pushed version: ${IMAGE_VERSION} ****"
|
echo "Last pushed version: \`${IMAGE_VERSION}\`" >> $GITHUB_STEP_SUMMARY
|
||||||
if [ "${EXT_RELEASE}" == "${IMAGE_VERSION}" ]; then
|
if [ "${EXT_RELEASE_SANITIZED}" == "${IMAGE_VERSION}" ]; then
|
||||||
echo "**** Version ${EXT_RELEASE} already pushed, exiting ****"
|
echo "Sanitized version \`${EXT_RELEASE_SANITIZED}\` already pushed, exiting" >> $GITHUB_STEP_SUMMARY
|
||||||
exit 0
|
exit 0
|
||||||
elif [ $(curl -s https://ci.linuxserver.io/job/Docker-Pipeline-Builders/job/docker-heimdall/job/development/lastBuild/api/json | jq -r '.building') == "true" ]; then
|
elif [ $(curl -s https://ci.linuxserver.io/job/Docker-Pipeline-Builders/job/docker-heimdall/job/development/lastBuild/api/json | jq -r '.building') == "true" ]; then
|
||||||
echo "**** New version ${EXT_RELEASE} found; but there already seems to be an active build on Jenkins; exiting ****"
|
echo "New version \`${EXT_RELEASE}\` found; but there already seems to be an active build on Jenkins; exiting" >> $GITHUB_STEP_SUMMARY
|
||||||
exit 0
|
exit 0
|
||||||
else
|
else
|
||||||
echo "**** New version ${EXT_RELEASE} found; old version was ${IMAGE_VERSION}. Triggering new build ****"
|
if [[ "${artifacts_found}" == "false" ]]; then
|
||||||
response=$(curl -iX POST \
|
echo "> [!WARNING]" >> $GITHUB_STEP_SUMMARY
|
||||||
https://ci.linuxserver.io/job/Docker-Pipeline-Builders/job/docker-heimdall/job/development/buildWithParameters?PACKAGE_CHECK=false \
|
echo "> New version detected, but not all artifacts are published yet; skipping trigger" >> $GITHUB_STEP_SUMMARY
|
||||||
--user ${{ secrets.JENKINS_USER }}:${{ secrets.JENKINS_TOKEN }} | grep -i location | sed "s|^[L|l]ocation: \(.*\)|\1|")
|
FAILURE_REASON="New version ${EXT_RELEASE} for heimdall tag development is detected, however not all artifacts are uploaded to upstream release yet. Will try again later."
|
||||||
echo "**** Jenkins job queue url: ${response%$'\r'} ****"
|
curl -X POST -H "Content-Type: application/json" --data '{"avatar_url": "https://cdn.discordapp.com/avatars/354986384542662657/df91181b3f1cf0ef1592fbe18e0962d7.png","embeds": [{"color": 9802903,
|
||||||
echo "**** Sleeping 10 seconds until job starts ****"
|
"description": "**Trigger Failed** \n**Reason:** '"${FAILURE_REASON}"' \n"}],
|
||||||
sleep 10
|
"username": "Github Actions"}' ${{ secrets.DISCORD_WEBHOOK }}
|
||||||
buildurl=$(curl -s "${response%$'\r'}api/json" | jq -r '.executable.url')
|
else
|
||||||
buildurl="${buildurl%$'\r'}"
|
printf "\n## Trigger new build\n\n" >> $GITHUB_STEP_SUMMARY
|
||||||
echo "**** Jenkins job build url: ${buildurl} ****"
|
echo "New sanitized version \`${EXT_RELEASE_SANITIZED}\` found; old version was \`${IMAGE_VERSION}\`. Triggering new build" >> $GITHUB_STEP_SUMMARY
|
||||||
echo "**** Attempting to change the Jenkins job description ****"
|
if [[ "${artifacts_found}" == "true" ]]; then
|
||||||
curl -iX POST \
|
echo "All artifacts seem to be uploaded." >> $GITHUB_STEP_SUMMARY
|
||||||
"${buildurl}submitDescription" \
|
fi
|
||||||
--user ${{ secrets.JENKINS_USER }}:${{ secrets.JENKINS_TOKEN }} \
|
response=$(curl -iX POST \
|
||||||
--data-urlencode "description=GHA external trigger https://github.com/${{ github.repository }}/actions/runs/${{ github.run_id }}" \
|
https://ci.linuxserver.io/job/Docker-Pipeline-Builders/job/docker-heimdall/job/development/buildWithParameters?PACKAGE_CHECK=false \
|
||||||
--data-urlencode "Submit=Submit"
|
--user ${{ secrets.JENKINS_USER }}:${{ secrets.JENKINS_TOKEN }} | grep -i location | sed "s|^[L|l]ocation: \(.*\)|\1|")
|
||||||
echo "**** Notifying Discord ****"
|
echo "Jenkins [job queue url](${response%$'\r'})" >> $GITHUB_STEP_SUMMARY
|
||||||
TRIGGER_REASON="A version change was detected for heimdall tag development. Old version:${IMAGE_VERSION} New version:${EXT_RELEASE}"
|
echo "Sleeping 10 seconds until job starts" >> $GITHUB_STEP_SUMMARY
|
||||||
curl -X POST -H "Content-Type: application/json" --data '{"avatar_url": "https://cdn.discordapp.com/avatars/354986384542662657/df91181b3f1cf0ef1592fbe18e0962d7.png","embeds": [{"color": 9802903,
|
sleep 10
|
||||||
"description": "**Build Triggered** \n**Reason:** '"${TRIGGER_REASON}"' \n**Build URL:** '"${buildurl}display/redirect"' \n"}],
|
buildurl=$(curl -s "${response%$'\r'}api/json" | jq -r '.executable.url')
|
||||||
"username": "Github Actions"}' ${{ secrets.DISCORD_WEBHOOK }}
|
buildurl="${buildurl%$'\r'}"
|
||||||
|
echo "Jenkins job [build url](${buildurl})" >> $GITHUB_STEP_SUMMARY
|
||||||
|
echo "Attempting to change the Jenkins job description" >> $GITHUB_STEP_SUMMARY
|
||||||
|
curl -iX POST \
|
||||||
|
"${buildurl}submitDescription" \
|
||||||
|
--user ${{ secrets.JENKINS_USER }}:${{ secrets.JENKINS_TOKEN }} \
|
||||||
|
--data-urlencode "description=GHA external trigger https://github.com/${{ github.repository }}/actions/runs/${{ github.run_id }}" \
|
||||||
|
--data-urlencode "Submit=Submit"
|
||||||
|
echo "**** Notifying Discord ****"
|
||||||
|
TRIGGER_REASON="A version change was detected for heimdall tag development. Old version:${IMAGE_VERSION} New version:${EXT_RELEASE_SANITIZED}"
|
||||||
|
curl -X POST -H "Content-Type: application/json" --data '{"avatar_url": "https://cdn.discordapp.com/avatars/354986384542662657/df91181b3f1cf0ef1592fbe18e0962d7.png","embeds": [{"color": 9802903,
|
||||||
|
"description": "**Build Triggered** \n**Reason:** '"${TRIGGER_REASON}"' \n**Build URL:** '"${buildurl}display/redirect"' \n"}],
|
||||||
|
"username": "Github Actions"}' ${{ secrets.DISCORD_WEBHOOK }}
|
||||||
|
fi
|
||||||
fi
|
fi
|
||||||
|
|||||||
37
.github/workflows/external_trigger_scheduler.yml
vendored
Executable file → Normal file
37
.github/workflows/external_trigger_scheduler.yml
vendored
Executable file → Normal file
@@ -2,42 +2,47 @@ name: External Trigger Scheduler
|
|||||||
|
|
||||||
on:
|
on:
|
||||||
schedule:
|
schedule:
|
||||||
- cron: '35 * * * *'
|
- cron: '39 * * * *'
|
||||||
workflow_dispatch:
|
workflow_dispatch:
|
||||||
|
|
||||||
|
permissions:
|
||||||
|
contents: read
|
||||||
|
|
||||||
jobs:
|
jobs:
|
||||||
external-trigger-scheduler:
|
external-trigger-scheduler:
|
||||||
runs-on: ubuntu-latest
|
runs-on: ubuntu-latest
|
||||||
steps:
|
steps:
|
||||||
- uses: actions/checkout@v3.1.0
|
- uses: actions/checkout@v4.1.1
|
||||||
with:
|
with:
|
||||||
fetch-depth: '0'
|
fetch-depth: '0'
|
||||||
|
|
||||||
- name: External Trigger Scheduler
|
- name: External Trigger Scheduler
|
||||||
run: |
|
run: |
|
||||||
echo "**** Branches found: ****"
|
printf "# External trigger scheduler for docker-heimdall\n\n" >> $GITHUB_STEP_SUMMARY
|
||||||
git for-each-ref --format='%(refname:short)' refs/remotes
|
printf "Found the branches:\n\n%s\n" "$(git for-each-ref --format='- %(refname:lstrip=3)' refs/remotes)" >> $GITHUB_STEP_SUMMARY
|
||||||
echo "**** Pulling the yq docker image ****"
|
for br in $(git for-each-ref --format='%(refname:lstrip=3)' refs/remotes)
|
||||||
docker pull ghcr.io/linuxserver/yq
|
|
||||||
for br in $(git for-each-ref --format='%(refname:short)' refs/remotes)
|
|
||||||
do
|
do
|
||||||
br=$(echo "$br" | sed 's|origin/||g')
|
if [[ "${br}" == "HEAD" ]]; then
|
||||||
echo "**** Evaluating branch ${br} ****"
|
printf "\nSkipping %s.\n" ${br} >> $GITHUB_STEP_SUMMARY
|
||||||
ls_branch=$(curl -sX GET https://raw.githubusercontent.com/linuxserver/docker-heimdall/${br}/jenkins-vars.yml \
|
continue
|
||||||
| docker run --rm -i --entrypoint yq ghcr.io/linuxserver/yq -r .ls_branch)
|
fi
|
||||||
if [ "$br" == "$ls_branch" ]; then
|
printf "\n## Evaluating \`%s\`\n\n" ${br} >> $GITHUB_STEP_SUMMARY
|
||||||
echo "**** Branch ${br} appears to be live; checking workflow. ****"
|
ls_jenkins_vars=$(curl -sX GET https://raw.githubusercontent.com/linuxserver/docker-heimdall/${br}/jenkins-vars.yml)
|
||||||
|
ls_branch=$(echo "${ls_jenkins_vars}" | yq -r '.ls_branch')
|
||||||
|
ls_trigger=$(echo "${ls_jenkins_vars}" | yq -r '.external_type')
|
||||||
|
if [[ "${br}" == "${ls_branch}" ]] && [[ "${ls_trigger}" != "os" ]]; then
|
||||||
|
echo "Branch appears to be live and trigger is not os; checking workflow." >> $GITHUB_STEP_SUMMARY
|
||||||
if curl -sfX GET https://raw.githubusercontent.com/linuxserver/docker-heimdall/${br}/.github/workflows/external_trigger.yml > /dev/null 2>&1; then
|
if curl -sfX GET https://raw.githubusercontent.com/linuxserver/docker-heimdall/${br}/.github/workflows/external_trigger.yml > /dev/null 2>&1; then
|
||||||
echo "**** Workflow exists. Triggering external trigger workflow for branch ${br} ****."
|
echo "Triggering external trigger workflow for branch." >> $GITHUB_STEP_SUMMARY
|
||||||
curl -iX POST \
|
curl -iX POST \
|
||||||
-H "Authorization: token ${{ secrets.CR_PAT }}" \
|
-H "Authorization: token ${{ secrets.CR_PAT }}" \
|
||||||
-H "Accept: application/vnd.github.v3+json" \
|
-H "Accept: application/vnd.github.v3+json" \
|
||||||
-d "{\"ref\":\"refs/heads/${br}\"}" \
|
-d "{\"ref\":\"refs/heads/${br}\"}" \
|
||||||
https://api.github.com/repos/linuxserver/docker-heimdall/actions/workflows/external_trigger.yml/dispatches
|
https://api.github.com/repos/linuxserver/docker-heimdall/actions/workflows/external_trigger.yml/dispatches
|
||||||
else
|
else
|
||||||
echo "**** Workflow doesn't exist; skipping trigger. ****"
|
echo "Skipping branch due to no external trigger workflow present." >> $GITHUB_STEP_SUMMARY
|
||||||
fi
|
fi
|
||||||
else
|
else
|
||||||
echo "**** ${br} appears to be a dev branch; skipping trigger. ****"
|
echo "Skipping branch due to being detected as dev branch or having no external version." >> $GITHUB_STEP_SUMMARY
|
||||||
fi
|
fi
|
||||||
done
|
done
|
||||||
|
|||||||
6
.github/workflows/greetings.yml
vendored
Executable file → Normal file
6
.github/workflows/greetings.yml
vendored
Executable file → Normal file
@@ -2,8 +2,14 @@ name: Greetings
|
|||||||
|
|
||||||
on: [pull_request_target, issues]
|
on: [pull_request_target, issues]
|
||||||
|
|
||||||
|
permissions:
|
||||||
|
contents: read
|
||||||
|
|
||||||
jobs:
|
jobs:
|
||||||
greeting:
|
greeting:
|
||||||
|
permissions:
|
||||||
|
issues: write
|
||||||
|
pull-requests: write
|
||||||
runs-on: ubuntu-latest
|
runs-on: ubuntu-latest
|
||||||
steps:
|
steps:
|
||||||
- uses: actions/first-interaction@v1
|
- uses: actions/first-interaction@v1
|
||||||
|
|||||||
38
.github/workflows/package_trigger.yml
vendored
38
.github/workflows/package_trigger.yml
vendored
@@ -1,38 +0,0 @@
|
|||||||
name: Package Trigger Main
|
|
||||||
|
|
||||||
on:
|
|
||||||
workflow_dispatch:
|
|
||||||
|
|
||||||
jobs:
|
|
||||||
package-trigger-development:
|
|
||||||
runs-on: ubuntu-latest
|
|
||||||
steps:
|
|
||||||
- uses: actions/checkout@v3.1.0
|
|
||||||
|
|
||||||
- name: Package Trigger
|
|
||||||
if: github.ref == 'refs/heads/development'
|
|
||||||
run: |
|
|
||||||
if [ -n "${{ secrets.PAUSE_PACKAGE_TRIGGER_HEIMDALL_DEVELOPMENT }}" ]; then
|
|
||||||
echo "**** Github secret PAUSE_PACKAGE_TRIGGER_HEIMDALL_DEVELOPMENT is set; skipping trigger. ****"
|
|
||||||
exit 0
|
|
||||||
fi
|
|
||||||
if [ $(curl -s https://ci.linuxserver.io/job/Docker-Pipeline-Builders/job/docker-heimdall/job/development/lastBuild/api/json | jq -r '.building') == "true" ]; then
|
|
||||||
echo "**** There already seems to be an active build on Jenkins; skipping package trigger ****"
|
|
||||||
exit 0
|
|
||||||
fi
|
|
||||||
echo "**** Package trigger running off of development branch. To disable, set a Github secret named \"PAUSE_PACKAGE_TRIGGER_HEIMDALL_DEVELOPMENT\". ****"
|
|
||||||
response=$(curl -iX POST \
|
|
||||||
https://ci.linuxserver.io/job/Docker-Pipeline-Builders/job/docker-heimdall/job/development/buildWithParameters?PACKAGE_CHECK=true \
|
|
||||||
--user ${{ secrets.JENKINS_USER }}:${{ secrets.JENKINS_TOKEN }} | grep -i location | sed "s|^[L|l]ocation: \(.*\)|\1|")
|
|
||||||
echo "**** Jenkins job queue url: ${response%$'\r'} ****"
|
|
||||||
echo "**** Sleeping 10 seconds until job starts ****"
|
|
||||||
sleep 10
|
|
||||||
buildurl=$(curl -s "${response%$'\r'}api/json" | jq -r '.executable.url')
|
|
||||||
buildurl="${buildurl%$'\r'}"
|
|
||||||
echo "**** Jenkins job build url: ${buildurl} ****"
|
|
||||||
echo "**** Attempting to change the Jenkins job description ****"
|
|
||||||
curl -iX POST \
|
|
||||||
"${buildurl}submitDescription" \
|
|
||||||
--user ${{ secrets.JENKINS_USER }}:${{ secrets.JENKINS_TOKEN }} \
|
|
||||||
--data-urlencode "description=GHA package trigger https://github.com/${{ github.repository }}/actions/runs/${{ github.run_id }}" \
|
|
||||||
--data-urlencode "Submit=Submit"
|
|
||||||
111
.github/workflows/package_trigger_scheduler.yml
vendored
Executable file → Normal file
111
.github/workflows/package_trigger_scheduler.yml
vendored
Executable file → Normal file
@@ -2,49 +2,102 @@ name: Package Trigger Scheduler
|
|||||||
|
|
||||||
on:
|
on:
|
||||||
schedule:
|
schedule:
|
||||||
- cron: '54 7 * * 0'
|
- cron: '14 18 * * 5'
|
||||||
workflow_dispatch:
|
workflow_dispatch:
|
||||||
|
|
||||||
|
permissions:
|
||||||
|
contents: read
|
||||||
|
|
||||||
jobs:
|
jobs:
|
||||||
package-trigger-scheduler:
|
package-trigger-scheduler:
|
||||||
runs-on: ubuntu-latest
|
runs-on: ubuntu-latest
|
||||||
steps:
|
steps:
|
||||||
- uses: actions/checkout@v3.1.0
|
- uses: actions/checkout@v4.1.1
|
||||||
with:
|
with:
|
||||||
fetch-depth: '0'
|
fetch-depth: '0'
|
||||||
|
|
||||||
- name: Package Trigger Scheduler
|
- name: Package Trigger Scheduler
|
||||||
|
env:
|
||||||
|
SKIP_PACKAGE_TRIGGER: ${{ vars.SKIP_PACKAGE_TRIGGER }}
|
||||||
run: |
|
run: |
|
||||||
echo "**** Branches found: ****"
|
printf "# Package trigger scheduler for docker-heimdall\n\n" >> $GITHUB_STEP_SUMMARY
|
||||||
git for-each-ref --format='%(refname:short)' refs/remotes
|
printf "Found the branches:\n\n%s\n" "$(git for-each-ref --format='- %(refname:lstrip=3)' refs/remotes)" >> $GITHUB_STEP_SUMMARY
|
||||||
echo "**** Pulling the yq docker image ****"
|
for br in $(git for-each-ref --format='%(refname:lstrip=3)' refs/remotes)
|
||||||
docker pull ghcr.io/linuxserver/yq
|
|
||||||
for br in $(git for-each-ref --format='%(refname:short)' refs/remotes)
|
|
||||||
do
|
do
|
||||||
br=$(echo "$br" | sed 's|origin/||g')
|
if [[ "${br}" == "HEAD" ]]; then
|
||||||
echo "**** Evaluating branch ${br} ****"
|
printf "\nSkipping %s.\n" ${br} >> $GITHUB_STEP_SUMMARY
|
||||||
ls_branch=$(curl -sX GET https://raw.githubusercontent.com/linuxserver/docker-heimdall/${br}/jenkins-vars.yml \
|
continue
|
||||||
| docker run --rm -i --entrypoint yq ghcr.io/linuxserver/yq -r .ls_branch)
|
fi
|
||||||
if [ "${br}" == "${ls_branch}" ]; then
|
printf "\n## Evaluating \`%s\`\n\n" ${br} >> $GITHUB_STEP_SUMMARY
|
||||||
echo "**** Branch ${br} appears to be live; checking workflow. ****"
|
JENKINS_VARS=$(curl -sX GET https://raw.githubusercontent.com/linuxserver/docker-heimdall/${br}/jenkins-vars.yml)
|
||||||
if curl -sfX GET https://raw.githubusercontent.com/linuxserver/docker-heimdall/${br}/.github/workflows/package_trigger.yml > /dev/null 2>&1; then
|
if ! curl -sfX GET https://raw.githubusercontent.com/linuxserver/docker-heimdall/${br}/Jenkinsfile >/dev/null 2>&1; then
|
||||||
echo "**** Workflow exists. Triggering package trigger workflow for branch ${br}. ****"
|
echo "> [!WARNING]" >> $GITHUB_STEP_SUMMARY
|
||||||
triggered_branches="${triggered_branches}${br} "
|
echo "> No Jenkinsfile found. Branch is either deprecated or is an early dev branch." >> $GITHUB_STEP_SUMMARY
|
||||||
curl -iX POST \
|
skipped_branches="${skipped_branches}${br} "
|
||||||
-H "Authorization: token ${{ secrets.CR_PAT }}" \
|
elif [[ "${br}" == $(yq -r '.ls_branch' <<< "${JENKINS_VARS}") ]]; then
|
||||||
-H "Accept: application/vnd.github.v3+json" \
|
echo "Branch appears to be live; checking workflow." >> $GITHUB_STEP_SUMMARY
|
||||||
-d "{\"ref\":\"refs/heads/${br}\"}" \
|
README_VARS=$(curl -sX GET https://raw.githubusercontent.com/linuxserver/docker-heimdall/${br}/readme-vars.yml)
|
||||||
https://api.github.com/repos/linuxserver/docker-heimdall/actions/workflows/package_trigger.yml/dispatches
|
if [[ $(yq -r '.project_deprecation_status' <<< "${README_VARS}") == "true" ]]; then
|
||||||
sleep 30
|
echo "> [!WARNING]" >> $GITHUB_STEP_SUMMARY
|
||||||
|
echo "> Branch appears to be deprecated; skipping trigger." >> $GITHUB_STEP_SUMMARY
|
||||||
|
skipped_branches="${skipped_branches}${br} "
|
||||||
|
elif [[ $(yq -r '.skip_package_check' <<< "${JENKINS_VARS}") == "true" ]]; then
|
||||||
|
echo "> [!WARNING]" >> $GITHUB_STEP_SUMMARY
|
||||||
|
echo "> Skipping branch ${br} due to \`skip_package_check\` being set in \`jenkins-vars.yml\`." >> $GITHUB_STEP_SUMMARY
|
||||||
|
skipped_branches="${skipped_branches}${br} "
|
||||||
|
elif grep -q "^heimdall_${br}" <<< "${SKIP_PACKAGE_TRIGGER}"; then
|
||||||
|
echo "> [!WARNING]" >> $GITHUB_STEP_SUMMARY
|
||||||
|
echo "> Github organizational variable \`SKIP_PACKAGE_TRIGGER\` contains \`heimdall_${br}\`; skipping trigger." >> $GITHUB_STEP_SUMMARY
|
||||||
|
skipped_branches="${skipped_branches}${br} "
|
||||||
|
elif [ $(curl -s https://ci.linuxserver.io/job/Docker-Pipeline-Builders/job/docker-heimdall/job/${br}/lastBuild/api/json | jq -r '.building' 2>/dev/null) == "true" ]; then
|
||||||
|
echo "> [!WARNING]" >> $GITHUB_STEP_SUMMARY
|
||||||
|
echo "> There already seems to be an active build on Jenkins; skipping package trigger for ${br}" >> $GITHUB_STEP_SUMMARY
|
||||||
|
skipped_branches="${skipped_branches}${br} "
|
||||||
else
|
else
|
||||||
echo "**** Workflow doesn't exist; skipping trigger. ****"
|
echo "> [!NOTE]" >> $GITHUB_STEP_SUMMARY
|
||||||
|
echo "> Triggering package trigger for branch ${br}" >> $GITHUB_STEP_SUMMARY
|
||||||
|
printf "> To disable, add \`heimdall_%s\` into the Github organizational variable \`SKIP_PACKAGE_TRIGGER\`.\n\n" "${br}" >> $GITHUB_STEP_SUMMARY
|
||||||
|
triggered_branches="${triggered_branches}${br} "
|
||||||
|
response=$(curl -iX POST \
|
||||||
|
https://ci.linuxserver.io/job/Docker-Pipeline-Builders/job/docker-heimdall/job/${br}/buildWithParameters?PACKAGE_CHECK=true \
|
||||||
|
--user ${{ secrets.JENKINS_USER }}:${{ secrets.JENKINS_TOKEN }} | grep -i location | sed "s|^[L|l]ocation: \(.*\)|\1|")
|
||||||
|
if [[ -z "${response}" ]]; then
|
||||||
|
echo "> [!WARNING]" >> $GITHUB_STEP_SUMMARY
|
||||||
|
echo "> Jenkins build could not be triggered. Skipping branch."
|
||||||
|
continue
|
||||||
|
fi
|
||||||
|
echo "Jenkins [job queue url](${response%$'\r'})" >> $GITHUB_STEP_SUMMARY
|
||||||
|
echo "Sleeping 10 seconds until job starts" >> $GITHUB_STEP_SUMMARY
|
||||||
|
sleep 10
|
||||||
|
buildurl=$(curl -s "${response%$'\r'}api/json" | jq -r '.executable.url')
|
||||||
|
buildurl="${buildurl%$'\r'}"
|
||||||
|
echo "Jenkins job [build url](${buildurl})" >> $GITHUB_STEP_SUMMARY
|
||||||
|
echo "Attempting to change the Jenkins job description" >> $GITHUB_STEP_SUMMARY
|
||||||
|
if ! curl -ifX POST \
|
||||||
|
"${buildurl}submitDescription" \
|
||||||
|
--user ${{ secrets.JENKINS_USER }}:${{ secrets.JENKINS_TOKEN }} \
|
||||||
|
--data-urlencode "description=GHA package trigger https://github.com/${{ github.repository }}/actions/runs/${{ github.run_id }}" \
|
||||||
|
--data-urlencode "Submit=Submit"; then
|
||||||
|
echo "> [!WARNING]" >> $GITHUB_STEP_SUMMARY
|
||||||
|
echo "> Unable to change the Jenkins job description."
|
||||||
|
fi
|
||||||
|
sleep 20
|
||||||
fi
|
fi
|
||||||
else
|
else
|
||||||
echo "**** ${br} appears to be a dev branch; skipping trigger. ****"
|
echo "Skipping branch ${br} due to being detected as dev branch." >> $GITHUB_STEP_SUMMARY
|
||||||
fi
|
fi
|
||||||
done
|
done
|
||||||
echo "**** Package check build(s) triggered for branch(es): ${triggered_branches} ****"
|
if [[ -n "${triggered_branches}" ]] || [[ -n "${skipped_branches}" ]]; then
|
||||||
echo "**** Notifying Discord ****"
|
if [[ -n "${triggered_branches}" ]]; then
|
||||||
curl -X POST -H "Content-Type: application/json" --data '{"avatar_url": "https://cdn.discordapp.com/avatars/354986384542662657/df91181b3f1cf0ef1592fbe18e0962d7.png","embeds": [{"color": 9802903,
|
NOTIFY_BRANCHES="**Triggered:** ${triggered_branches} \n"
|
||||||
"description": "**Package Check Build(s) Triggered for heimdall** \n**Branch(es):** '"${triggered_branches}"' \n**Build URL:** '"https://ci.linuxserver.io/blue/organizations/jenkins/Docker-Pipeline-Builders%2Fdocker-heimdall/activity/"' \n"}],
|
NOTIFY_BUILD_URL="**Build URL:** https://ci.linuxserver.io/blue/organizations/jenkins/Docker-Pipeline-Builders%2Fdocker-heimdall/activity/ \n"
|
||||||
"username": "Github Actions"}' ${{ secrets.DISCORD_WEBHOOK }}
|
echo "**** Package check build(s) triggered for branch(es): ${triggered_branches} ****"
|
||||||
|
fi
|
||||||
|
if [[ -n "${skipped_branches}" ]]; then
|
||||||
|
NOTIFY_BRANCHES="${NOTIFY_BRANCHES}**Skipped:** ${skipped_branches} \n"
|
||||||
|
fi
|
||||||
|
echo "**** Notifying Discord ****"
|
||||||
|
curl -X POST -H "Content-Type: application/json" --data '{"avatar_url": "https://cdn.discordapp.com/avatars/354986384542662657/df91181b3f1cf0ef1592fbe18e0962d7.png","embeds": [{"color": 9802903,
|
||||||
|
"description": "**Package Check Build(s) for heimdall** \n'"${NOTIFY_BRANCHES}"''"${NOTIFY_BUILD_URL}"'"}],
|
||||||
|
"username": "Github Actions"}' ${{ secrets.DISCORD_WEBHOOK }}
|
||||||
|
fi
|
||||||
|
|||||||
5
.github/workflows/permissions.yml
vendored
Executable file → Normal file
5
.github/workflows/permissions.yml
vendored
Executable file → Normal file
@@ -1,9 +1,12 @@
|
|||||||
name: Permission check
|
name: Permission check
|
||||||
on:
|
on:
|
||||||
pull_request:
|
pull_request_target:
|
||||||
paths:
|
paths:
|
||||||
- '**/run'
|
- '**/run'
|
||||||
- '**/finish'
|
- '**/finish'
|
||||||
|
- '**/check'
|
||||||
|
- 'root/migrations/*'
|
||||||
|
|
||||||
jobs:
|
jobs:
|
||||||
permission_check:
|
permission_check:
|
||||||
uses: linuxserver/github-workflows/.github/workflows/init-svc-executable-permissions.yml@v1
|
uses: linuxserver/github-workflows/.github/workflows/init-svc-executable-permissions.yml@v1
|
||||||
|
|||||||
23
.github/workflows/stale.yml
vendored
23
.github/workflows/stale.yml
vendored
@@ -1,23 +0,0 @@
|
|||||||
name: Mark stale issues and pull requests
|
|
||||||
|
|
||||||
on:
|
|
||||||
schedule:
|
|
||||||
- cron: "30 1 * * *"
|
|
||||||
|
|
||||||
jobs:
|
|
||||||
stale:
|
|
||||||
|
|
||||||
runs-on: ubuntu-latest
|
|
||||||
|
|
||||||
steps:
|
|
||||||
- uses: actions/stale@v6.0.1
|
|
||||||
with:
|
|
||||||
stale-issue-message: "This issue has been automatically marked as stale because it has not had recent activity. It will be closed if no further activity occurs. Thank you for your contributions."
|
|
||||||
stale-pr-message: "This pull request has been automatically marked as stale because it has not had recent activity. It will be closed if no further activity occurs. Thank you for your contributions."
|
|
||||||
stale-issue-label: 'no-issue-activity'
|
|
||||||
stale-pr-label: 'no-pr-activity'
|
|
||||||
days-before-stale: 30
|
|
||||||
days-before-close: 365
|
|
||||||
exempt-issue-labels: 'awaiting-approval,work-in-progress'
|
|
||||||
exempt-pr-labels: 'awaiting-approval,work-in-progress'
|
|
||||||
repo-token: ${{ secrets.GITHUB_TOKEN }}
|
|
||||||
30
Dockerfile
30
Dockerfile
@@ -1,6 +1,6 @@
|
|||||||
# syntax=docker/dockerfile:1
|
# syntax=docker/dockerfile:1
|
||||||
|
|
||||||
FROM ghcr.io/linuxserver/baseimage-alpine-nginx:3.17
|
FROM ghcr.io/linuxserver/baseimage-alpine-nginx:3.22
|
||||||
|
|
||||||
# set version label
|
# set version label
|
||||||
ARG BUILD_DATE
|
ARG BUILD_DATE
|
||||||
@@ -9,25 +9,28 @@ ARG HEIMDALL_RELEASE
|
|||||||
LABEL build_version="Linuxserver.io version:- ${VERSION} Build-date:- ${BUILD_DATE}"
|
LABEL build_version="Linuxserver.io version:- ${VERSION} Build-date:- ${BUILD_DATE}"
|
||||||
LABEL maintainer="aptalca"
|
LABEL maintainer="aptalca"
|
||||||
|
|
||||||
# environment settings
|
|
||||||
ENV S6_BEHAVIOUR_IF_STAGE2_FAILS=2
|
|
||||||
|
|
||||||
RUN \
|
RUN \
|
||||||
echo "**** install runtime packages ****" && \
|
echo "**** install runtime packages ****" && \
|
||||||
apk add --no-cache --upgrade \
|
apk add --no-cache \
|
||||||
php81-ctype \
|
php84-dom \
|
||||||
php81-curl \
|
php84-intl \
|
||||||
php81-intl \
|
php84-opcache \
|
||||||
php81-pdo_pgsql \
|
php84-pdo_mysql \
|
||||||
php81-pdo_sqlite \
|
php84-pdo_pgsql \
|
||||||
php81-pdo_mysql \
|
php84-pdo_sqlite \
|
||||||
php81-tokenizer \
|
php84-tokenizer && \
|
||||||
php81-zip && \
|
|
||||||
echo "**** configure nginx ****" && \
|
echo "**** configure nginx ****" && \
|
||||||
echo 'fastcgi_param PHP_AUTH_USER $remote_user; # Heimdall user authorization' >> \
|
echo 'fastcgi_param PHP_AUTH_USER $remote_user; # Heimdall user authorization' >> \
|
||||||
/etc/nginx/fastcgi_params && \
|
/etc/nginx/fastcgi_params && \
|
||||||
echo 'fastcgi_param PHP_AUTH_PW $http_authorization; # Heimdall user authorization' >> \
|
echo 'fastcgi_param PHP_AUTH_PW $http_authorization; # Heimdall user authorization' >> \
|
||||||
/etc/nginx/fastcgi_params && \
|
/etc/nginx/fastcgi_params && \
|
||||||
|
echo "**** configure php opcache ****" && \
|
||||||
|
echo 'opcache.validate_timestamps=0' >> \
|
||||||
|
/etc/php84/conf.d/00_opcache.ini && \
|
||||||
|
echo "**** configure php-fpm to pass env vars ****" && \
|
||||||
|
sed -E -i 's/^;?clear_env ?=.*$/clear_env = no/g' /etc/php84/php-fpm.d/www.conf && \
|
||||||
|
if ! grep -qxF 'clear_env = no' /etc/php84/php-fpm.d/www.conf; then echo 'clear_env = no' >> /etc/php84/php-fpm.d/www.conf; fi && \
|
||||||
|
echo "env[PATH] = /usr/local/bin:/usr/bin:/bin" >> /etc/php84/php-fpm.conf && \
|
||||||
echo "**** install heimdall ****" && \
|
echo "**** install heimdall ****" && \
|
||||||
mkdir -p \
|
mkdir -p \
|
||||||
/heimdall && \
|
/heimdall && \
|
||||||
@@ -43,6 +46,7 @@ RUN \
|
|||||||
tar xf \
|
tar xf \
|
||||||
/tmp/heimdall.tar.gz -C \
|
/tmp/heimdall.tar.gz -C \
|
||||||
/app/www-tmp --strip-components=1 && \
|
/app/www-tmp --strip-components=1 && \
|
||||||
|
printf "Linuxserver.io version: ${VERSION}\nBuild-date: ${BUILD_DATE}" > /build_version && \
|
||||||
echo "**** cleanup ****" && \
|
echo "**** cleanup ****" && \
|
||||||
rm -rf \
|
rm -rf \
|
||||||
/tmp/*
|
/tmp/*
|
||||||
|
|||||||
@@ -1,6 +1,6 @@
|
|||||||
# syntax=docker/dockerfile:1
|
# syntax=docker/dockerfile:1
|
||||||
|
|
||||||
FROM ghcr.io/linuxserver/baseimage-alpine-nginx:arm64v8-3.17
|
FROM ghcr.io/linuxserver/baseimage-alpine-nginx:arm64v8-3.22
|
||||||
|
|
||||||
# set version label
|
# set version label
|
||||||
ARG BUILD_DATE
|
ARG BUILD_DATE
|
||||||
@@ -9,25 +9,28 @@ ARG HEIMDALL_RELEASE
|
|||||||
LABEL build_version="Linuxserver.io version:- ${VERSION} Build-date:- ${BUILD_DATE}"
|
LABEL build_version="Linuxserver.io version:- ${VERSION} Build-date:- ${BUILD_DATE}"
|
||||||
LABEL maintainer="aptalca"
|
LABEL maintainer="aptalca"
|
||||||
|
|
||||||
# environment settings
|
|
||||||
ENV S6_BEHAVIOUR_IF_STAGE2_FAILS=2
|
|
||||||
|
|
||||||
RUN \
|
RUN \
|
||||||
echo "**** install runtime packages ****" && \
|
echo "**** install runtime packages ****" && \
|
||||||
apk add --no-cache --upgrade \
|
apk add --no-cache \
|
||||||
php81-ctype \
|
php84-dom \
|
||||||
php81-curl \
|
php84-intl \
|
||||||
php81-intl \
|
php84-opcache \
|
||||||
php81-pdo_pgsql \
|
php84-pdo_mysql \
|
||||||
php81-pdo_sqlite \
|
php84-pdo_pgsql \
|
||||||
php81-pdo_mysql \
|
php84-pdo_sqlite \
|
||||||
php81-tokenizer \
|
php84-tokenizer && \
|
||||||
php81-zip && \
|
|
||||||
echo "**** configure nginx ****" && \
|
echo "**** configure nginx ****" && \
|
||||||
echo 'fastcgi_param PHP_AUTH_USER $remote_user; # Heimdall user authorization' >> \
|
echo 'fastcgi_param PHP_AUTH_USER $remote_user; # Heimdall user authorization' >> \
|
||||||
/etc/nginx/fastcgi_params && \
|
/etc/nginx/fastcgi_params && \
|
||||||
echo 'fastcgi_param PHP_AUTH_PW $http_authorization; # Heimdall user authorization' >> \
|
echo 'fastcgi_param PHP_AUTH_PW $http_authorization; # Heimdall user authorization' >> \
|
||||||
/etc/nginx/fastcgi_params && \
|
/etc/nginx/fastcgi_params && \
|
||||||
|
echo "**** configure php opcache ****" && \
|
||||||
|
echo 'opcache.validate_timestamps=0' >> \
|
||||||
|
/etc/php84/conf.d/00_opcache.ini && \
|
||||||
|
echo "**** configure php-fpm to pass env vars ****" && \
|
||||||
|
sed -E -i 's/^;?clear_env ?=.*$/clear_env = no/g' /etc/php84/php-fpm.d/www.conf && \
|
||||||
|
if ! grep -qxF 'clear_env = no' /etc/php84/php-fpm.d/www.conf; then echo 'clear_env = no' >> /etc/php84/php-fpm.d/www.conf; fi && \
|
||||||
|
echo "env[PATH] = /usr/local/bin:/usr/bin:/bin" >> /etc/php84/php-fpm.conf && \
|
||||||
echo "**** install heimdall ****" && \
|
echo "**** install heimdall ****" && \
|
||||||
mkdir -p \
|
mkdir -p \
|
||||||
/heimdall && \
|
/heimdall && \
|
||||||
@@ -43,6 +46,7 @@ RUN \
|
|||||||
tar xf \
|
tar xf \
|
||||||
/tmp/heimdall.tar.gz -C \
|
/tmp/heimdall.tar.gz -C \
|
||||||
/app/www-tmp --strip-components=1 && \
|
/app/www-tmp --strip-components=1 && \
|
||||||
|
printf "Linuxserver.io version: ${VERSION}\nBuild-date: ${BUILD_DATE}" > /build_version && \
|
||||||
echo "**** cleanup ****" && \
|
echo "**** cleanup ****" && \
|
||||||
rm -rf \
|
rm -rf \
|
||||||
/tmp/*
|
/tmp/*
|
||||||
|
|||||||
@@ -1,55 +0,0 @@
|
|||||||
# syntax=docker/dockerfile:1
|
|
||||||
|
|
||||||
FROM ghcr.io/linuxserver/baseimage-alpine-nginx:arm32v7-3.17
|
|
||||||
|
|
||||||
# set version label
|
|
||||||
ARG BUILD_DATE
|
|
||||||
ARG VERSION
|
|
||||||
ARG HEIMDALL_RELEASE
|
|
||||||
LABEL build_version="Linuxserver.io version:- ${VERSION} Build-date:- ${BUILD_DATE}"
|
|
||||||
LABEL maintainer="aptalca"
|
|
||||||
|
|
||||||
# environment settings
|
|
||||||
ENV S6_BEHAVIOUR_IF_STAGE2_FAILS=2
|
|
||||||
|
|
||||||
RUN \
|
|
||||||
echo "**** install runtime packages ****" && \
|
|
||||||
apk add --no-cache --upgrade \
|
|
||||||
php81-ctype \
|
|
||||||
php81-curl \
|
|
||||||
php81-intl \
|
|
||||||
php81-pdo_pgsql \
|
|
||||||
php81-pdo_sqlite \
|
|
||||||
php81-pdo_mysql \
|
|
||||||
php81-tokenizer \
|
|
||||||
php81-zip && \
|
|
||||||
echo "**** configure nginx ****" && \
|
|
||||||
echo 'fastcgi_param PHP_AUTH_USER $remote_user; # Heimdall user authorization' >> \
|
|
||||||
/etc/nginx/fastcgi_params && \
|
|
||||||
echo 'fastcgi_param PHP_AUTH_PW $http_authorization; # Heimdall user authorization' >> \
|
|
||||||
/etc/nginx/fastcgi_params && \
|
|
||||||
echo "**** install heimdall ****" && \
|
|
||||||
mkdir -p \
|
|
||||||
/heimdall && \
|
|
||||||
if [ -z ${HEIMDALL_RELEASE+x} ]; then \
|
|
||||||
HEIMDALL_RELEASE=$(curl -sX GET "https://api.github.com/repos/linuxserver/Heimdall/commits/2.x" \
|
|
||||||
| awk '/sha/{print $4;exit}' FS='[""]'); \
|
|
||||||
fi && \
|
|
||||||
curl -o \
|
|
||||||
/tmp/heimdall.tar.gz -L \
|
|
||||||
"https://github.com/linuxserver/Heimdall/archive/${HEIMDALL_RELEASE}.tar.gz" && \
|
|
||||||
mkdir -p \
|
|
||||||
/app/www-tmp && \
|
|
||||||
tar xf \
|
|
||||||
/tmp/heimdall.tar.gz -C \
|
|
||||||
/app/www-tmp --strip-components=1 && \
|
|
||||||
echo "**** cleanup ****" && \
|
|
||||||
rm -rf \
|
|
||||||
/tmp/*
|
|
||||||
|
|
||||||
# add local files
|
|
||||||
COPY root/ /
|
|
||||||
|
|
||||||
# ports and volumes
|
|
||||||
EXPOSE 80 443
|
|
||||||
VOLUME /config
|
|
||||||
977
Jenkinsfile
vendored
977
Jenkinsfile
vendored
File diff suppressed because it is too large
Load Diff
180
README.md
180
README.md
@@ -1,12 +1,10 @@
|
|||||||
<!-- DO NOT EDIT THIS FILE MANUALLY -->
|
<!-- DO NOT EDIT THIS FILE MANUALLY -->
|
||||||
<!-- Please read the https://github.com/linuxserver/docker-heimdall/blob/development/.github/CONTRIBUTING.md -->
|
<!-- Please read https://github.com/linuxserver/docker-heimdall/blob/development/.github/CONTRIBUTING.md -->
|
||||||
|
|
||||||
[](https://linuxserver.io)
|
[](https://linuxserver.io)
|
||||||
|
|
||||||
[](https://blog.linuxserver.io "all the things you can do with our containers including How-To guides, opinions and much more!")
|
[](https://blog.linuxserver.io "all the things you can do with our containers including How-To guides, opinions and much more!")
|
||||||
[](https://discord.gg/YWrKVTn "realtime support / chat with the community and the team.")
|
[](https://linuxserver.io/discord "realtime support / chat with the community and the team.")
|
||||||
[](https://discourse.linuxserver.io "post on our community forum.")
|
[](https://discourse.linuxserver.io "post on our community forum.")
|
||||||
[](https://fleet.linuxserver.io "an online web interface which displays all of our maintained images.")
|
|
||||||
[](https://github.com/linuxserver "view the source for all of our repositories.")
|
[](https://github.com/linuxserver "view the source for all of our repositories.")
|
||||||
[](https://opencollective.com/linuxserver "please consider helping us by either donating or contributing to our budget")
|
[](https://opencollective.com/linuxserver "please consider helping us by either donating or contributing to our budget")
|
||||||
|
|
||||||
@@ -21,15 +19,14 @@ The [LinuxServer.io](https://linuxserver.io) team brings you another container r
|
|||||||
Find us at:
|
Find us at:
|
||||||
|
|
||||||
* [Blog](https://blog.linuxserver.io) - all the things you can do with our containers including How-To guides, opinions and much more!
|
* [Blog](https://blog.linuxserver.io) - all the things you can do with our containers including How-To guides, opinions and much more!
|
||||||
* [Discord](https://discord.gg/YWrKVTn) - realtime support / chat with the community and the team.
|
* [Discord](https://linuxserver.io/discord) - realtime support / chat with the community and the team.
|
||||||
* [Discourse](https://discourse.linuxserver.io) - post on our community forum.
|
* [Discourse](https://discourse.linuxserver.io) - post on our community forum.
|
||||||
* [Fleet](https://fleet.linuxserver.io) - an online web interface which displays all of our maintained images.
|
|
||||||
* [GitHub](https://github.com/linuxserver) - view the source for all of our repositories.
|
* [GitHub](https://github.com/linuxserver) - view the source for all of our repositories.
|
||||||
* [Open Collective](https://opencollective.com/linuxserver) - please consider helping us by either donating or contributing to our budget
|
* [Open Collective](https://opencollective.com/linuxserver) - please consider helping us by either donating or contributing to our budget
|
||||||
|
|
||||||
# [linuxserver/heimdall](https://github.com/linuxserver/docker-heimdall)
|
# [linuxserver/heimdall](https://github.com/linuxserver/docker-heimdall)
|
||||||
|
|
||||||
[](https://scarf.sh/gateway/linuxserver-ci/docker/linuxserver%2Fheimdall)
|
[](https://scarf.sh)
|
||||||
[](https://github.com/linuxserver/docker-heimdall)
|
[](https://github.com/linuxserver/docker-heimdall)
|
||||||
[](https://github.com/linuxserver/docker-heimdall/releases)
|
[](https://github.com/linuxserver/docker-heimdall/releases)
|
||||||
[](https://github.com/linuxserver/docker-heimdall/packages)
|
[](https://github.com/linuxserver/docker-heimdall/packages)
|
||||||
@@ -38,7 +35,7 @@ Find us at:
|
|||||||
[](https://hub.docker.com/r/linuxserver/heimdall)
|
[](https://hub.docker.com/r/linuxserver/heimdall)
|
||||||
[](https://hub.docker.com/r/linuxserver/heimdall)
|
[](https://hub.docker.com/r/linuxserver/heimdall)
|
||||||
[](https://ci.linuxserver.io/job/Docker-Pipeline-Builders/job/docker-heimdall/job/development/)
|
[](https://ci.linuxserver.io/job/Docker-Pipeline-Builders/job/docker-heimdall/job/development/)
|
||||||
[](https://ci-tests.linuxserver.io/linuxserver/heimdall/latest/index.html)
|
[](https://ci-tests.linuxserver.io/linuxserver/heimdall/development/index.html)
|
||||||
|
|
||||||
[Heimdall](https://heimdall.site) is a way to organise all those links to your most used web sites and web applications in a simple way.
|
[Heimdall](https://heimdall.site) is a way to organise all those links to your most used web sites and web applications in a simple way.
|
||||||
|
|
||||||
@@ -50,7 +47,7 @@ Why not use it as your browser start page? It even has the ability to include a
|
|||||||
|
|
||||||
## Supported Architectures
|
## Supported Architectures
|
||||||
|
|
||||||
We utilise the docker manifest for multi-platform awareness. More information is available from docker [here](https://github.com/docker/distribution/blob/master/docs/spec/manifest-v2-2.md#manifest-list) and our announcement [here](https://blog.linuxserver.io/2019/02/21/the-lsio-pipeline-project/).
|
We utilise the docker manifest for multi-platform awareness. More information is available from docker [here](https://distribution.github.io/distribution/spec/manifest-v2-2/#manifest-list) and our announcement [here](https://blog.linuxserver.io/2019/02/21/the-lsio-pipeline-project/).
|
||||||
|
|
||||||
Simply pulling `lscr.io/linuxserver/heimdall:development` should retrieve the correct image for your arch, but you can also pull specific arch images via tags.
|
Simply pulling `lscr.io/linuxserver/heimdall:development` should retrieve the correct image for your arch, but you can also pull specific arch images via tags.
|
||||||
|
|
||||||
@@ -60,7 +57,6 @@ The architectures supported by this image are:
|
|||||||
| :----: | :----: | ---- |
|
| :----: | :----: | ---- |
|
||||||
| x86-64 | ✅ | amd64-\<version tag\> |
|
| x86-64 | ✅ | amd64-\<version tag\> |
|
||||||
| arm64 | ✅ | arm64v8-\<version tag\> |
|
| arm64 | ✅ | arm64v8-\<version tag\> |
|
||||||
| armhf | ✅ | arm32v7-\<version tag\> |
|
|
||||||
|
|
||||||
## Version Tags
|
## Version Tags
|
||||||
|
|
||||||
@@ -70,24 +66,26 @@ This image provides various versions that are available via tags. Please read th
|
|||||||
| :----: | :----: |--- |
|
| :----: | :----: |--- |
|
||||||
| latest | ✅ | Stable Heimdall releases. |
|
| latest | ✅ | Stable Heimdall releases. |
|
||||||
| development | ✅ | Latest commit from the github 2.x branch. |
|
| development | ✅ | Latest commit from the github 2.x branch. |
|
||||||
|
|
||||||
## Application Setup
|
## Application Setup
|
||||||
|
|
||||||
Access the web gui at http://SERVERIP:PORT
|
Access the web gui at http://SERVERIP:PORT
|
||||||
|
|
||||||
|
|
||||||
### Adding password protection
|
### Adding password protection
|
||||||
|
|
||||||
This image now supports password protection through htpasswd. Run the following command on your host to generate the htpasswd file `docker exec -it heimdall htpasswd -c /config/nginx/.htpasswd <username>`. Replace <username> with a username of your choice and you will be asked to enter a password. Uncomment the `basic auth` lines in `/config/nginx/site-confs/default.conf` and restart the container.
|
This image now supports password protection through htpasswd. Run the following command on your host to generate the htpasswd file `docker exec -it heimdall htpasswd -c /config/nginx/.htpasswd <username>`. Replace <username> with a username of your choice and you will be asked to enter a password. Uncomment the `basic auth` lines in `/config/nginx/site-confs/default.conf` and restart the container.
|
||||||
|
|
||||||
## Usage
|
## Usage
|
||||||
|
|
||||||
Here are some example snippets to help you get started creating a container.
|
To help you get started creating a container from this image you can either use docker-compose or the docker cli.
|
||||||
|
|
||||||
|
>[!NOTE]
|
||||||
|
>Unless a parameter is flagged as 'optional', it is *mandatory* and a value must be provided.
|
||||||
|
|
||||||
### docker-compose (recommended, [click here for more info](https://docs.linuxserver.io/general/docker-compose))
|
### docker-compose (recommended, [click here for more info](https://docs.linuxserver.io/general/docker-compose))
|
||||||
|
|
||||||
```yaml
|
```yaml
|
||||||
---
|
---
|
||||||
version: "2.1"
|
|
||||||
services:
|
services:
|
||||||
heimdall:
|
heimdall:
|
||||||
image: lscr.io/linuxserver/heimdall:development
|
image: lscr.io/linuxserver/heimdall:development
|
||||||
@@ -96,8 +94,9 @@ services:
|
|||||||
- PUID=1000
|
- PUID=1000
|
||||||
- PGID=1000
|
- PGID=1000
|
||||||
- TZ=Etc/UTC
|
- TZ=Etc/UTC
|
||||||
|
- ALLOW_INTERNAL_REQUESTS=false #optional
|
||||||
volumes:
|
volumes:
|
||||||
- /path/to/appdata/config:/config
|
- /path/to/heimdall/config:/config
|
||||||
ports:
|
ports:
|
||||||
- 80:80
|
- 80:80
|
||||||
- 443:443
|
- 443:443
|
||||||
@@ -112,26 +111,27 @@ docker run -d \
|
|||||||
-e PUID=1000 \
|
-e PUID=1000 \
|
||||||
-e PGID=1000 \
|
-e PGID=1000 \
|
||||||
-e TZ=Etc/UTC \
|
-e TZ=Etc/UTC \
|
||||||
|
-e ALLOW_INTERNAL_REQUESTS=false `#optional` \
|
||||||
-p 80:80 \
|
-p 80:80 \
|
||||||
-p 443:443 \
|
-p 443:443 \
|
||||||
-v /path/to/appdata/config:/config \
|
-v /path/to/heimdall/config:/config \
|
||||||
--restart unless-stopped \
|
--restart unless-stopped \
|
||||||
lscr.io/linuxserver/heimdall:development
|
lscr.io/linuxserver/heimdall:development
|
||||||
|
|
||||||
```
|
```
|
||||||
|
|
||||||
## Parameters
|
## Parameters
|
||||||
|
|
||||||
Container images are configured using parameters passed at runtime (such as those above). These parameters are separated by a colon and indicate `<external>:<internal>` respectively. For example, `-p 8080:80` would expose port `80` from inside the container to be accessible from the host's IP on port `8080` outside the container.
|
Containers are configured using parameters passed at runtime (such as those above). These parameters are separated by a colon and indicate `<external>:<internal>` respectively. For example, `-p 8080:80` would expose port `80` from inside the container to be accessible from the host's IP on port `8080` outside the container.
|
||||||
|
|
||||||
| Parameter | Function |
|
| Parameter | Function |
|
||||||
| :----: | --- |
|
| :----: | --- |
|
||||||
| `-p 80` | http gui |
|
| `-p 80:80` | http gui |
|
||||||
| `-p 443` | https gui |
|
| `-p 443:443` | https gui |
|
||||||
| `-e PUID=1000` | for UserID - see below for explanation |
|
| `-e PUID=1000` | for UserID - see below for explanation |
|
||||||
| `-e PGID=1000` | for GroupID - see below for explanation |
|
| `-e PGID=1000` | for GroupID - see below for explanation |
|
||||||
| `-e TZ=Etc/UTC` | specify a timezone to use, see this [list](https://en.wikipedia.org/wiki/List_of_tz_database_time_zones#List). |
|
| `-e TZ=Etc/UTC` | specify a timezone to use, see this [list](https://en.wikipedia.org/wiki/List_of_tz_database_time_zones#List). |
|
||||||
| `-v /config` | Contains all relevant configuration files. |
|
| `-e ALLOW_INTERNAL_REQUESTS=false` | By default, Heimdall blocks lookup requests to private or reserved IP addresses, if your instance is not exposed to the internet, or is behind some level of authentication, you can set this to `true` to allow requests to private IP addresses. |
|
||||||
|
| `-v /config` | Persistent config files |
|
||||||
|
|
||||||
## Environment variables from files (Docker secrets)
|
## Environment variables from files (Docker secrets)
|
||||||
|
|
||||||
@@ -140,10 +140,10 @@ You can set any environment variable from a file by using a special prepend `FIL
|
|||||||
As an example:
|
As an example:
|
||||||
|
|
||||||
```bash
|
```bash
|
||||||
-e FILE__PASSWORD=/run/secrets/mysecretpassword
|
-e FILE__MYVAR=/run/secrets/mysecretvariable
|
||||||
```
|
```
|
||||||
|
|
||||||
Will set the environment variable `PASSWORD` based on the contents of the `/run/secrets/mysecretpassword` file.
|
Will set the environment variable `MYVAR` based on the contents of the `/run/secrets/mysecretvariable` file.
|
||||||
|
|
||||||
## Umask for running applications
|
## Umask for running applications
|
||||||
|
|
||||||
@@ -152,15 +152,20 @@ Keep in mind umask is not chmod it subtracts from permissions based on it's valu
|
|||||||
|
|
||||||
## User / Group Identifiers
|
## User / Group Identifiers
|
||||||
|
|
||||||
When using volumes (`-v` flags) permissions issues can arise between the host OS and the container, we avoid this issue by allowing you to specify the user `PUID` and group `PGID`.
|
When using volumes (`-v` flags), permissions issues can arise between the host OS and the container, we avoid this issue by allowing you to specify the user `PUID` and group `PGID`.
|
||||||
|
|
||||||
Ensure any volume directories on the host are owned by the same user you specify and any permissions issues will vanish like magic.
|
Ensure any volume directories on the host are owned by the same user you specify and any permissions issues will vanish like magic.
|
||||||
|
|
||||||
In this instance `PUID=1000` and `PGID=1000`, to find yours use `id user` as below:
|
In this instance `PUID=1000` and `PGID=1000`, to find yours use `id your_user` as below:
|
||||||
|
|
||||||
```bash
|
```bash
|
||||||
$ id username
|
id your_user
|
||||||
uid=1000(dockeruser) gid=1000(dockergroup) groups=1000(dockergroup)
|
```
|
||||||
|
|
||||||
|
Example output:
|
||||||
|
|
||||||
|
```text
|
||||||
|
uid=1000(your_user) gid=1000(your_user) groups=1000(your_user)
|
||||||
```
|
```
|
||||||
|
|
||||||
## Docker Mods
|
## Docker Mods
|
||||||
@@ -171,53 +176,101 @@ We publish various [Docker Mods](https://github.com/linuxserver/docker-mods) to
|
|||||||
|
|
||||||
## Support Info
|
## Support Info
|
||||||
|
|
||||||
* Shell access whilst the container is running: `docker exec -it heimdall /bin/bash`
|
* Shell access whilst the container is running:
|
||||||
* To monitor the logs of the container in realtime: `docker logs -f heimdall`
|
|
||||||
* container version number
|
```bash
|
||||||
* `docker inspect -f '{{ index .Config.Labels "build_version" }}' heimdall`
|
docker exec -it heimdall /bin/bash
|
||||||
* image version number
|
```
|
||||||
* `docker inspect -f '{{ index .Config.Labels "build_version" }}' lscr.io/linuxserver/heimdall:development`
|
|
||||||
|
* To monitor the logs of the container in realtime:
|
||||||
|
|
||||||
|
```bash
|
||||||
|
docker logs -f heimdall
|
||||||
|
```
|
||||||
|
|
||||||
|
* Container version number:
|
||||||
|
|
||||||
|
```bash
|
||||||
|
docker inspect -f '{{ index .Config.Labels "build_version" }}' heimdall
|
||||||
|
```
|
||||||
|
|
||||||
|
* Image version number:
|
||||||
|
|
||||||
|
```bash
|
||||||
|
docker inspect -f '{{ index .Config.Labels "build_version" }}' lscr.io/linuxserver/heimdall:development
|
||||||
|
```
|
||||||
|
|
||||||
## Updating Info
|
## Updating Info
|
||||||
|
|
||||||
Most of our images are static, versioned, and require an image update and container recreation to update the app inside. With some exceptions (ie. nextcloud, plex), we do not recommend or support updating apps inside the container. Please consult the [Application Setup](#application-setup) section above to see if it is recommended for the image.
|
Most of our images are static, versioned, and require an image update and container recreation to update the app inside. With some exceptions (noted in the relevant readme.md), we do not recommend or support updating apps inside the container. Please consult the [Application Setup](#application-setup) section above to see if it is recommended for the image.
|
||||||
|
|
||||||
Below are the instructions for updating containers:
|
Below are the instructions for updating containers:
|
||||||
|
|
||||||
### Via Docker Compose
|
### Via Docker Compose
|
||||||
|
|
||||||
* Update all images: `docker-compose pull`
|
* Update images:
|
||||||
* or update a single image: `docker-compose pull heimdall`
|
* All images:
|
||||||
* Let compose update all containers as necessary: `docker-compose up -d`
|
|
||||||
* or update a single container: `docker-compose up -d heimdall`
|
```bash
|
||||||
* You can also remove the old dangling images: `docker image prune`
|
docker-compose pull
|
||||||
|
```
|
||||||
|
|
||||||
|
* Single image:
|
||||||
|
|
||||||
|
```bash
|
||||||
|
docker-compose pull heimdall
|
||||||
|
```
|
||||||
|
|
||||||
|
* Update containers:
|
||||||
|
* All containers:
|
||||||
|
|
||||||
|
```bash
|
||||||
|
docker-compose up -d
|
||||||
|
```
|
||||||
|
|
||||||
|
* Single container:
|
||||||
|
|
||||||
|
```bash
|
||||||
|
docker-compose up -d heimdall
|
||||||
|
```
|
||||||
|
|
||||||
|
* You can also remove the old dangling images:
|
||||||
|
|
||||||
|
```bash
|
||||||
|
docker image prune
|
||||||
|
```
|
||||||
|
|
||||||
### Via Docker Run
|
### Via Docker Run
|
||||||
|
|
||||||
* Update the image: `docker pull lscr.io/linuxserver/heimdall:development`
|
* Update the image:
|
||||||
* Stop the running container: `docker stop heimdall`
|
|
||||||
* Delete the container: `docker rm heimdall`
|
```bash
|
||||||
|
docker pull lscr.io/linuxserver/heimdall:development
|
||||||
|
```
|
||||||
|
|
||||||
|
* Stop the running container:
|
||||||
|
|
||||||
|
```bash
|
||||||
|
docker stop heimdall
|
||||||
|
```
|
||||||
|
|
||||||
|
* Delete the container:
|
||||||
|
|
||||||
|
```bash
|
||||||
|
docker rm heimdall
|
||||||
|
```
|
||||||
|
|
||||||
* Recreate a new container with the same docker run parameters as instructed above (if mapped correctly to a host folder, your `/config` folder and settings will be preserved)
|
* Recreate a new container with the same docker run parameters as instructed above (if mapped correctly to a host folder, your `/config` folder and settings will be preserved)
|
||||||
* You can also remove the old dangling images: `docker image prune`
|
* You can also remove the old dangling images:
|
||||||
|
|
||||||
### Via Watchtower auto-updater (only use if you don't remember the original parameters)
|
```bash
|
||||||
|
docker image prune
|
||||||
* Pull the latest image at its tag and replace it with the same env variables in one run:
|
```
|
||||||
|
|
||||||
```bash
|
|
||||||
docker run --rm \
|
|
||||||
-v /var/run/docker.sock:/var/run/docker.sock \
|
|
||||||
containrrr/watchtower \
|
|
||||||
--run-once heimdall
|
|
||||||
```
|
|
||||||
|
|
||||||
* You can also remove the old dangling images: `docker image prune`
|
|
||||||
|
|
||||||
**Note:** We do not endorse the use of Watchtower as a solution to automated updates of existing Docker containers. In fact we generally discourage automated updates. However, this is a useful tool for one-time manual updates of containers where you have forgotten the original parameters. In the long term, we highly recommend using [Docker Compose](https://docs.linuxserver.io/general/docker-compose).
|
|
||||||
|
|
||||||
### Image Update Notifications - Diun (Docker Image Update Notifier)
|
### Image Update Notifications - Diun (Docker Image Update Notifier)
|
||||||
|
|
||||||
* We recommend [Diun](https://crazymax.dev/diun/) for update notifications. Other tools that automatically update containers unattended are not recommended or supported.
|
>[!TIP]
|
||||||
|
>We recommend [Diun](https://crazymax.dev/diun/) for update notifications. Other tools that automatically update containers unattended are not recommended or supported.
|
||||||
|
|
||||||
## Building locally
|
## Building locally
|
||||||
|
|
||||||
@@ -232,16 +285,23 @@ docker build \
|
|||||||
-t lscr.io/linuxserver/heimdall:development .
|
-t lscr.io/linuxserver/heimdall:development .
|
||||||
```
|
```
|
||||||
|
|
||||||
The ARM variants can be built on x86_64 hardware using `multiarch/qemu-user-static`
|
The ARM variants can be built on x86_64 hardware and vice versa using `lscr.io/linuxserver/qemu-static`
|
||||||
|
|
||||||
```bash
|
```bash
|
||||||
docker run --rm --privileged multiarch/qemu-user-static:register --reset
|
docker run --rm --privileged lscr.io/linuxserver/qemu-static --reset
|
||||||
```
|
```
|
||||||
|
|
||||||
Once registered you can define the dockerfile to use with `-f Dockerfile.aarch64`.
|
Once registered you can define the dockerfile to use with `-f Dockerfile.aarch64`.
|
||||||
|
|
||||||
## Versions
|
## Versions
|
||||||
|
|
||||||
|
* **17.07.25:** - Rebase to Alpine 3.22, enable PHP environment passthrough.
|
||||||
|
* **27.06.24:** - Rebase to Alpine 3.20. Existing users should update their nginx confs to avoid http2 deprecation warnings.
|
||||||
|
* **07.03.24:** - Enable the opcache and disable file revalidation.
|
||||||
|
* **06.03.24:** - Existing users should update: site-confs/default.conf - Cleanup default site conf.
|
||||||
|
* **23.12.23:** - Rebase to Alpine 3.19 with php 8.3.
|
||||||
|
* **25.05.23:** - Rebase to Alpine 3.18, deprecate armhf.
|
||||||
|
* **13.04.23:** - Move ssl.conf include to default.conf.
|
||||||
* **20.01.23:** - Rebase to alpine 3.17 with php8.1.
|
* **20.01.23:** - Rebase to alpine 3.17 with php8.1.
|
||||||
* **14.11.22:** - Rebasing to alpine 3.15 with php8. Restructure nginx configs ([see changes announcement](https://info.linuxserver.io/issues/2022-08-20-nginx-base)).
|
* **14.11.22:** - Rebasing to alpine 3.15 with php8. Restructure nginx configs ([see changes announcement](https://info.linuxserver.io/issues/2022-08-20-nginx-base)).
|
||||||
* **04.11.22:** - Build commits to upstream branch 2.x.
|
* **04.11.22:** - Build commits to upstream branch 2.x.
|
||||||
|
|||||||
@@ -24,6 +24,6 @@ repo_vars:
|
|||||||
- CI_PORT='80'
|
- CI_PORT='80'
|
||||||
- CI_SSL='false'
|
- CI_SSL='false'
|
||||||
- CI_DELAY='120'
|
- CI_DELAY='120'
|
||||||
- CI_DOCKERENV='TZ=US/Pacific'
|
- CI_DOCKERENV=''
|
||||||
- CI_AUTH='user:password'
|
- CI_AUTH=''
|
||||||
- CI_WEBPATH=''
|
- CI_WEBPATH=''
|
||||||
|
|||||||
@@ -1,227 +1,245 @@
|
|||||||
NAME VERSION TYPE
|
NAME VERSION TYPE
|
||||||
alpine-baselayout 3.4.0-r0 apk
|
Hidden Input 1, 0, 0, 0 binary
|
||||||
alpine-baselayout-data 3.4.0-r0 apk
|
acl-libs 2.3.2-r1 apk
|
||||||
alpine-keys 2.4-r1 apk
|
alpine-baselayout 3.7.0-r0 apk
|
||||||
alpine-release 3.17.2-r0 apk
|
alpine-baselayout-data 3.7.0-r0 apk
|
||||||
apache2-utils 2.4.55-r0 apk
|
alpine-keys 2.5-r0 apk
|
||||||
apk-tools 2.12.10-r1 apk
|
alpine-release 3.22.3-r0 apk
|
||||||
apr 1.7.2-r0 apk
|
apache2-utils 2.4.66-r0 apk
|
||||||
apr-util 1.6.3-r0 apk
|
apk-tools 2.14.9-r3 apk
|
||||||
argon2-libs 20190702-r2 apk
|
apr 1.7.5-r0 apk
|
||||||
barryvdh/laravel-ide-helper v2.12.3 php-composer
|
apr-util 1.6.3-r1 apk
|
||||||
barryvdh/reflection-docblock v2.1.0 php-composer
|
argon2-libs 20190702-r5 apk
|
||||||
bash 5.2.15-r0 apk
|
aws/aws-crt-php v1.2.7 php-composer
|
||||||
brick/math 0.9.3 php-composer
|
aws/aws-sdk-php 3.349.3 php-composer
|
||||||
brotli-libs 1.0.9-r9 apk
|
barryvdh/laravel-ide-helper v3.5.5 php-composer
|
||||||
busybox 1.35.0 binary
|
barryvdh/reflection-docblock v2.3.1 php-composer
|
||||||
busybox 1.35.0-r29 apk
|
bash 5.2.37-r0 apk
|
||||||
busybox-binsh 1.35.0-r29 apk
|
brick/math 0.12.3 php-composer
|
||||||
ca-certificates 20220614-r4 apk
|
brotli-libs 1.1.0-r2 apk
|
||||||
ca-certificates-bundle 20220614-r4 apk
|
busybox 1.37.0-r20 apk
|
||||||
clue/stream-filter v1.6.0 php-composer
|
busybox-binsh 1.37.0-r20 apk
|
||||||
composer/pcre 3.1.0 php-composer
|
c-ares 1.34.6-r0 apk
|
||||||
coreutils 9.1-r0 apk
|
ca-certificates 20250911-r0 apk
|
||||||
curl 7.88.1-r0 apk
|
ca-certificates-bundle 20250911-r0 apk
|
||||||
dflydev/dot-access-data v3.0.2 php-composer
|
carbonphp/carbon-doctrine-types 3.2.0 php-composer
|
||||||
doctrine/cache 2.2.0 php-composer
|
catatonit 0.2.1-r0 apk
|
||||||
doctrine/dbal 3.5.1 php-composer
|
clue/stream-filter v1.7.0 php-composer
|
||||||
doctrine/deprecations v1.0.0 php-composer
|
composer 2.9.5 binary
|
||||||
doctrine/event-manager 1.2.0 php-composer
|
composer/class-map-generator 1.6.1 php-composer
|
||||||
doctrine/inflector 2.0.6 php-composer
|
composer/pcre 3.3.2 php-composer
|
||||||
doctrine/instantiator 1.4.1 php-composer
|
coreutils 9.7-r1 apk
|
||||||
doctrine/lexer 1.2.3 php-composer
|
coreutils-env 9.7-r1 apk
|
||||||
dragonmantank/cron-expression v3.3.2 php-composer
|
coreutils-fmt 9.7-r1 apk
|
||||||
egulias/email-validator 2.1.25 php-composer
|
coreutils-sha512sum 9.7-r1 apk
|
||||||
facade/flare-client-php 1.10.0 php-composer
|
curl 8.14.1-r2 apk
|
||||||
facade/ignition 2.17.6 php-composer
|
dflydev/dot-access-data v3.0.3 php-composer
|
||||||
facade/ignition-contracts 1.0.2 php-composer
|
doctrine/inflector 2.0.10 php-composer
|
||||||
fideloper/proxy 4.4.2 php-composer
|
doctrine/lexer 3.0.1 php-composer
|
||||||
filp/whoops 2.14.6 php-composer
|
dragonmantank/cron-expression v3.4.0 php-composer
|
||||||
fzaninotto/faker v1.9.2 php-composer
|
egulias/email-validator 4.0.4 php-composer
|
||||||
git 2.38.4-r0 apk
|
enshrined/svg-sanitize 0.21.0 php-composer
|
||||||
graham-campbell/bounded-cache v1.3.0 php-composer
|
fakerphp/faker v1.24.1 php-composer
|
||||||
graham-campbell/github v10.6.0 php-composer
|
filp/whoops 2.18.3 php-composer
|
||||||
graham-campbell/manager v4.7.0 php-composer
|
findutils 4.10.0-r0 apk
|
||||||
graham-campbell/result-type v1.1.0 php-composer
|
fruitcake/php-cors v1.3.0 php-composer
|
||||||
guzzlehttp/guzzle 7.5.0 php-composer
|
git 2.49.1-r0 apk
|
||||||
guzzlehttp/promises 1.5.2 php-composer
|
git-init-template 2.49.1-r0 apk
|
||||||
guzzlehttp/psr7 2.4.3 php-composer
|
graham-campbell/bounded-cache v3.0.0 php-composer
|
||||||
hamcrest/hamcrest-php v2.0.1 php-composer
|
graham-campbell/github v12.8.0 php-composer
|
||||||
icu-data-en 72.1-r1 apk
|
graham-campbell/manager v5.2.0 php-composer
|
||||||
icu-libs 72.1-r1 apk
|
graham-campbell/result-type v1.1.3 php-composer
|
||||||
jq 1.6-r2 apk
|
guzzlehttp/guzzle 7.9.3 php-composer
|
||||||
knplabs/github-api v3.6.0 php-composer
|
guzzlehttp/promises 2.2.0 php-composer
|
||||||
laravel/framework v8.83.26 php-composer
|
guzzlehttp/psr7 2.7.1 php-composer
|
||||||
laravel/serializable-closure v1.2.2 php-composer
|
guzzlehttp/uri-template v1.0.4 php-composer
|
||||||
laravel/tinker v2.7.3 php-composer
|
hamcrest/hamcrest-php v2.1.1 php-composer
|
||||||
laravel/ui v3.4.6 php-composer
|
icu-data-en 76.1-r1 apk
|
||||||
laravelcollective/html v6.3.0 php-composer
|
icu-libs 76.1-r1 apk
|
||||||
league/commonmark 2.3.7 php-composer
|
jq 1.8.1-r0 apk
|
||||||
league/config v1.1.1 php-composer
|
knplabs/github-api v3.16.0 php-composer
|
||||||
league/flysystem 1.1.10 php-composer
|
laravel/framework v11.45.1 php-composer
|
||||||
league/mime-type-detection 1.11.0 php-composer
|
laravel/prompts v0.3.6 php-composer
|
||||||
libacl 2.3.1-r1 apk
|
laravel/serializable-closure v2.0.4 php-composer
|
||||||
libattr 2.5.1-r2 apk
|
laravel/tinker v2.10.1 php-composer
|
||||||
libbsd 0.11.7-r0 apk
|
laravel/ui v4.6.1 php-composer
|
||||||
libbz2 1.0.8-r4 apk
|
lcobucci/jwt 5.5.0 php-composer
|
||||||
libc-utils 0.7.2-r3 apk
|
league/commonmark 2.7.0 php-composer
|
||||||
libcrypto3 3.0.8-r0 apk
|
league/config v1.2.0 php-composer
|
||||||
libcurl 7.88.1-r0 apk
|
league/flysystem 3.30.0 php-composer
|
||||||
libedit 20221030.3.1-r0 apk
|
league/flysystem-aws-s3-v3 3.29.0 php-composer
|
||||||
libexpat 2.5.0-r0 apk
|
league/flysystem-local 3.30.0 php-composer
|
||||||
libgcc 12.2.1_git20220924-r4 apk
|
league/mime-type-detection 1.16.0 php-composer
|
||||||
libintl 0.21.1-r1 apk
|
league/uri 7.5.1 php-composer
|
||||||
libmd 1.0.4-r0 apk
|
league/uri-interfaces 7.5.0 php-composer
|
||||||
libpq 15.2-r0 apk
|
libapk2 2.14.9-r3 apk
|
||||||
libproc 3.3.17-r2 apk
|
libattr 2.5.2-r2 apk
|
||||||
libssl3 3.0.8-r0 apk
|
libbsd 0.12.2-r0 apk
|
||||||
libstdc++ 12.2.1_git20220924-r4 apk
|
libbz2 1.0.8-r6 apk
|
||||||
libuuid 2.38.1-r1 apk
|
libcrypto3 3.5.5-r0 apk
|
||||||
libxml2 2.10.3-r1 apk
|
libcurl 8.14.1-r2 apk
|
||||||
libzip 1.9.2-r2 apk
|
libedit 20250104.3.1-r1 apk
|
||||||
linux-pam 1.5.2-r1 apk
|
libexpat 2.7.5-r0 apk
|
||||||
logrotate 3.20.1-r3 apk
|
libgcc 14.2.0-r6 apk
|
||||||
mockery/mockery 1.5.1 php-composer
|
libidn2 2.3.7-r0 apk
|
||||||
monolog/monolog 2.8.0 php-composer
|
libintl 0.24.1-r0 apk
|
||||||
musl 1.2.3-r4 apk
|
libmd 1.1.0-r0 apk
|
||||||
musl-utils 1.2.3-r4 apk
|
libncursesw 6.5_p20250503-r0 apk
|
||||||
myclabs/deep-copy 1.11.0 php-composer
|
libpq 17.9-r0 apk
|
||||||
nano 7.0-r0 apk
|
libproc2 4.0.4-r3 apk
|
||||||
ncurses-libs 6.3_p20221119-r0 apk
|
libpsl 0.21.5-r3 apk
|
||||||
ncurses-terminfo-base 6.3_p20221119-r0 apk
|
libssl3 3.5.5-r0 apk
|
||||||
nesbot/carbon 2.63.0 php-composer
|
libstdc++ 14.2.0-r6 apk
|
||||||
netcat-openbsd 1.130-r4 apk
|
libunistring 1.3-r0 apk
|
||||||
nette/schema v1.2.3 php-composer
|
libuuid 2.41-r9 apk
|
||||||
nette/utils v3.2.8 php-composer
|
libxml2 2.13.9-r0 apk
|
||||||
nghttp2-libs 1.51.0-r0 apk
|
libzip 1.11.4-r0 apk
|
||||||
nginx 1.22.1-r0 apk
|
linux-pam 1.7.0-r4 apk
|
||||||
nikic/php-parser v4.15.2 php-composer
|
logrotate 3.21.0-r1 apk
|
||||||
nunomaduro/collision v5.11.0 php-composer
|
mockery/mockery 1.6.12 php-composer
|
||||||
oniguruma 6.9.8-r0 apk
|
monolog/monolog 3.9.0 php-composer
|
||||||
openssl 3.0.8-r0 apk
|
mtdowling/jmespath.php 2.8.0 php-composer
|
||||||
opis/closure 3.6.3 php-composer
|
musl 1.2.5-r10 apk
|
||||||
pcre 8.45-r2 apk
|
musl-utils 1.2.5-r10 apk
|
||||||
pcre2 10.42-r0 apk
|
myclabs/deep-copy 1.13.3 php-composer
|
||||||
phar-io/manifest 2.0.3 php-composer
|
nano 8.4-r0 apk
|
||||||
phar-io/version 3.2.1 php-composer
|
ncurses-terminfo-base 6.5_p20250503-r0 apk
|
||||||
php-cli 8.1.16 binary
|
nesbot/carbon 3.10.1 php-composer
|
||||||
php-fpm 8.1.16 binary
|
netcat-openbsd 1.229.1-r0 apk
|
||||||
php-http/cache-plugin 1.7.5 php-composer
|
nette/schema v1.3.2 php-composer
|
||||||
php-http/client-common 2.6.0 php-composer
|
nette/utils v4.0.7 php-composer
|
||||||
php-http/discovery 1.14.3 php-composer
|
nghttp2-libs 1.65.0-r0 apk
|
||||||
php-http/httplug 2.3.0 php-composer
|
nginx 1.28.3-r0 apk
|
||||||
php-http/message 1.13.0 php-composer
|
nikic/php-parser v5.5.0 php-composer
|
||||||
php-http/message-factory v1.0.2 php-composer
|
nunomaduro/collision v8.5.0 php-composer
|
||||||
php-http/multipart-stream-builder 1.2.0 php-composer
|
nunomaduro/termwind v2.3.1 php-composer
|
||||||
php-http/promise 1.1.0 php-composer
|
oniguruma 6.9.10-r0 apk
|
||||||
php81 8.1.16-r0 apk
|
openssl 3.5.5-r0 apk
|
||||||
php81-common 8.1.16-r0 apk
|
pcre2 10.46-r0 apk
|
||||||
php81-ctype 8.1.16-r0 apk
|
phar-io/manifest 2.0.4 php-composer
|
||||||
php81-curl 8.1.16-r0 apk
|
phar-io/version 3.2.1 php-composer
|
||||||
php81-fileinfo 8.1.16-r0 apk
|
php-http/cache-plugin 2.0.1 php-composer
|
||||||
php81-fpm 8.1.16-r0 apk
|
php-http/client-common 2.7.2 php-composer
|
||||||
php81-intl 8.1.16-r0 apk
|
php-http/discovery 1.20.0 php-composer
|
||||||
php81-mbstring 8.1.16-r0 apk
|
php-http/httplug 2.4.1 php-composer
|
||||||
php81-mysqlnd 8.1.16-r0 apk
|
php-http/message 1.16.2 php-composer
|
||||||
php81-openssl 8.1.16-r0 apk
|
php-http/multipart-stream-builder 1.4.2 php-composer
|
||||||
php81-pdo 8.1.16-r0 apk
|
php-http/promise 1.3.1 php-composer
|
||||||
php81-pdo_mysql 8.1.16-r0 apk
|
php84 8.4.16-r0 apk
|
||||||
php81-pdo_pgsql 8.1.16-r0 apk
|
php84-common 8.4.16-r0 apk
|
||||||
php81-pdo_sqlite 8.1.16-r0 apk
|
php84-ctype 8.4.16-r0 apk
|
||||||
php81-session 8.1.16-r0 apk
|
php84-curl 8.4.16-r0 apk
|
||||||
php81-simplexml 8.1.16-r0 apk
|
php84-dom 8.4.16-r0 apk
|
||||||
php81-tokenizer 8.1.16-r0 apk
|
php84-fileinfo 8.4.16-r0 apk
|
||||||
php81-xml 8.1.16-r0 apk
|
php84-fpm 8.4.16-r0 apk
|
||||||
php81-xmlwriter 8.1.16-r0 apk
|
php84-iconv 8.4.16-r0 apk
|
||||||
php81-zip 8.1.16-r0 apk
|
php84-intl 8.4.16-r0 apk
|
||||||
phpdocumentor/reflection-common 2.2.0 php-composer
|
php84-mbstring 8.4.16-r0 apk
|
||||||
phpdocumentor/type-resolver 1.6.2 php-composer
|
php84-mysqlnd 8.4.16-r0 apk
|
||||||
phpoption/phpoption 1.9.0 php-composer
|
php84-opcache 8.4.16-r0 apk
|
||||||
phpunit/php-code-coverage 9.2.19 php-composer
|
php84-openssl 8.4.16-r0 apk
|
||||||
phpunit/php-file-iterator 3.0.6 php-composer
|
php84-pdo 8.4.16-r0 apk
|
||||||
phpunit/php-invoker 3.1.1 php-composer
|
php84-pdo_mysql 8.4.16-r0 apk
|
||||||
phpunit/php-text-template 2.0.4 php-composer
|
php84-pdo_pgsql 8.4.16-r0 apk
|
||||||
phpunit/php-timer 5.0.3 php-composer
|
php84-pdo_sqlite 8.4.16-r0 apk
|
||||||
phpunit/phpunit 9.5.26 php-composer
|
php84-phar 8.4.16-r0 apk
|
||||||
popt 1.19-r0 apk
|
php84-session 8.4.16-r0 apk
|
||||||
procps 3.3.17-r2 apk
|
php84-simplexml 8.4.16-r0 apk
|
||||||
psr/cache 1.0.1 php-composer
|
php84-tokenizer 8.4.16-r0 apk
|
||||||
psr/container 1.1.2 php-composer
|
php84-xml 8.4.16-r0 apk
|
||||||
psr/event-dispatcher 1.0.0 php-composer
|
php84-xmlwriter 8.4.16-r0 apk
|
||||||
psr/http-client 1.0.1 php-composer
|
php84-zip 8.4.16-r0 apk
|
||||||
psr/http-factory 1.0.1 php-composer
|
phpoption/phpoption 1.9.3 php-composer
|
||||||
psr/http-message 1.0.1 php-composer
|
phpunit/php-code-coverage 10.1.16 php-composer
|
||||||
psr/log 1.1.4 php-composer
|
phpunit/php-file-iterator 4.1.0 php-composer
|
||||||
psr/simple-cache 1.0.1 php-composer
|
phpunit/php-invoker 4.0.0 php-composer
|
||||||
psy/psysh v0.11.9 php-composer
|
phpunit/php-text-template 3.0.1 php-composer
|
||||||
ralouphie/getallheaders 3.0.3 php-composer
|
phpunit/php-timer 6.0.0 php-composer
|
||||||
ramsey/collection 1.2.2 php-composer
|
phpunit/phpunit 10.5.47 php-composer
|
||||||
ramsey/uuid 4.2.3 php-composer
|
popt 1.19-r4 apk
|
||||||
readline 8.2.0-r0 apk
|
procps-ng 4.0.4-r3 apk
|
||||||
scanelf 1.3.5-r1 apk
|
psr/cache 3.0.0 php-composer
|
||||||
sebastian/cli-parser 1.0.1 php-composer
|
psr/clock 1.0.0 php-composer
|
||||||
sebastian/code-unit 1.0.8 php-composer
|
psr/container 2.0.2 php-composer
|
||||||
sebastian/code-unit-reverse-lookup 2.0.3 php-composer
|
psr/event-dispatcher 1.0.0 php-composer
|
||||||
sebastian/comparator 4.0.8 php-composer
|
psr/http-client 1.0.3 php-composer
|
||||||
sebastian/complexity 2.0.2 php-composer
|
psr/http-factory 1.1.0 php-composer
|
||||||
sebastian/diff 4.0.4 php-composer
|
psr/http-message 2.0 php-composer
|
||||||
sebastian/environment 5.1.4 php-composer
|
psr/log 3.0.2 php-composer
|
||||||
sebastian/exporter 4.0.5 php-composer
|
psr/simple-cache 3.0.0 php-composer
|
||||||
sebastian/global-state 5.0.5 php-composer
|
psy/psysh v0.12.9 php-composer
|
||||||
sebastian/lines-of-code 1.0.3 php-composer
|
ralouphie/getallheaders 3.0.3 php-composer
|
||||||
sebastian/object-enumerator 4.0.4 php-composer
|
ramsey/collection 2.1.1 php-composer
|
||||||
sebastian/object-reflector 2.0.4 php-composer
|
ramsey/uuid 4.9.0 php-composer
|
||||||
sebastian/recursion-context 4.0.4 php-composer
|
readline 8.2.13-r1 apk
|
||||||
sebastian/resource-operations 3.0.3 php-composer
|
scanelf 1.3.8-r1 apk
|
||||||
sebastian/type 3.2.0 php-composer
|
sebastian/cli-parser 2.0.1 php-composer
|
||||||
sebastian/version 3.0.2 php-composer
|
sebastian/code-unit 2.0.0 php-composer
|
||||||
shadow 4.13-r0 apk
|
sebastian/code-unit-reverse-lookup 3.0.0 php-composer
|
||||||
skalibs 2.12.0.1-r0 apk
|
sebastian/comparator 5.0.3 php-composer
|
||||||
sqlite-libs 3.40.1-r0 apk
|
sebastian/complexity 3.2.0 php-composer
|
||||||
squizlabs/php_codesniffer 3.7.1 php-composer
|
sebastian/diff 5.1.1 php-composer
|
||||||
ssl_client 1.35.0-r29 apk
|
sebastian/environment 6.1.0 php-composer
|
||||||
swiftmailer/swiftmailer v6.3.0 php-composer
|
sebastian/exporter 5.1.2 php-composer
|
||||||
symfony/cache v5.4.15 php-composer
|
sebastian/global-state 6.0.2 php-composer
|
||||||
symfony/cache-contracts v2.5.2 php-composer
|
sebastian/lines-of-code 2.0.2 php-composer
|
||||||
symfony/console v5.4.15 php-composer
|
sebastian/object-enumerator 5.0.0 php-composer
|
||||||
symfony/css-selector v5.4.11 php-composer
|
sebastian/object-reflector 3.0.0 php-composer
|
||||||
symfony/deprecation-contracts v2.5.2 php-composer
|
sebastian/recursion-context 5.0.0 php-composer
|
||||||
symfony/error-handler v5.4.15 php-composer
|
sebastian/type 4.0.0 php-composer
|
||||||
symfony/event-dispatcher v5.4.9 php-composer
|
sebastian/version 4.0.1 php-composer
|
||||||
symfony/event-dispatcher-contracts v2.5.2 php-composer
|
shadow 4.17.3-r0 apk
|
||||||
symfony/finder v5.4.11 php-composer
|
skalibs-libs 2.14.4.0-r0 apk
|
||||||
symfony/http-foundation v5.4.15 php-composer
|
spatie/backtrace 1.7.4 php-composer
|
||||||
symfony/http-kernel v5.4.15 php-composer
|
spatie/error-solutions 1.1.3 php-composer
|
||||||
symfony/mime v5.4.14 php-composer
|
spatie/flare-client-php 1.10.1 php-composer
|
||||||
symfony/options-resolver v5.4.11 php-composer
|
spatie/ignition 1.15.1 php-composer
|
||||||
symfony/polyfill-ctype v1.27.0 php-composer
|
spatie/laravel-html 3.12.0 php-composer
|
||||||
symfony/polyfill-iconv v1.27.0 php-composer
|
spatie/laravel-ignition 2.9.1 php-composer
|
||||||
symfony/polyfill-intl-grapheme v1.27.0 php-composer
|
sqlite-libs 3.49.2-r1 apk
|
||||||
symfony/polyfill-intl-idn v1.27.0 php-composer
|
squizlabs/php_codesniffer 3.13.2 php-composer
|
||||||
symfony/polyfill-intl-normalizer v1.27.0 php-composer
|
ssl_client 1.37.0-r20 apk
|
||||||
symfony/polyfill-mbstring v1.27.0 php-composer
|
symfony/cache v7.3.1 php-composer
|
||||||
symfony/polyfill-php72 v1.27.0 php-composer
|
symfony/cache-contracts v3.6.0 php-composer
|
||||||
symfony/polyfill-php73 v1.27.0 php-composer
|
symfony/clock v7.3.0 php-composer
|
||||||
symfony/polyfill-php80 v1.27.0 php-composer
|
symfony/console v7.3.1 php-composer
|
||||||
symfony/polyfill-php81 v1.27.0 php-composer
|
symfony/css-selector v7.3.0 php-composer
|
||||||
symfony/process v5.4.11 php-composer
|
symfony/deprecation-contracts v3.6.0 php-composer
|
||||||
symfony/routing v5.4.15 php-composer
|
symfony/error-handler v7.3.1 php-composer
|
||||||
symfony/service-contracts v2.5.2 php-composer
|
symfony/event-dispatcher v7.3.0 php-composer
|
||||||
symfony/string v5.4.15 php-composer
|
symfony/event-dispatcher-contracts v3.6.0 php-composer
|
||||||
symfony/thanks v1.2.10 php-composer
|
symfony/finder v7.3.0 php-composer
|
||||||
symfony/translation v5.4.14 php-composer
|
symfony/http-foundation v7.3.1 php-composer
|
||||||
symfony/translation-contracts v2.5.2 php-composer
|
symfony/http-kernel v7.3.1 php-composer
|
||||||
symfony/var-dumper v5.4.14 php-composer
|
symfony/mailer v7.3.1 php-composer
|
||||||
symfony/var-exporter v5.4.10 php-composer
|
symfony/mime v7.3.0 php-composer
|
||||||
symfony/yaml v5.4.14 php-composer
|
symfony/options-resolver v7.3.0 php-composer
|
||||||
theseer/tokenizer 1.2.1 php-composer
|
symfony/polyfill-ctype v1.32.0 php-composer
|
||||||
tijsverkoyen/css-to-inline-styles 2.2.5 php-composer
|
symfony/polyfill-intl-grapheme v1.32.0 php-composer
|
||||||
tzdata 2022f-r1 apk
|
symfony/polyfill-intl-idn v1.32.0 php-composer
|
||||||
utmps-libs 0.1.2.0-r1 apk
|
symfony/polyfill-intl-normalizer v1.32.0 php-composer
|
||||||
vlucas/phpdotenv v5.5.0 php-composer
|
symfony/polyfill-mbstring v1.32.0 php-composer
|
||||||
voku/portable-ascii 1.6.1 php-composer
|
symfony/polyfill-php80 v1.32.0 php-composer
|
||||||
webmozart/assert 1.11.0 php-composer
|
symfony/polyfill-php83 v1.32.0 php-composer
|
||||||
xz 5.2.9-r0 apk
|
symfony/polyfill-uuid v1.32.0 php-composer
|
||||||
xz-libs 5.2.9-r0 apk
|
symfony/process v7.3.0 php-composer
|
||||||
zlib 1.2.13-r0 apk
|
symfony/routing v7.3.0 php-composer
|
||||||
zstd-libs 1.5.2-r9 apk
|
symfony/service-contracts v3.6.0 php-composer
|
||||||
|
symfony/string v7.3.0 php-composer
|
||||||
|
symfony/thanks v1.4.0 php-composer
|
||||||
|
symfony/translation v7.3.1 php-composer
|
||||||
|
symfony/translation-contracts v3.6.0 php-composer
|
||||||
|
symfony/uid v7.3.1 php-composer
|
||||||
|
symfony/var-dumper v7.3.1 php-composer
|
||||||
|
symfony/var-exporter v7.3.0 php-composer
|
||||||
|
symfony/yaml v7.3.1 php-composer
|
||||||
|
theseer/tokenizer 1.2.3 php-composer
|
||||||
|
tijsverkoyen/css-to-inline-styles v2.3.0 php-composer
|
||||||
|
tzdata 2026a-r0 apk
|
||||||
|
utmps-libs 0.1.3.1-r0 apk
|
||||||
|
vlucas/phpdotenv v5.6.2 php-composer
|
||||||
|
voku/portable-ascii 2.0.3 php-composer
|
||||||
|
webmozart/assert 1.11.0 php-composer
|
||||||
|
xz-libs 5.8.1-r0 apk
|
||||||
|
zlib 1.3.1-r2 apk
|
||||||
|
zstd-libs 1.5.7-r0 apk
|
||||||
|
|||||||
143
readme-vars.yml
143
readme-vars.yml
@@ -11,73 +11,118 @@ project_blurb: |
|
|||||||
|
|
||||||
Why not use it as your browser start page? It even has the ability to include a search bar using either Google, Bing or DuckDuckGo.
|
Why not use it as your browser start page? It even has the ability to include a search bar using either Google, Bing or DuckDuckGo.
|
||||||
project_lsio_github_repo_url: "https://github.com/linuxserver/docker-{{ project_name }}"
|
project_lsio_github_repo_url: "https://github.com/linuxserver/docker-{{ project_name }}"
|
||||||
|
|
||||||
# supported architectures
|
# supported architectures
|
||||||
available_architectures:
|
available_architectures:
|
||||||
- { arch: "{{ arch_x86_64 }}", tag: "amd64-latest"}
|
- {arch: "{{ arch_x86_64 }}", tag: "amd64-latest"}
|
||||||
- { arch: "{{ arch_arm64 }}", tag: "arm64v8-latest"}
|
- {arch: "{{ arch_arm64 }}", tag: "arm64v8-latest"}
|
||||||
- { arch: "{{ arch_armhf }}", tag: "arm32v7-latest"}
|
|
||||||
|
|
||||||
# development version
|
# development version
|
||||||
development_versions: true
|
development_versions: true
|
||||||
development_versions_items:
|
development_versions_items:
|
||||||
- { tag: "latest", desc: "Stable Heimdall releases." }
|
- {tag: "latest", desc: "Stable Heimdall releases."}
|
||||||
- { tag: "development", desc: "Latest commit from the github 2.x branch." }
|
- {tag: "development", desc: "Latest commit from the github 2.x branch."}
|
||||||
|
|
||||||
# container parameters
|
# container parameters
|
||||||
common_param_env_vars_enabled: true
|
common_param_env_vars_enabled: true
|
||||||
param_container_name: "{{ project_name }}"
|
param_container_name: "{{ project_name }}"
|
||||||
param_usage_include_vols: true
|
param_usage_include_vols: true
|
||||||
param_volumes:
|
param_volumes:
|
||||||
- { vol_path: "/config", vol_host_path: "/path/to/appdata/config", desc: "Contains all relevant configuration files." }
|
- {vol_path: "/config", vol_host_path: "/path/to/{{ project_name }}/config", desc: "Persistent config files"}
|
||||||
param_usage_include_ports: true
|
param_usage_include_ports: true
|
||||||
param_ports:
|
param_ports:
|
||||||
- { external_port: "80", internal_port: "80", port_desc: "http gui" }
|
- {external_port: "80", internal_port: "80", port_desc: "http gui"}
|
||||||
- { external_port: "443", internal_port: "443", port_desc: "https gui" }
|
- {external_port: "443", internal_port: "443", port_desc: "https gui"}
|
||||||
param_usage_include_env: true
|
opt_param_usage_include_env: true
|
||||||
param_env_vars:
|
opt_param_env_vars:
|
||||||
- { env_var: "TZ", env_value: "Europe/London", desc: "Specify a timezone to use EG Europe/London"}
|
- {env_var: "ALLOW_INTERNAL_REQUESTS", env_value: "false", desc: "By default, Heimdall blocks lookup requests to private or reserved IP addresses, if your instance is not exposed to the internet, or is behind some level of authentication, you can set this to `true` to allow requests to private IP addresses."}
|
||||||
|
|
||||||
# optional parameters
|
|
||||||
optional_block_1: false
|
|
||||||
optional_block_1_items:
|
|
||||||
- |
|
|
||||||
Using tags, you can switch between the stable releases of Heimdall and the master branch. No tag is required for the latest stable release.
|
|
||||||
Add the development tag, if required, to the linuxserver/heimdall line of the run/create command in the following format, linuxserver/heimdall:development
|
|
||||||
The development tag will be the latest commit in the master branch of Heimdall.
|
|
||||||
HOWEVER , USE THE DEVELOPMENT TAG AT YOUR OWN PERIL !!!!!!!!!
|
|
||||||
|
|
||||||
# application setup block
|
# application setup block
|
||||||
app_setup_block_enabled: true
|
app_setup_block_enabled: true
|
||||||
app_setup_block: |
|
app_setup_block: |
|
||||||
Access the web gui at http://SERVERIP:PORT
|
Access the web gui at http://SERVERIP:PORT
|
||||||
|
|
||||||
|
|
||||||
### Adding password protection
|
### Adding password protection
|
||||||
|
|
||||||
This image now supports password protection through htpasswd. Run the following command on your host to generate the htpasswd file `docker exec -it heimdall htpasswd -c /config/nginx/.htpasswd <username>`. Replace <username> with a username of your choice and you will be asked to enter a password. Uncomment the `basic auth` lines in `/config/nginx/site-confs/default.conf` and restart the container.
|
|
||||||
|
|
||||||
|
This image now supports password protection through htpasswd. Run the following command on your host to generate the htpasswd file `docker exec -it heimdall htpasswd -c /config/nginx/.htpasswd <username>`. Replace <username> with a username of your choice and you will be asked to enter a password. Uncomment the `basic auth` lines in `/config/nginx/site-confs/default.conf` and restart the container.
|
||||||
|
# init diagram
|
||||||
|
init_diagram: |
|
||||||
|
"heimdall:development": {
|
||||||
|
docker-mods
|
||||||
|
base {
|
||||||
|
fix-attr +\nlegacy cont-init
|
||||||
|
}
|
||||||
|
docker-mods -> base
|
||||||
|
legacy-services
|
||||||
|
custom services
|
||||||
|
init-services -> legacy-services
|
||||||
|
init-services -> custom services
|
||||||
|
custom services -> legacy-services
|
||||||
|
legacy-services -> ci-service-check
|
||||||
|
init-migrations -> init-adduser
|
||||||
|
init-nginx-end -> init-config
|
||||||
|
init-os-end -> init-config
|
||||||
|
init-config -> init-config-end
|
||||||
|
init-crontab-config -> init-config-end
|
||||||
|
init-heimdall-config -> init-config-end
|
||||||
|
init-config -> init-crontab-config
|
||||||
|
init-mods-end -> init-custom-files
|
||||||
|
init-adduser -> init-device-perms
|
||||||
|
base -> init-envfile
|
||||||
|
init-os-end -> init-folders
|
||||||
|
init-nginx-end -> init-heimdall-config
|
||||||
|
init-php -> init-keygen
|
||||||
|
base -> init-migrations
|
||||||
|
init-config-end -> init-mods
|
||||||
|
init-mods-package-install -> init-mods-end
|
||||||
|
init-mods -> init-mods-package-install
|
||||||
|
init-samples -> init-nginx
|
||||||
|
init-version-checks -> init-nginx-end
|
||||||
|
init-adduser -> init-os-end
|
||||||
|
init-device-perms -> init-os-end
|
||||||
|
init-envfile -> init-os-end
|
||||||
|
init-keygen -> init-permissions
|
||||||
|
init-nginx -> init-php
|
||||||
|
init-folders -> init-samples
|
||||||
|
init-custom-files -> init-services
|
||||||
|
init-permissions -> init-version-checks
|
||||||
|
init-services -> svc-cron
|
||||||
|
svc-cron -> legacy-services
|
||||||
|
init-services -> svc-nginx
|
||||||
|
svc-nginx -> legacy-services
|
||||||
|
init-services -> svc-php-fpm
|
||||||
|
svc-php-fpm -> legacy-services
|
||||||
|
init-services -> svc-queue
|
||||||
|
svc-queue -> legacy-services
|
||||||
|
}
|
||||||
|
Base Images: {
|
||||||
|
"baseimage-alpine-nginx:3.22" <- "baseimage-alpine:3.22"
|
||||||
|
}
|
||||||
|
"heimdall:development" <- Base Images
|
||||||
# changelog
|
# changelog
|
||||||
changelogs:
|
changelogs:
|
||||||
- { date: "20.01.23:", desc: "Rebase to alpine 3.17 with php8.1." }
|
- {date: "17.07.25:", desc: "Rebase to Alpine 3.22, enable PHP environment passthrough."}
|
||||||
- { date: "14.11.22:", desc: "Rebasing to alpine 3.15 with php8. Restructure nginx configs ([see changes announcement](https://info.linuxserver.io/issues/2022-08-20-nginx-base))." }
|
- {date: "27.06.24:", desc: "Rebase to Alpine 3.20. Existing users should update their nginx confs to avoid http2 deprecation warnings."}
|
||||||
- { date: "04.11.22:", desc: "Build commits to upstream branch 2.x." }
|
- {date: "07.03.24:", desc: "Enable the opcache and disable file revalidation."}
|
||||||
- { date: "13.03.21:", desc: "Make searchproviders.yaml user configurable." }
|
- {date: "06.03.24:", desc: "Existing users should update: site-confs/default.conf - Cleanup default site conf."}
|
||||||
- { date: "11.03.21:", desc: "Rebase to alpine 3.14." }
|
- {date: "23.12.23:", desc: "Rebase to Alpine 3.19 with php 8.3."}
|
||||||
- { date: "10.02.21:", desc: "Revert to alpine 3.12 as php 7.4 broke laravel." }
|
- {date: "25.05.23:", desc: "Rebase to Alpine 3.18, deprecate armhf."}
|
||||||
- { date: "10.02.21:", desc: "Rebasing to alpine 3.13." }
|
- {date: "13.04.23:", desc: "Move ssl.conf include to default.conf."}
|
||||||
- { date: "01.06.20:", desc: "Rebasing to alpine 3.12." }
|
- {date: "20.01.23:", desc: "Rebase to alpine 3.17 with php8.1."}
|
||||||
- { date: "19.12.19:", desc: "Rebasing to alpine 3.11." }
|
- {date: "14.11.22:", desc: "Rebasing to alpine 3.15 with php8. Restructure nginx configs ([see changes announcement](https://info.linuxserver.io/issues/2022-08-20-nginx-base))."}
|
||||||
- { date: "15.07.19:", desc: "Save laravel.log to /config, install heimdall during first start." }
|
- {date: "04.11.22:", desc: "Build commits to upstream branch 2.x."}
|
||||||
- { date: "28.06.19:", desc: "Rebasing to alpine 3.10." }
|
- {date: "13.03.21:", desc: "Make searchproviders.yaml user configurable."}
|
||||||
- { date: "23.03.19:", desc: "Switching to new Base images, shift to arm32v7 tag." }
|
- {date: "11.03.21:", desc: "Rebase to alpine 3.14."}
|
||||||
- { date: "22.02.19:", desc: "Rebasing to alpine 3.9." }
|
- {date: "10.02.21:", desc: "Revert to alpine 3.12 as php 7.4 broke laravel."}
|
||||||
- { date: "04.11.18:", desc: "Add php7-zip." }
|
- {date: "10.02.21:", desc: "Rebasing to alpine 3.13."}
|
||||||
- { date: "31.10.18:", desc: "Add queue service." }
|
- {date: "01.06.20:", desc: "Rebasing to alpine 3.12."}
|
||||||
- { date: "17.10.18:", desc: "Symlink avatars folder." }
|
- {date: "19.12.19:", desc: "Rebasing to alpine 3.11."}
|
||||||
- { date: "16.10.18:", desc: "Updated fastcgi_params for user login support." }
|
- {date: "15.07.19:", desc: "Save laravel.log to /config, install heimdall during first start."}
|
||||||
- { date: "07.10.18:", desc: "Symlink `.env` rather than copy. It now resides under `/config/www`" }
|
- {date: "28.06.19:", desc: "Rebasing to alpine 3.10."}
|
||||||
- { date: "30.09.18:", desc: "Multi-arch image. Move `.env` to `/config`." }
|
- {date: "23.03.19:", desc: "Switching to new Base images, shift to arm32v7 tag."}
|
||||||
- { date: "05.09.18:", desc: "Rebase to alpine linux 3.8." }
|
- {date: "22.02.19:", desc: "Rebasing to alpine 3.9."}
|
||||||
- { date: "06.03.18:", desc: "Use password protection if htpasswd is set. Existing users can delete their default site config at /config/nginx/site-confs/default.conf and restart the container, a new default site config with htpasswd support will be created in its place" }
|
- {date: "04.11.18:", desc: "Add php7-zip."}
|
||||||
- { date: "12.02.18:", desc: "Initial Release." }
|
- {date: "31.10.18:", desc: "Add queue service."}
|
||||||
|
- {date: "17.10.18:", desc: "Symlink avatars folder."}
|
||||||
|
- {date: "16.10.18:", desc: "Updated fastcgi_params for user login support."}
|
||||||
|
- {date: "07.10.18:", desc: "Symlink `.env` rather than copy. It now resides under `/config/www`"}
|
||||||
|
- {date: "30.09.18:", desc: "Multi-arch image. Move `.env` to `/config`."}
|
||||||
|
- {date: "05.09.18:", desc: "Rebase to alpine linux 3.8."}
|
||||||
|
- {date: "06.03.18:", desc: "Use password protection if htpasswd is set. Existing users can delete their default site config at /config/nginx/site-confs/default.conf and restart the container, a new default site config with htpasswd support will be created in its place"}
|
||||||
|
- {date: "12.02.18:", desc: "Initial Release."}
|
||||||
|
|||||||
@@ -1,34 +0,0 @@
|
|||||||
## Version 2022/11/14 - Changelog: https://github.com/linuxserver/docker-heimdall/commits/master/root/defaults/nginx/site-confs/default.conf.sample
|
|
||||||
|
|
||||||
server {
|
|
||||||
listen 80 default_server;
|
|
||||||
listen [::]:80 default_server;
|
|
||||||
|
|
||||||
listen 443 ssl http2 default_server;
|
|
||||||
listen [::]:443 ssl http2 default_server;
|
|
||||||
|
|
||||||
server_name _;
|
|
||||||
|
|
||||||
root /app/www/public;
|
|
||||||
index index.html index.htm index.php;
|
|
||||||
|
|
||||||
location / {
|
|
||||||
# enable for basic auth
|
|
||||||
#auth_basic "Restricted";
|
|
||||||
#auth_basic_user_file /config/nginx/.htpasswd;
|
|
||||||
|
|
||||||
try_files $uri $uri/ /index.html /index.php$is_args$args;
|
|
||||||
}
|
|
||||||
|
|
||||||
location ~ ^(.+\.php)(.*)$ {
|
|
||||||
fastcgi_split_path_info ^(.+\.php)(.*)$;
|
|
||||||
fastcgi_pass 127.0.0.1:9000;
|
|
||||||
fastcgi_index index.php;
|
|
||||||
include /etc/nginx/fastcgi_params;
|
|
||||||
}
|
|
||||||
|
|
||||||
# deny access to .htaccess/.htpasswd files
|
|
||||||
location ~ /\.ht {
|
|
||||||
deny all;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
@@ -1,4 +1,5 @@
|
|||||||
#!/usr/bin/with-contenv bash
|
#!/usr/bin/with-contenv bash
|
||||||
|
# shellcheck shell=bash
|
||||||
|
|
||||||
exec \
|
exec \
|
||||||
s6-setuidgid abc php /app/www/artisan queue:work database --sleep=3 --tries=3
|
s6-setuidgid abc php /app/www/artisan queue:work database --sleep=3 --tries=3
|
||||||
|
|||||||
3
root/migrations/02-default-location
Normal file → Executable file
3
root/migrations/02-default-location
Normal file → Executable file
@@ -1,10 +1,11 @@
|
|||||||
#!/usr/bin/with-contenv bash
|
#!/usr/bin/with-contenv bash
|
||||||
|
# shellcheck shell=bash
|
||||||
|
|
||||||
DEFAULT_CONF="/config/nginx/site-confs/default.conf"
|
DEFAULT_CONF="/config/nginx/site-confs/default.conf"
|
||||||
OLD_ROOT="root /var/www/localhost/heimdall/public;"
|
OLD_ROOT="root /var/www/localhost/heimdall/public;"
|
||||||
NEW_ROOT="root /app/www/public;"
|
NEW_ROOT="root /app/www/public;"
|
||||||
|
|
||||||
if grep -q "${OLD_ROOT}" "${DEFAULT_CONF}" 2>/dev/null; then
|
if [[ -f "${DEFAULT_CONF}" ]] && grep -q "${OLD_ROOT}" "${DEFAULT_CONF}" 2>/dev/null; then
|
||||||
echo "updating root in ${DEFAULT_CONF}"
|
echo "updating root in ${DEFAULT_CONF}"
|
||||||
sed -i "s|${OLD_ROOT}|${NEW_ROOT}|" "${DEFAULT_CONF}"
|
sed -i "s|${OLD_ROOT}|${NEW_ROOT}|" "${DEFAULT_CONF}"
|
||||||
fi
|
fi
|
||||||
|
|||||||
Reference in New Issue
Block a user