mirror of
https://github.com/linuxserver/docker-emulatorjs.git
synced 2026-03-09 00:04:53 +08:00
Compare commits
180 Commits
1.7.2-ls58
...
master
| Author | SHA1 | Date | |
|---|---|---|---|
|
|
282a248181 | ||
|
|
1857495aef | ||
|
|
c60b35de70 | ||
|
|
59a5e09712 | ||
|
|
e799453428 | ||
|
|
69fe5ddeaf | ||
|
|
64d89ece56 | ||
|
|
63435a970d | ||
|
|
1a9b47a400 | ||
|
|
1dd8c60c45 | ||
|
|
0519a9b4f5 | ||
|
|
8647f0c047 | ||
|
|
0ef44e8bd5 | ||
|
|
eae885e0dd | ||
|
|
64991fff0c | ||
|
|
a763f33c85 | ||
|
|
1bcd8ffb17 | ||
|
|
7f0f5869a6 | ||
|
|
53dc85f901 | ||
|
|
feb8af4ed5 | ||
|
|
bd04d61797 | ||
|
|
667090250d | ||
|
|
1e36b65b4a | ||
|
|
d0129dd019 | ||
|
|
ec9f47745e | ||
|
|
76e0448701 | ||
|
|
0b8bdab955 | ||
|
|
a20a604817 | ||
|
|
3f26f12b27 | ||
|
|
e68566f565 | ||
|
|
d42cd8e491 | ||
|
|
aa002dd0bc | ||
|
|
88efc43363 | ||
|
|
26f14248dd | ||
|
|
f4d3168e38 | ||
|
|
a243d4f7a7 | ||
|
|
f6bf0fcbe9 | ||
|
|
3e512ec577 | ||
|
|
abac616ab8 | ||
|
|
686a2b3231 | ||
|
|
d2a1cdb8f5 | ||
|
|
bcca693952 | ||
|
|
75141b0811 | ||
|
|
57f7cf5e91 | ||
|
|
aba0dabf0b | ||
|
|
ec12eb6566 | ||
|
|
ef36ff5117 | ||
|
|
24cfedf13e | ||
|
|
4b7f4dd386 | ||
|
|
982312e6ae | ||
|
|
3b5e0b9ec4 | ||
|
|
8a04c9d36b | ||
|
|
92e0fdf514 | ||
|
|
f63e798af3 | ||
|
|
47db5ebaa1 | ||
|
|
9b57a5649c | ||
|
|
292940bf7f | ||
|
|
82c2cfcfb8 | ||
|
|
b1fc81f0c9 | ||
|
|
0667564015 | ||
|
|
1e4e142b2e | ||
|
|
aaf419dc92 | ||
|
|
bca1f166e4 | ||
|
|
21bf62cc8c | ||
|
|
21a2e9329a | ||
|
|
b5466c9b65 | ||
|
|
0e68b3cd19 | ||
|
|
f4e77c564c | ||
|
|
53381296a2 | ||
|
|
0c168bb747 | ||
|
|
61071b349d | ||
|
|
ee343d3e9a | ||
|
|
75925a9a75 | ||
|
|
9ec90bd353 | ||
|
|
024579e127 | ||
|
|
4a8a23120c | ||
|
|
bf0a1a9a17 | ||
|
|
e091f4cd56 | ||
|
|
f23f4cd67f | ||
|
|
bff8af3870 | ||
|
|
15c2a229a9 | ||
|
|
2f538d07de | ||
|
|
6c212c36af | ||
|
|
60ec88be1f | ||
|
|
cb3cd5cee7 | ||
|
|
1d5f4ee483 | ||
|
|
f3dae87d86 | ||
|
|
5ca8e873c7 | ||
|
|
6d5cf193f3 | ||
|
|
7f1311a179 | ||
|
|
948d0fbbb7 | ||
|
|
e4fffbf73a | ||
|
|
fa5e93e96a | ||
|
|
eaf391ec63 | ||
|
|
f81be34d28 | ||
|
|
4597160511 | ||
|
|
2731c10ca4 | ||
|
|
c7df8df301 | ||
|
|
672780fd04 | ||
|
|
93d22007a5 | ||
|
|
d408db8dc3 | ||
|
|
e163cfa09c | ||
|
|
f4e6cb5f74 | ||
|
|
7293ed3265 | ||
|
|
e22315c0b2 | ||
|
|
ddfcd52e6a | ||
|
|
8b74fb7ffc | ||
|
|
55669d8601 | ||
|
|
9a5673344d | ||
|
|
118b516666 | ||
|
|
17b43c6240 | ||
|
|
832f342e67 | ||
|
|
8f071a242d | ||
|
|
25881395cb | ||
|
|
a47f465a36 | ||
|
|
676ad1fb1d | ||
|
|
32c91f6c1f | ||
|
|
de2b9cacda | ||
|
|
19b2ca9c9b | ||
|
|
766c10d164 | ||
|
|
077c5b73f7 | ||
|
|
7d5d7d94b1 | ||
|
|
9302f8306b | ||
|
|
c564255827 | ||
|
|
011aba3786 | ||
|
|
2c3043f025 | ||
|
|
82e2cca37e | ||
|
|
145197f357 | ||
|
|
f71e16b467 | ||
|
|
3d4c49aa30 | ||
|
|
db69c78fe7 | ||
|
|
06d74d237b | ||
|
|
6a456bdd06 | ||
|
|
11bd0aea18 | ||
|
|
bfd842b1c6 | ||
|
|
21b8d8eda6 | ||
|
|
33f1554009 | ||
|
|
e4dbad2f05 | ||
|
|
e4d9256d66 | ||
|
|
28febbf342 | ||
|
|
2cecb66ea3 | ||
|
|
178c9cae5b | ||
|
|
52cf02afaf | ||
|
|
ab9ea07a34 | ||
|
|
b5f8acc35c | ||
|
|
25d024e768 | ||
|
|
d08e9af68e | ||
|
|
a2c7392fe3 | ||
|
|
986332a28d | ||
|
|
358b4a8177 | ||
|
|
ab942a6971 | ||
|
|
c4c67c4f04 | ||
|
|
659a5720ad | ||
|
|
972ae48c8b | ||
|
|
e8da9160f7 | ||
|
|
370bc9f967 | ||
|
|
2b2851e2ca | ||
|
|
a9cff79a6e | ||
|
|
e406810bc6 | ||
|
|
b830e816b4 | ||
|
|
acb975371a | ||
|
|
74a569f02f | ||
|
|
677b19d17b | ||
|
|
391d9d4281 | ||
|
|
07e0bf61a7 | ||
|
|
2a0617e67f | ||
|
|
d59e15ad92 | ||
|
|
02cb15ad71 | ||
|
|
5e530fd156 | ||
|
|
ce4b62e15d | ||
|
|
dc7f76dac1 | ||
|
|
57b7ef4c50 | ||
|
|
2e340e2bab | ||
|
|
62270ca528 | ||
|
|
14054201f6 | ||
|
|
ffff39e47c | ||
|
|
05f9d899b3 | ||
|
|
63b6394a0e | ||
|
|
6b957deed9 | ||
|
|
c6e058d77d |
6
.github/CONTRIBUTING.md
vendored
6
.github/CONTRIBUTING.md
vendored
@ -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/emulatorjs:latest .
|
-t linuxserver/emulatorjs: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`.
|
||||||
|
|||||||
2
.github/ISSUE_TEMPLATE/config.yml
vendored
2
.github/ISSUE_TEMPLATE/config.yml
vendored
@ -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
|
||||||
|
|||||||
79
.github/ISSUE_TEMPLATE/issue.bug.yml
vendored
79
.github/ISSUE_TEMPLATE/issue.bug.yml
vendored
@ -4,74 +4,15 @@ description: Create a report to help us improve
|
|||||||
title: "[BUG] <title>"
|
title: "[BUG] <title>"
|
||||||
labels: [Bug]
|
labels: [Bug]
|
||||||
body:
|
body:
|
||||||
- type: checkboxes
|
- type: markdown
|
||||||
attributes:
|
attributes:
|
||||||
label: Is there an existing issue for this?
|
|
||||||
description: Please search to see if an issue already exists for the bug you encountered.
|
|
||||||
options:
|
|
||||||
- label: I have searched the existing issues
|
|
||||||
required: true
|
|
||||||
- type: textarea
|
|
||||||
attributes:
|
|
||||||
label: Current Behavior
|
|
||||||
description: Tell us what happens instead of the expected behavior.
|
|
||||||
validations:
|
|
||||||
required: true
|
|
||||||
- type: textarea
|
|
||||||
attributes:
|
|
||||||
label: Expected Behavior
|
|
||||||
description: Tell us what should happen.
|
|
||||||
validations:
|
|
||||||
required: false
|
|
||||||
- type: textarea
|
|
||||||
attributes:
|
|
||||||
label: Steps To Reproduce
|
|
||||||
description: Steps to reproduce the behavior.
|
|
||||||
placeholder: |
|
|
||||||
1. In this environment...
|
|
||||||
2. With this config...
|
|
||||||
3. Run '...'
|
|
||||||
4. See error...
|
|
||||||
validations:
|
|
||||||
required: true
|
|
||||||
- type: textarea
|
|
||||||
attributes:
|
|
||||||
label: Environment
|
|
||||||
description: |
|
|
||||||
examples:
|
|
||||||
- **OS**: Ubuntu 20.04
|
|
||||||
- **How docker service was installed**: distro's packagemanager
|
|
||||||
value: |
|
value: |
|
||||||
- OS:
|
# DEPRECATION NOTICE
|
||||||
- How docker service was installed:
|
This image is deprecated. We will not offer support for this image and it will not be updated.
|
||||||
render: markdown
|
|
||||||
validations:
|
|
||||||
required: false
|
Please consider these alternatives:
|
||||||
- type: dropdown
|
https://github.com/gaseous-project/gaseous-server
|
||||||
attributes:
|
https://github.com/rommapp/romm/
|
||||||
label: CPU architecture
|
https://github.com/webrcade/webrcade
|
||||||
options:
|
|
||||||
- x86-64
|
|
||||||
- arm64
|
|
||||||
- armhf
|
|
||||||
validations:
|
|
||||||
required: true
|
|
||||||
- type: textarea
|
|
||||||
attributes:
|
|
||||||
label: Docker creation
|
|
||||||
description: |
|
|
||||||
Command used to create docker container
|
|
||||||
Provide your docker create/run command or compose yaml snippet, or a screenshot of settings if using a gui to create the container
|
|
||||||
render: bash
|
|
||||||
validations:
|
|
||||||
required: true
|
|
||||||
- type: textarea
|
|
||||||
attributes:
|
|
||||||
description: |
|
|
||||||
Provide a full docker log, output of "docker logs linuxserver.io"
|
|
||||||
label: Container logs
|
|
||||||
placeholder: |
|
|
||||||
Output of `docker logs linuxserver.io`
|
|
||||||
render: bash
|
|
||||||
validations:
|
|
||||||
required: true
|
|
||||||
|
|||||||
35
.github/ISSUE_TEMPLATE/issue.feature.yml
vendored
35
.github/ISSUE_TEMPLATE/issue.feature.yml
vendored
@ -4,28 +4,15 @@ description: Suggest an idea for this project
|
|||||||
title: "[FEAT] <title>"
|
title: "[FEAT] <title>"
|
||||||
labels: [enhancement]
|
labels: [enhancement]
|
||||||
body:
|
body:
|
||||||
- type: checkboxes
|
- type: markdown
|
||||||
attributes:
|
attributes:
|
||||||
label: Is this a new feature request?
|
value: |
|
||||||
description: Please search to see if a feature request already exists.
|
# DEPRECATION NOTICE
|
||||||
options:
|
This image is deprecated. We will not offer support for this image and it will not be updated.
|
||||||
- label: I have searched the existing issues
|
|
||||||
required: true
|
|
||||||
- type: textarea
|
Please consider these alternatives:
|
||||||
attributes:
|
https://github.com/gaseous-project/gaseous-server
|
||||||
label: Wanted change
|
https://github.com/rommapp/romm/
|
||||||
description: Tell us what you want to happen.
|
https://github.com/webrcade/webrcade
|
||||||
validations:
|
|
||||||
required: true
|
|
||||||
- type: textarea
|
|
||||||
attributes:
|
|
||||||
label: Reason for change
|
|
||||||
description: Justify your request, why do you want it, what is the benefit.
|
|
||||||
validations:
|
|
||||||
required: true
|
|
||||||
- type: textarea
|
|
||||||
attributes:
|
|
||||||
label: Proposed code change
|
|
||||||
description: Do you have a potential code change in mind?
|
|
||||||
validations:
|
|
||||||
required: false
|
|
||||||
|
|||||||
9
.github/PULL_REQUEST_TEMPLATE.md
vendored
9
.github/PULL_REQUEST_TEMPLATE.md
vendored
@ -1,3 +1,12 @@
|
|||||||
|
# DEPRECATION NOTICE
|
||||||
|
This image is deprecated. We will not offer support for this image and it will not be updated.
|
||||||
|
|
||||||
|
|
||||||
|
Please consider these alternatives:
|
||||||
|
https://github.com/gaseous-project/gaseous-server
|
||||||
|
https://github.com/rommapp/romm/
|
||||||
|
https://github.com/webrcade/webrcade
|
||||||
|
|
||||||
<!--- Provide a general summary of your changes in the Title above -->
|
<!--- Provide a general summary of your changes in the Title above -->
|
||||||
|
|
||||||
[linuxserverurl]: https://linuxserver.io
|
[linuxserverurl]: https://linuxserver.io
|
||||||
|
|||||||
14
.github/workflows/call_issue_pr_tracker.yml
vendored
14
.github/workflows/call_issue_pr_tracker.yml
vendored
@ -1,14 +0,0 @@
|
|||||||
name: Issue & PR Tracker
|
|
||||||
|
|
||||||
on:
|
|
||||||
issues:
|
|
||||||
types: [opened,reopened,labeled,unlabeled]
|
|
||||||
pull_request_target:
|
|
||||||
types: [opened,reopened,review_requested,review_request_removed,labeled,unlabeled]
|
|
||||||
|
|
||||||
jobs:
|
|
||||||
manage-project:
|
|
||||||
permissions:
|
|
||||||
issues: write
|
|
||||||
uses: linuxserver/github-workflows/.github/workflows/issue-pr-tracker.yml@v1
|
|
||||||
secrets: inherit
|
|
||||||
13
.github/workflows/call_issues_cron.yml
vendored
13
.github/workflows/call_issues_cron.yml
vendored
@ -1,13 +0,0 @@
|
|||||||
name: Mark stale issues and pull requests
|
|
||||||
on:
|
|
||||||
schedule:
|
|
||||||
- cron: '56 4 * * *'
|
|
||||||
workflow_dispatch:
|
|
||||||
|
|
||||||
jobs:
|
|
||||||
stale:
|
|
||||||
permissions:
|
|
||||||
issues: write
|
|
||||||
pull-requests: write
|
|
||||||
uses: linuxserver/github-workflows/.github/workflows/issues-cron.yml@v1
|
|
||||||
secrets: inherit
|
|
||||||
96
.github/workflows/external_trigger.yml
vendored
96
.github/workflows/external_trigger.yml
vendored
@ -1,96 +0,0 @@
|
|||||||
name: External Trigger Main
|
|
||||||
|
|
||||||
on:
|
|
||||||
workflow_dispatch:
|
|
||||||
|
|
||||||
jobs:
|
|
||||||
external-trigger-master:
|
|
||||||
runs-on: ubuntu-latest
|
|
||||||
steps:
|
|
||||||
- uses: actions/checkout@v3.1.0
|
|
||||||
|
|
||||||
- name: External Trigger
|
|
||||||
if: github.ref == 'refs/heads/master'
|
|
||||||
run: |
|
|
||||||
if [ -n "${{ secrets.PAUSE_EXTERNAL_TRIGGER_EMULATORJS_MASTER }}" ]; then
|
|
||||||
echo "**** Github secret PAUSE_EXTERNAL_TRIGGER_EMULATORJS_MASTER is set; skipping trigger. ****"
|
|
||||||
exit 0
|
|
||||||
fi
|
|
||||||
echo "**** External trigger running off of master branch. To disable this trigger, set a Github secret named \"PAUSE_EXTERNAL_TRIGGER_EMULATORJS_MASTER\". ****"
|
|
||||||
echo "**** Retrieving external version ****"
|
|
||||||
EXT_RELEASE=$(curl -u "${{ secrets.CR_USER }}:${{ secrets.CR_PAT }}" -sX GET "https://api.github.com/repos/linuxserver/emulatorjs/releases/latest" | jq -r '. | .tag_name')
|
|
||||||
if [ -z "${EXT_RELEASE}" ] || [ "${EXT_RELEASE}" == "null" ]; then
|
|
||||||
echo "**** Can't retrieve external version, exiting ****"
|
|
||||||
FAILURE_REASON="Can't retrieve external version for emulatorjs branch master"
|
|
||||||
GHA_TRIGGER_URL="https://github.com/linuxserver/docker-emulatorjs/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,
|
|
||||||
"description": "**Trigger Failed** \n**Reason:** '"${FAILURE_REASON}"' \n**Trigger URL:** '"${GHA_TRIGGER_URL}"' \n"}],
|
|
||||||
"username": "Github Actions"}' ${{ secrets.DISCORD_WEBHOOK }}
|
|
||||||
exit 1
|
|
||||||
fi
|
|
||||||
EXT_RELEASE=$(echo ${EXT_RELEASE} | sed 's/[~,%@+;:/]//g')
|
|
||||||
echo "**** External version: ${EXT_RELEASE} ****"
|
|
||||||
echo "**** Retrieving last pushed version ****"
|
|
||||||
image="linuxserver/emulatorjs"
|
|
||||||
tag="latest"
|
|
||||||
token=$(curl -sX GET \
|
|
||||||
"https://ghcr.io/token?scope=repository%3Alinuxserver%2Femulatorjs%3Apull" \
|
|
||||||
| jq -r '.token')
|
|
||||||
multidigest=$(curl -s \
|
|
||||||
--header "Accept: application/vnd.docker.distribution.manifest.v2+json" \
|
|
||||||
--header "Authorization: Bearer ${token}" \
|
|
||||||
"https://ghcr.io/v2/${image}/manifests/${tag}" \
|
|
||||||
| jq -r 'first(.manifests[].digest)')
|
|
||||||
digest=$(curl -s \
|
|
||||||
--header "Accept: application/vnd.docker.distribution.manifest.v2+json" \
|
|
||||||
--header "Authorization: Bearer ${token}" \
|
|
||||||
"https://ghcr.io/v2/${image}/manifests/${multidigest}" \
|
|
||||||
| jq -r '.config.digest')
|
|
||||||
image_info=$(curl -sL \
|
|
||||||
--header "Authorization: Bearer ${token}" \
|
|
||||||
"https://ghcr.io/v2/${image}/blobs/${digest}")
|
|
||||||
if [[ $(echo $image_info | jq -r '.container_config') == "null" ]]; then
|
|
||||||
image_info=$(echo $image_info | jq -r '.config')
|
|
||||||
else
|
|
||||||
image_info=$(echo $image_info | jq -r '.container_config')
|
|
||||||
fi
|
|
||||||
IMAGE_RELEASE=$(echo ${image_info} | jq -r '.Labels.build_version' | awk '{print $3}')
|
|
||||||
IMAGE_VERSION=$(echo ${IMAGE_RELEASE} | awk -F'-ls' '{print $1}')
|
|
||||||
if [ -z "${IMAGE_VERSION}" ]; then
|
|
||||||
echo "**** Can't retrieve last pushed version, exiting ****"
|
|
||||||
FAILURE_REASON="Can't retrieve last pushed version for emulatorjs tag latest"
|
|
||||||
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"}],
|
|
||||||
"username": "Github Actions"}' ${{ secrets.DISCORD_WEBHOOK }}
|
|
||||||
exit 1
|
|
||||||
fi
|
|
||||||
echo "**** Last pushed version: ${IMAGE_VERSION} ****"
|
|
||||||
if [ "${EXT_RELEASE}" == "${IMAGE_VERSION}" ]; then
|
|
||||||
echo "**** Version ${EXT_RELEASE} already pushed, exiting ****"
|
|
||||||
exit 0
|
|
||||||
elif [ $(curl -s https://ci.linuxserver.io/job/Docker-Pipeline-Builders/job/docker-emulatorjs/job/master/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 ****"
|
|
||||||
exit 0
|
|
||||||
else
|
|
||||||
echo "**** New version ${EXT_RELEASE} found; old version was ${IMAGE_VERSION}. Triggering new build ****"
|
|
||||||
response=$(curl -iX POST \
|
|
||||||
https://ci.linuxserver.io/job/Docker-Pipeline-Builders/job/docker-emulatorjs/job/master/buildWithParameters?PACKAGE_CHECK=false \
|
|
||||||
--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 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 emulatorjs tag latest. Old version:${IMAGE_VERSION} New version:${EXT_RELEASE}"
|
|
||||||
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
|
|
||||||
43
.github/workflows/external_trigger_scheduler.yml
vendored
43
.github/workflows/external_trigger_scheduler.yml
vendored
@ -1,43 +0,0 @@
|
|||||||
name: External Trigger Scheduler
|
|
||||||
|
|
||||||
on:
|
|
||||||
schedule:
|
|
||||||
- cron: '11 * * * *'
|
|
||||||
workflow_dispatch:
|
|
||||||
|
|
||||||
jobs:
|
|
||||||
external-trigger-scheduler:
|
|
||||||
runs-on: ubuntu-latest
|
|
||||||
steps:
|
|
||||||
- uses: actions/checkout@v3.1.0
|
|
||||||
with:
|
|
||||||
fetch-depth: '0'
|
|
||||||
|
|
||||||
- name: External Trigger Scheduler
|
|
||||||
run: |
|
|
||||||
echo "**** Branches found: ****"
|
|
||||||
git for-each-ref --format='%(refname:short)' refs/remotes
|
|
||||||
echo "**** Pulling the yq docker image ****"
|
|
||||||
docker pull ghcr.io/linuxserver/yq
|
|
||||||
for br in $(git for-each-ref --format='%(refname:short)' refs/remotes)
|
|
||||||
do
|
|
||||||
br=$(echo "$br" | sed 's|origin/||g')
|
|
||||||
echo "**** Evaluating branch ${br} ****"
|
|
||||||
ls_branch=$(curl -sX GET https://raw.githubusercontent.com/linuxserver/docker-emulatorjs/${br}/jenkins-vars.yml \
|
|
||||||
| docker run --rm -i --entrypoint yq ghcr.io/linuxserver/yq -r .ls_branch)
|
|
||||||
if [ "$br" == "$ls_branch" ]; then
|
|
||||||
echo "**** Branch ${br} appears to be live; checking workflow. ****"
|
|
||||||
if curl -sfX GET https://raw.githubusercontent.com/linuxserver/docker-emulatorjs/${br}/.github/workflows/external_trigger.yml > /dev/null 2>&1; then
|
|
||||||
echo "**** Workflow exists. Triggering external trigger workflow for branch ${br} ****."
|
|
||||||
curl -iX POST \
|
|
||||||
-H "Authorization: token ${{ secrets.CR_PAT }}" \
|
|
||||||
-H "Accept: application/vnd.github.v3+json" \
|
|
||||||
-d "{\"ref\":\"refs/heads/${br}\"}" \
|
|
||||||
https://api.github.com/repos/linuxserver/docker-emulatorjs/actions/workflows/external_trigger.yml/dispatches
|
|
||||||
else
|
|
||||||
echo "**** Workflow doesn't exist; skipping trigger. ****"
|
|
||||||
fi
|
|
||||||
else
|
|
||||||
echo "**** ${br} appears to be a dev branch; skipping trigger. ****"
|
|
||||||
fi
|
|
||||||
done
|
|
||||||
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-master:
|
|
||||||
runs-on: ubuntu-latest
|
|
||||||
steps:
|
|
||||||
- uses: actions/checkout@v3.1.0
|
|
||||||
|
|
||||||
- name: Package Trigger
|
|
||||||
if: github.ref == 'refs/heads/master'
|
|
||||||
run: |
|
|
||||||
if [ -n "${{ secrets.PAUSE_PACKAGE_TRIGGER_EMULATORJS_MASTER }}" ]; then
|
|
||||||
echo "**** Github secret PAUSE_PACKAGE_TRIGGER_EMULATORJS_MASTER is set; skipping trigger. ****"
|
|
||||||
exit 0
|
|
||||||
fi
|
|
||||||
if [ $(curl -s https://ci.linuxserver.io/job/Docker-Pipeline-Builders/job/docker-emulatorjs/job/master/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 master branch. To disable, set a Github secret named \"PAUSE_PACKAGE_TRIGGER_EMULATORJS_MASTER\". ****"
|
|
||||||
response=$(curl -iX POST \
|
|
||||||
https://ci.linuxserver.io/job/Docker-Pipeline-Builders/job/docker-emulatorjs/job/master/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"
|
|
||||||
50
.github/workflows/package_trigger_scheduler.yml
vendored
50
.github/workflows/package_trigger_scheduler.yml
vendored
@ -1,50 +0,0 @@
|
|||||||
name: Package Trigger Scheduler
|
|
||||||
|
|
||||||
on:
|
|
||||||
schedule:
|
|
||||||
- cron: '3 8 * * 4'
|
|
||||||
workflow_dispatch:
|
|
||||||
|
|
||||||
jobs:
|
|
||||||
package-trigger-scheduler:
|
|
||||||
runs-on: ubuntu-latest
|
|
||||||
steps:
|
|
||||||
- uses: actions/checkout@v3.1.0
|
|
||||||
with:
|
|
||||||
fetch-depth: '0'
|
|
||||||
|
|
||||||
- name: Package Trigger Scheduler
|
|
||||||
run: |
|
|
||||||
echo "**** Branches found: ****"
|
|
||||||
git for-each-ref --format='%(refname:short)' refs/remotes
|
|
||||||
echo "**** Pulling the yq docker image ****"
|
|
||||||
docker pull ghcr.io/linuxserver/yq
|
|
||||||
for br in $(git for-each-ref --format='%(refname:short)' refs/remotes)
|
|
||||||
do
|
|
||||||
br=$(echo "$br" | sed 's|origin/||g')
|
|
||||||
echo "**** Evaluating branch ${br} ****"
|
|
||||||
ls_branch=$(curl -sX GET https://raw.githubusercontent.com/linuxserver/docker-emulatorjs/${br}/jenkins-vars.yml \
|
|
||||||
| docker run --rm -i --entrypoint yq ghcr.io/linuxserver/yq -r .ls_branch)
|
|
||||||
if [ "${br}" == "${ls_branch}" ]; then
|
|
||||||
echo "**** Branch ${br} appears to be live; checking workflow. ****"
|
|
||||||
if curl -sfX GET https://raw.githubusercontent.com/linuxserver/docker-emulatorjs/${br}/.github/workflows/package_trigger.yml > /dev/null 2>&1; then
|
|
||||||
echo "**** Workflow exists. Triggering package trigger workflow for branch ${br}. ****"
|
|
||||||
triggered_branches="${triggered_branches}${br} "
|
|
||||||
curl -iX POST \
|
|
||||||
-H "Authorization: token ${{ secrets.CR_PAT }}" \
|
|
||||||
-H "Accept: application/vnd.github.v3+json" \
|
|
||||||
-d "{\"ref\":\"refs/heads/${br}\"}" \
|
|
||||||
https://api.github.com/repos/linuxserver/docker-emulatorjs/actions/workflows/package_trigger.yml/dispatches
|
|
||||||
sleep 30
|
|
||||||
else
|
|
||||||
echo "**** Workflow doesn't exist; skipping trigger. ****"
|
|
||||||
fi
|
|
||||||
else
|
|
||||||
echo "**** ${br} appears to be a dev branch; skipping trigger. ****"
|
|
||||||
fi
|
|
||||||
done
|
|
||||||
echo "**** Package check build(s) triggered for branch(es): ${triggered_branches} ****"
|
|
||||||
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) Triggered for emulatorjs** \n**Branch(es):** '"${triggered_branches}"' \n**Build URL:** '"https://ci.linuxserver.io/blue/organizations/jenkins/Docker-Pipeline-Builders%2Fdocker-emulatorjs/activity/"' \n"}],
|
|
||||||
"username": "Github Actions"}' ${{ secrets.DISCORD_WEBHOOK }}
|
|
||||||
2
.github/workflows/permissions.yml
vendored
2
.github/workflows/permissions.yml
vendored
@ -5,6 +5,8 @@ on:
|
|||||||
- '**/run'
|
- '**/run'
|
||||||
- '**/finish'
|
- '**/finish'
|
||||||
- '**/check'
|
- '**/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
|
||||||
|
|||||||
58
Dockerfile
58
Dockerfile
@ -1,9 +1,30 @@
|
|||||||
FROM ghcr.io/linuxserver/baseimage-alpine:3.15 as binbuilder
|
# syntax=docker/dockerfile:1
|
||||||
|
|
||||||
|
FROM ghcr.io/linuxserver/baseimage-alpine:3.14 as migrationbuilder
|
||||||
|
|
||||||
|
RUN \
|
||||||
|
echo "**** install build packages ****" && \
|
||||||
|
apk add \
|
||||||
|
git \
|
||||||
|
go
|
||||||
|
|
||||||
|
RUN \
|
||||||
|
echo "**** build fs-repo-migrations ****" && \
|
||||||
|
mkdir -p /build-out/usr/bin && \
|
||||||
|
git clone https://github.com/ipfs/fs-repo-migrations.git && \
|
||||||
|
cd fs-repo-migrations && \
|
||||||
|
for BUILD in fs-repo-migrations fs-repo-9-to-10 fs-repo-10-to-11 fs-repo-11-to-12; do \
|
||||||
|
cd ${BUILD} && \
|
||||||
|
go build && \
|
||||||
|
mv fs-repo-* /build-out/usr/bin/ && \
|
||||||
|
cd .. ; \
|
||||||
|
done
|
||||||
|
|
||||||
|
FROM ghcr.io/linuxserver/baseimage-alpine:3.19 as binbuilder
|
||||||
|
|
||||||
RUN \
|
RUN \
|
||||||
echo "**** install build packages ****" && \
|
echo "**** install build packages ****" && \
|
||||||
apk add \
|
apk add \
|
||||||
curl \
|
|
||||||
git \
|
git \
|
||||||
go
|
go
|
||||||
|
|
||||||
@ -28,15 +49,25 @@ RUN \
|
|||||||
chmod +x /tmp/binmerge && \
|
chmod +x /tmp/binmerge && \
|
||||||
mv /tmp/binmerge /build-out/usr/local/bin
|
mv /tmp/binmerge /build-out/usr/local/bin
|
||||||
|
|
||||||
FROM ghcr.io/linuxserver/baseimage-alpine:3.15 as nodebuilder
|
RUN \
|
||||||
|
echo "**** build fs-repo-migrations ****" && \
|
||||||
|
mkdir /build-out/usr/bin && \
|
||||||
|
git clone https://github.com/ipfs/fs-repo-migrations.git && \
|
||||||
|
cd fs-repo-migrations && \
|
||||||
|
for BUILD in fs-repo-migrations fs-repo-12-to-13 fs-repo-13-to-14 fs-repo-14-to-15; do \
|
||||||
|
cd ${BUILD} && \
|
||||||
|
go build && \
|
||||||
|
mv fs-repo-* /build-out/usr/bin/ && \
|
||||||
|
cd .. ; \
|
||||||
|
done
|
||||||
|
|
||||||
|
FROM ghcr.io/linuxserver/baseimage-alpine:3.19 as nodebuilder
|
||||||
|
|
||||||
ARG EMULATORJS_RELEASE
|
ARG EMULATORJS_RELEASE
|
||||||
ARG RETRO_VERSION=1.9.10
|
|
||||||
|
|
||||||
RUN \
|
RUN \
|
||||||
echo "**** install build packages ****" && \
|
echo "**** install build packages ****" && \
|
||||||
apk add \
|
apk add \
|
||||||
curl \
|
|
||||||
nodejs \
|
nodejs \
|
||||||
npm \
|
npm \
|
||||||
p7zip \
|
p7zip \
|
||||||
@ -81,7 +112,7 @@ RUN \
|
|||||||
npm install
|
npm install
|
||||||
|
|
||||||
# runtime stage
|
# runtime stage
|
||||||
FROM ghcr.io/linuxserver/baseimage-alpine:3.15
|
FROM ghcr.io/linuxserver/baseimage-alpine:3.19
|
||||||
|
|
||||||
# set version label
|
# set version label
|
||||||
ARG BUILD_DATE
|
ARG BUILD_DATE
|
||||||
@ -92,27 +123,28 @@ LABEL maintainer="thelamer"
|
|||||||
RUN \
|
RUN \
|
||||||
echo "**** install runtime packages ****" && \
|
echo "**** install runtime packages ****" && \
|
||||||
apk add --no-cache \
|
apk add --no-cache \
|
||||||
curl \
|
|
||||||
file \
|
file \
|
||||||
flac \
|
flac \
|
||||||
go-ipfs \
|
kubo \
|
||||||
nginx \
|
nginx \
|
||||||
nodejs \
|
|
||||||
p7zip \
|
p7zip \
|
||||||
python3 \
|
python3 \
|
||||||
sdl2 && \
|
sdl2 && \
|
||||||
|
apk add --no-cache --repository=http://dl-cdn.alpinelinux.org/alpine/edge/testing \
|
||||||
|
mame-tools && \
|
||||||
mkdir /data && \
|
mkdir /data && \
|
||||||
echo "**** grab pre-built chdman ****" && \
|
echo "**** use pinned node ****" && \
|
||||||
curl -L \
|
curl -L \
|
||||||
"https://infura-ipfs.io/ipfs/QmUfYfuoxPgDRc9Mniv1TBXv6LXPRNArAabZo5VnzfZNtP" \
|
https://github.com/thelamer/node-stash/raw/master/v16.20.2/x86_64/node -o \
|
||||||
-o /usr/local/bin/chdman && \
|
/bin/node && \
|
||||||
chmod +x /usr/local/bin/chdman && \
|
chmod +x /bin/node && \
|
||||||
echo "**** cleanup ****" && \
|
echo "**** cleanup ****" && \
|
||||||
rm -rf \
|
rm -rf \
|
||||||
/tmp/*
|
/tmp/*
|
||||||
|
|
||||||
# add local files and files from buildstage
|
# add local files and files from buildstage
|
||||||
COPY --from=binbuilder /build-out/ /
|
COPY --from=binbuilder /build-out/ /
|
||||||
|
COPY --from=migrationbuilder /build-out/ /
|
||||||
COPY --from=nodebuilder /emulatorjs/ /emulatorjs/
|
COPY --from=nodebuilder /emulatorjs/ /emulatorjs/
|
||||||
COPY root/ /
|
COPY root/ /
|
||||||
|
|
||||||
|
|||||||
@ -1,11 +1,36 @@
|
|||||||
FROM ghcr.io/linuxserver/baseimage-alpine:arm64v8-3.15 as binbuilder
|
# syntax=docker/dockerfile:1
|
||||||
|
|
||||||
|
FROM ghcr.io/linuxserver/baseimage-alpine:arm64v8-3.14 as migrationbuilder
|
||||||
|
|
||||||
RUN \
|
RUN \
|
||||||
echo "**** install build packages ****" && \
|
echo "**** install build packages ****" && \
|
||||||
apk add \
|
apk add \
|
||||||
curl \
|
|
||||||
git \
|
git \
|
||||||
go
|
gcc \
|
||||||
|
go \
|
||||||
|
musl-dev
|
||||||
|
|
||||||
|
RUN \
|
||||||
|
echo "**** build fs-repo-migrations ****" && \
|
||||||
|
mkdir -p /build-out/usr/bin && \
|
||||||
|
git clone https://github.com/ipfs/fs-repo-migrations.git && \
|
||||||
|
cd fs-repo-migrations && \
|
||||||
|
for BUILD in fs-repo-migrations fs-repo-9-to-10 fs-repo-10-to-11 fs-repo-11-to-12; do \
|
||||||
|
cd ${BUILD} && \
|
||||||
|
go build && \
|
||||||
|
mv fs-repo-* /build-out/usr/bin/ && \
|
||||||
|
cd .. ; \
|
||||||
|
done
|
||||||
|
|
||||||
|
FROM ghcr.io/linuxserver/baseimage-alpine:arm64v8-3.19 as binbuilder
|
||||||
|
|
||||||
|
RUN \
|
||||||
|
echo "**** install build packages ****" && \
|
||||||
|
apk add \
|
||||||
|
git \
|
||||||
|
gcc \
|
||||||
|
go \
|
||||||
|
musl-dev
|
||||||
|
|
||||||
RUN \
|
RUN \
|
||||||
echo "**** build nestool ****" && \
|
echo "**** build nestool ****" && \
|
||||||
@ -28,14 +53,25 @@ RUN \
|
|||||||
chmod +x /tmp/binmerge && \
|
chmod +x /tmp/binmerge && \
|
||||||
mv /tmp/binmerge /build-out/usr/local/bin
|
mv /tmp/binmerge /build-out/usr/local/bin
|
||||||
|
|
||||||
FROM ghcr.io/linuxserver/baseimage-alpine:arm64v8-3.15 as nodebuilder
|
RUN \
|
||||||
|
echo "**** build fs-repo-migrations ****" && \
|
||||||
|
mkdir /build-out/usr/bin && \
|
||||||
|
git clone https://github.com/ipfs/fs-repo-migrations.git && \
|
||||||
|
cd fs-repo-migrations && \
|
||||||
|
for BUILD in fs-repo-migrations fs-repo-12-to-13 fs-repo-13-to-14 fs-repo-14-to-15; do \
|
||||||
|
cd ${BUILD} && \
|
||||||
|
go build && \
|
||||||
|
mv fs-repo-* /build-out/usr/bin/ && \
|
||||||
|
cd .. ; \
|
||||||
|
done
|
||||||
|
|
||||||
|
FROM ghcr.io/linuxserver/baseimage-alpine:arm64v8-3.19 as nodebuilder
|
||||||
|
|
||||||
ARG EMULATORJS_RELEASE
|
ARG EMULATORJS_RELEASE
|
||||||
|
|
||||||
RUN \
|
RUN \
|
||||||
echo "**** install build packages ****" && \
|
echo "**** install build packages ****" && \
|
||||||
apk add \
|
apk add \
|
||||||
curl \
|
|
||||||
nodejs \
|
nodejs \
|
||||||
npm \
|
npm \
|
||||||
p7zip \
|
p7zip \
|
||||||
@ -80,7 +116,7 @@ RUN \
|
|||||||
npm install
|
npm install
|
||||||
|
|
||||||
# runtime stage
|
# runtime stage
|
||||||
FROM ghcr.io/linuxserver/baseimage-alpine:arm64v8-3.15
|
FROM ghcr.io/linuxserver/baseimage-alpine:arm64v8-3.19
|
||||||
|
|
||||||
# set version label
|
# set version label
|
||||||
ARG BUILD_DATE
|
ARG BUILD_DATE
|
||||||
@ -91,28 +127,28 @@ LABEL maintainer="thelamer"
|
|||||||
RUN \
|
RUN \
|
||||||
echo "**** install runtime packages ****" && \
|
echo "**** install runtime packages ****" && \
|
||||||
apk add --no-cache \
|
apk add --no-cache \
|
||||||
curl \
|
|
||||||
file \
|
file \
|
||||||
flac \
|
flac \
|
||||||
|
kubo \
|
||||||
nginx \
|
nginx \
|
||||||
nodejs \
|
|
||||||
p7zip \
|
p7zip \
|
||||||
python3 \
|
python3 \
|
||||||
sdl2 && \
|
sdl2 && \
|
||||||
mkdir /data && \
|
mkdir /data && \
|
||||||
apk add --no-cache --repository=http://dl-cdn.alpinelinux.org/alpine/v3.14/community \
|
apk add --no-cache --repository=http://dl-cdn.alpinelinux.org/alpine/edge/testing \
|
||||||
go-ipfs && \
|
mame-tools && \
|
||||||
echo "**** grab pre-built chdman ****" && \
|
echo "**** use pinned node ****" && \
|
||||||
curl -L \
|
curl -L \
|
||||||
"https://infura-ipfs.io/ipfs/QmUqmGm5KUeeWSS9FG9DMuSQPpvU7RqffFR9n3rJXDQ8AQ" \
|
https://github.com/thelamer/node-stash/raw/master/v16.20.2/aarch64/node -o \
|
||||||
-o /usr/local/bin/chdman && \
|
/bin/node && \
|
||||||
chmod +x /usr/local/bin/chdman && \
|
chmod +x /bin/node && \
|
||||||
echo "**** cleanup ****" && \
|
echo "**** cleanup ****" && \
|
||||||
rm -rf \
|
rm -rf \
|
||||||
/tmp/*
|
/tmp/*
|
||||||
|
|
||||||
# add local files and files from buildstage
|
# add local files and files from buildstage
|
||||||
COPY --from=binbuilder /build-out/ /
|
COPY --from=binbuilder /build-out/ /
|
||||||
|
COPY --from=migrationbuilder /build-out/ /
|
||||||
COPY --from=nodebuilder /emulatorjs/ /emulatorjs/
|
COPY --from=nodebuilder /emulatorjs/ /emulatorjs/
|
||||||
COPY root/ /
|
COPY root/ /
|
||||||
|
|
||||||
|
|||||||
120
Dockerfile.armhf
120
Dockerfile.armhf
@ -1,120 +0,0 @@
|
|||||||
FROM ghcr.io/linuxserver/baseimage-alpine:arm32v7-3.15 as binbuilder
|
|
||||||
|
|
||||||
RUN \
|
|
||||||
echo "**** install build packages ****" && \
|
|
||||||
apk add \
|
|
||||||
curl \
|
|
||||||
git \
|
|
||||||
go
|
|
||||||
|
|
||||||
RUN \
|
|
||||||
echo "**** build nestool ****" && \
|
|
||||||
mkdir -p /build-out/usr/local/bin && \
|
|
||||||
git clone https://github.com/Kreeblah/NES20Tool.git && \
|
|
||||||
cd NES20Tool && \
|
|
||||||
go build && \
|
|
||||||
mv NES20Tool /build-out/usr/local/bin
|
|
||||||
|
|
||||||
RUN \
|
|
||||||
echo "**** grab binmerge ****" && \
|
|
||||||
BINMERGE_RELEASE=$(curl -sX GET "https://api.github.com/repos/putnam/binmerge/releases/latest" \
|
|
||||||
| awk '/tag_name/{print $4;exit}' FS='[""]') && \
|
|
||||||
curl -o \
|
|
||||||
/tmp/binmerge.tar.gz -L \
|
|
||||||
"https://github.com/putnam/binmerge/archive/${BINMERGE_RELEASE}.tar.gz" && \
|
|
||||||
tar xf \
|
|
||||||
/tmp/binmerge.tar.gz -C \
|
|
||||||
/tmp/ --strip-components=1 && \
|
|
||||||
chmod +x /tmp/binmerge && \
|
|
||||||
mv /tmp/binmerge /build-out/usr/local/bin
|
|
||||||
|
|
||||||
FROM ghcr.io/linuxserver/baseimage-alpine:arm32v7-3.15 as nodebuilder
|
|
||||||
|
|
||||||
ARG EMULATORJS_RELEASE
|
|
||||||
ARG RETRO_VERSION=1.9.10
|
|
||||||
|
|
||||||
RUN \
|
|
||||||
echo "**** install build packages ****" && \
|
|
||||||
apk add \
|
|
||||||
curl \
|
|
||||||
nodejs \
|
|
||||||
npm \
|
|
||||||
p7zip \
|
|
||||||
zip
|
|
||||||
|
|
||||||
RUN \
|
|
||||||
echo "**** grab emulatorjs ****" && \
|
|
||||||
mkdir /emulatorjs && \
|
|
||||||
if [ -z ${EMULATORJS_RELEASE+x} ]; then \
|
|
||||||
EMULATORJS_RELEASE=$(curl -sX GET "https://api.github.com/repos/linuxserver/emulatorjs/releases/latest" \
|
|
||||||
| awk '/tag_name/{print $4;exit}' FS='[""]'); \
|
|
||||||
fi && \
|
|
||||||
curl -o \
|
|
||||||
/tmp/emulatorjs.tar.gz -L \
|
|
||||||
"https://github.com/linuxserver/emulatorjs/archive/${EMULATORJS_RELEASE}.tar.gz" && \
|
|
||||||
tar xf \
|
|
||||||
/tmp/emulatorjs.tar.gz -C \
|
|
||||||
/emulatorjs/ --strip-components=1
|
|
||||||
|
|
||||||
RUN \
|
|
||||||
echo "**** grab emulatorjs blobs ****" && \
|
|
||||||
curl -o \
|
|
||||||
/tmp/emulatorjs-blob.tar.gz -L \
|
|
||||||
"https://github.com/thelamer/emulatorjs/archive/main.tar.gz" && \
|
|
||||||
tar xf \
|
|
||||||
/tmp/emulatorjs-blob.tar.gz -C \
|
|
||||||
/emulatorjs/frontend/ --strip-components=1
|
|
||||||
|
|
||||||
RUN \
|
|
||||||
echo "**** grab libretro blobs ****" && \
|
|
||||||
curl -o \
|
|
||||||
/tmp/custom-cores.tar.gz -L \
|
|
||||||
"https://github.com/linuxserver/libretro-cores/archive/master.tar.gz" && \
|
|
||||||
tar xf \
|
|
||||||
/tmp/custom-cores.tar.gz -C \
|
|
||||||
/emulatorjs/frontend/ --strip-components=1 && \
|
|
||||||
rm /emulatorjs/frontend/README.md
|
|
||||||
|
|
||||||
RUN \
|
|
||||||
echo "**** build emulatorjs ****" && \
|
|
||||||
cd /emulatorjs && \
|
|
||||||
npm install
|
|
||||||
|
|
||||||
# runtime stage
|
|
||||||
FROM ghcr.io/linuxserver/baseimage-alpine:arm32v7-3.15
|
|
||||||
|
|
||||||
# set version label
|
|
||||||
ARG BUILD_DATE
|
|
||||||
ARG VERSION
|
|
||||||
LABEL build_version="Linuxserver.io version:- ${VERSION} Build-date:- ${BUILD_DATE}"
|
|
||||||
LABEL maintainer="thelamer"
|
|
||||||
|
|
||||||
RUN \
|
|
||||||
echo "**** install runtime packages ****" && \
|
|
||||||
apk add --no-cache \
|
|
||||||
curl \
|
|
||||||
file \
|
|
||||||
flac \
|
|
||||||
go-ipfs \
|
|
||||||
nginx \
|
|
||||||
nodejs \
|
|
||||||
p7zip \
|
|
||||||
python3 \
|
|
||||||
sdl2 && \
|
|
||||||
mkdir /data && \
|
|
||||||
echo "**** grab pre-built chdman ****" && \
|
|
||||||
curl -L \
|
|
||||||
"https://infura-ipfs.io/ipfs/QmPYV2qJi3QrgqS9gPbX4XQ7DoNj3aZAz9sHy2Bo3Xeqbj" \
|
|
||||||
-o /usr/local/bin/chdman && \
|
|
||||||
chmod +x /usr/local/bin/chdman && \
|
|
||||||
echo "**** cleanup ****" && \
|
|
||||||
rm -rf \
|
|
||||||
/tmp/*
|
|
||||||
|
|
||||||
# add local files and files from buildstage
|
|
||||||
COPY --from=binbuilder /build-out/ /
|
|
||||||
COPY --from=nodebuilder /emulatorjs/ /emulatorjs/
|
|
||||||
COPY root/ /
|
|
||||||
|
|
||||||
# ports
|
|
||||||
EXPOSE 80 3000
|
|
||||||
992
Jenkinsfile
vendored
992
Jenkinsfile
vendored
@ -1,992 +0,0 @@
|
|||||||
pipeline {
|
|
||||||
agent {
|
|
||||||
label 'X86-64-MULTI'
|
|
||||||
}
|
|
||||||
options {
|
|
||||||
buildDiscarder(logRotator(numToKeepStr: '10', daysToKeepStr: '60'))
|
|
||||||
parallelsAlwaysFailFast()
|
|
||||||
}
|
|
||||||
// Input to determine if this is a package check
|
|
||||||
parameters {
|
|
||||||
string(defaultValue: 'false', description: 'package check run', name: 'PACKAGE_CHECK')
|
|
||||||
}
|
|
||||||
// Configuration for the variables used for this specific repo
|
|
||||||
environment {
|
|
||||||
BUILDS_DISCORD=credentials('build_webhook_url')
|
|
||||||
GITHUB_TOKEN=credentials('498b4638-2d02-4ce5-832d-8a57d01d97ab')
|
|
||||||
GITLAB_TOKEN=credentials('b6f0f1dd-6952-4cf6-95d1-9c06380283f0')
|
|
||||||
GITLAB_NAMESPACE=credentials('gitlab-namespace-id')
|
|
||||||
SCARF_TOKEN=credentials('scarf_api_key')
|
|
||||||
EXT_GIT_BRANCH = 'master'
|
|
||||||
EXT_USER = 'linuxserver'
|
|
||||||
EXT_REPO = 'emulatorjs'
|
|
||||||
BUILD_VERSION_ARG = 'EMULATORJS_RELEASE'
|
|
||||||
LS_USER = 'linuxserver'
|
|
||||||
LS_REPO = 'docker-emulatorjs'
|
|
||||||
CONTAINER_NAME = 'emulatorjs'
|
|
||||||
DOCKERHUB_IMAGE = 'linuxserver/emulatorjs'
|
|
||||||
DEV_DOCKERHUB_IMAGE = 'lsiodev/emulatorjs'
|
|
||||||
PR_DOCKERHUB_IMAGE = 'lspipepr/emulatorjs'
|
|
||||||
DIST_IMAGE = 'alpine'
|
|
||||||
MULTIARCH='true'
|
|
||||||
CI='true'
|
|
||||||
CI_WEB='true'
|
|
||||||
CI_PORT='3000'
|
|
||||||
CI_SSL='false'
|
|
||||||
CI_DELAY='120'
|
|
||||||
CI_DOCKERENV='TZ=US/Pacific'
|
|
||||||
CI_AUTH='user:password'
|
|
||||||
CI_WEBPATH=''
|
|
||||||
}
|
|
||||||
stages {
|
|
||||||
// Setup all the basic environment variables needed for the build
|
|
||||||
stage("Set ENV Variables base"){
|
|
||||||
steps{
|
|
||||||
script{
|
|
||||||
env.EXIT_STATUS = ''
|
|
||||||
env.LS_RELEASE = sh(
|
|
||||||
script: '''docker run --rm ghcr.io/linuxserver/alexeiled-skopeo sh -c 'skopeo inspect docker://docker.io/'${DOCKERHUB_IMAGE}':latest 2>/dev/null' | jq -r '.Labels.build_version' | awk '{print $3}' | grep '\\-ls' || : ''',
|
|
||||||
returnStdout: true).trim()
|
|
||||||
env.LS_RELEASE_NOTES = sh(
|
|
||||||
script: '''cat readme-vars.yml | awk -F \\" '/date: "[0-9][0-9].[0-9][0-9].[0-9][0-9]:/ {print $4;exit;}' | sed -E ':a;N;$!ba;s/\\r{0,1}\\n/\\\\n/g' ''',
|
|
||||||
returnStdout: true).trim()
|
|
||||||
env.GITHUB_DATE = sh(
|
|
||||||
script: '''date '+%Y-%m-%dT%H:%M:%S%:z' ''',
|
|
||||||
returnStdout: true).trim()
|
|
||||||
env.COMMIT_SHA = sh(
|
|
||||||
script: '''git rev-parse HEAD''',
|
|
||||||
returnStdout: true).trim()
|
|
||||||
env.CODE_URL = 'https://github.com/' + env.LS_USER + '/' + env.LS_REPO + '/commit/' + env.GIT_COMMIT
|
|
||||||
env.DOCKERHUB_LINK = 'https://hub.docker.com/r/' + env.DOCKERHUB_IMAGE + '/tags/'
|
|
||||||
env.PULL_REQUEST = env.CHANGE_ID
|
|
||||||
env.TEMPLATED_FILES = 'Jenkinsfile README.md LICENSE .editorconfig ./.github/CONTRIBUTING.md ./.github/FUNDING.yml ./.github/ISSUE_TEMPLATE/config.yml ./.github/ISSUE_TEMPLATE/issue.bug.yml ./.github/ISSUE_TEMPLATE/issue.feature.yml ./.github/PULL_REQUEST_TEMPLATE.md ./.github/workflows/external_trigger_scheduler.yml ./.github/workflows/greetings.yml ./.github/workflows/package_trigger_scheduler.yml ./.github/workflows/call_issue_pr_tracker.yml ./.github/workflows/call_issues_cron.yml ./.github/workflows/permissions.yml ./.github/workflows/external_trigger.yml ./.github/workflows/package_trigger.yml'
|
|
||||||
}
|
|
||||||
script{
|
|
||||||
env.LS_RELEASE_NUMBER = sh(
|
|
||||||
script: '''echo ${LS_RELEASE} |sed 's/^.*-ls//g' ''',
|
|
||||||
returnStdout: true).trim()
|
|
||||||
}
|
|
||||||
script{
|
|
||||||
env.LS_TAG_NUMBER = sh(
|
|
||||||
script: '''#! /bin/bash
|
|
||||||
tagsha=$(git rev-list -n 1 ${LS_RELEASE} 2>/dev/null)
|
|
||||||
if [ "${tagsha}" == "${COMMIT_SHA}" ]; then
|
|
||||||
echo ${LS_RELEASE_NUMBER}
|
|
||||||
elif [ -z "${GIT_COMMIT}" ]; then
|
|
||||||
echo ${LS_RELEASE_NUMBER}
|
|
||||||
else
|
|
||||||
echo $((${LS_RELEASE_NUMBER} + 1))
|
|
||||||
fi''',
|
|
||||||
returnStdout: true).trim()
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
|
||||||
/* #######################
|
|
||||||
Package Version Tagging
|
|
||||||
####################### */
|
|
||||||
// Grab the current package versions in Git to determine package tag
|
|
||||||
stage("Set Package tag"){
|
|
||||||
steps{
|
|
||||||
script{
|
|
||||||
env.PACKAGE_TAG = sh(
|
|
||||||
script: '''#!/bin/bash
|
|
||||||
if [ -e package_versions.txt ] ; then
|
|
||||||
cat package_versions.txt | md5sum | cut -c1-8
|
|
||||||
else
|
|
||||||
echo none
|
|
||||||
fi''',
|
|
||||||
returnStdout: true).trim()
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
|
||||||
/* ########################
|
|
||||||
External Release Tagging
|
|
||||||
######################## */
|
|
||||||
// If this is a stable github release use the latest endpoint from github to determine the ext tag
|
|
||||||
stage("Set ENV github_stable"){
|
|
||||||
steps{
|
|
||||||
script{
|
|
||||||
env.EXT_RELEASE = sh(
|
|
||||||
script: '''curl -H "Authorization: token ${GITHUB_TOKEN}" -s https://api.github.com/repos/${EXT_USER}/${EXT_REPO}/releases/latest | jq -r '. | .tag_name' ''',
|
|
||||||
returnStdout: true).trim()
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
|
||||||
// If this is a stable or devel github release generate the link for the build message
|
|
||||||
stage("Set ENV github_link"){
|
|
||||||
steps{
|
|
||||||
script{
|
|
||||||
env.RELEASE_LINK = 'https://github.com/' + env.EXT_USER + '/' + env.EXT_REPO + '/releases/tag/' + env.EXT_RELEASE
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
|
||||||
// Sanitize the release tag and strip illegal docker or github characters
|
|
||||||
stage("Sanitize tag"){
|
|
||||||
steps{
|
|
||||||
script{
|
|
||||||
env.EXT_RELEASE_CLEAN = sh(
|
|
||||||
script: '''echo ${EXT_RELEASE} | sed 's/[~,%@+;:/]//g' ''',
|
|
||||||
returnStdout: true).trim()
|
|
||||||
|
|
||||||
def semver = env.EXT_RELEASE_CLEAN =~ /(\d+)\.(\d+)\.(\d+)/
|
|
||||||
if (semver.find()) {
|
|
||||||
env.SEMVER = "${semver[0][1]}.${semver[0][2]}.${semver[0][3]}"
|
|
||||||
} else {
|
|
||||||
semver = env.EXT_RELEASE_CLEAN =~ /(\d+)\.(\d+)(?:\.(\d+))?(.*)/
|
|
||||||
if (semver.find()) {
|
|
||||||
if (semver[0][3]) {
|
|
||||||
env.SEMVER = "${semver[0][1]}.${semver[0][2]}.${semver[0][3]}"
|
|
||||||
} else if (!semver[0][3] && !semver[0][4]) {
|
|
||||||
env.SEMVER = "${semver[0][1]}.${semver[0][2]}.${(new Date()).format('YYYYMMdd')}"
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
if (env.SEMVER != null) {
|
|
||||||
if (BRANCH_NAME != "master" && BRANCH_NAME != "main") {
|
|
||||||
env.SEMVER = "${env.SEMVER}-${BRANCH_NAME}"
|
|
||||||
}
|
|
||||||
println("SEMVER: ${env.SEMVER}")
|
|
||||||
} else {
|
|
||||||
println("No SEMVER detected")
|
|
||||||
}
|
|
||||||
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
|
||||||
// If this is a master build use live docker endpoints
|
|
||||||
stage("Set ENV live build"){
|
|
||||||
when {
|
|
||||||
branch "master"
|
|
||||||
environment name: 'CHANGE_ID', value: ''
|
|
||||||
}
|
|
||||||
steps {
|
|
||||||
script{
|
|
||||||
env.IMAGE = env.DOCKERHUB_IMAGE
|
|
||||||
env.GITHUBIMAGE = 'ghcr.io/' + env.LS_USER + '/' + env.CONTAINER_NAME
|
|
||||||
env.GITLABIMAGE = 'registry.gitlab.com/linuxserver.io/' + env.LS_REPO + '/' + env.CONTAINER_NAME
|
|
||||||
env.QUAYIMAGE = 'quay.io/linuxserver.io/' + env.CONTAINER_NAME
|
|
||||||
if (env.MULTIARCH == 'true') {
|
|
||||||
env.CI_TAGS = 'amd64-' + env.EXT_RELEASE_CLEAN + '-ls' + env.LS_TAG_NUMBER + '|arm32v7-' + env.EXT_RELEASE_CLEAN + '-ls' + env.LS_TAG_NUMBER + '|arm64v8-' + env.EXT_RELEASE_CLEAN + '-ls' + env.LS_TAG_NUMBER
|
|
||||||
} else {
|
|
||||||
env.CI_TAGS = env.EXT_RELEASE_CLEAN + '-ls' + env.LS_TAG_NUMBER
|
|
||||||
}
|
|
||||||
env.VERSION_TAG = env.EXT_RELEASE_CLEAN + '-ls' + env.LS_TAG_NUMBER
|
|
||||||
env.META_TAG = env.EXT_RELEASE_CLEAN + '-ls' + env.LS_TAG_NUMBER
|
|
||||||
env.EXT_RELEASE_TAG = 'version-' + env.EXT_RELEASE_CLEAN
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
|
||||||
// If this is a dev build use dev docker endpoints
|
|
||||||
stage("Set ENV dev build"){
|
|
||||||
when {
|
|
||||||
not {branch "master"}
|
|
||||||
environment name: 'CHANGE_ID', value: ''
|
|
||||||
}
|
|
||||||
steps {
|
|
||||||
script{
|
|
||||||
env.IMAGE = env.DEV_DOCKERHUB_IMAGE
|
|
||||||
env.GITHUBIMAGE = 'ghcr.io/' + env.LS_USER + '/lsiodev-' + env.CONTAINER_NAME
|
|
||||||
env.GITLABIMAGE = 'registry.gitlab.com/linuxserver.io/' + env.LS_REPO + '/lsiodev-' + env.CONTAINER_NAME
|
|
||||||
env.QUAYIMAGE = 'quay.io/linuxserver.io/lsiodev-' + env.CONTAINER_NAME
|
|
||||||
if (env.MULTIARCH == 'true') {
|
|
||||||
env.CI_TAGS = 'amd64-' + env.EXT_RELEASE_CLEAN + '-pkg-' + env.PACKAGE_TAG + '-dev-' + env.COMMIT_SHA + '|arm32v7-' + env.EXT_RELEASE_CLEAN + '-pkg-' + env.PACKAGE_TAG + '-dev-' + env.COMMIT_SHA + '|arm64v8-' + env.EXT_RELEASE_CLEAN + '-pkg-' + env.PACKAGE_TAG + '-dev-' + env.COMMIT_SHA
|
|
||||||
} else {
|
|
||||||
env.CI_TAGS = env.EXT_RELEASE_CLEAN + '-pkg-' + env.PACKAGE_TAG + '-dev-' + env.COMMIT_SHA
|
|
||||||
}
|
|
||||||
env.VERSION_TAG = env.EXT_RELEASE_CLEAN + '-pkg-' + env.PACKAGE_TAG + '-dev-' + env.COMMIT_SHA
|
|
||||||
env.META_TAG = env.EXT_RELEASE_CLEAN + '-pkg-' + env.PACKAGE_TAG + '-dev-' + env.COMMIT_SHA
|
|
||||||
env.EXT_RELEASE_TAG = 'version-' + env.EXT_RELEASE_CLEAN
|
|
||||||
env.DOCKERHUB_LINK = 'https://hub.docker.com/r/' + env.DEV_DOCKERHUB_IMAGE + '/tags/'
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
|
||||||
// If this is a pull request build use dev docker endpoints
|
|
||||||
stage("Set ENV PR build"){
|
|
||||||
when {
|
|
||||||
not {environment name: 'CHANGE_ID', value: ''}
|
|
||||||
}
|
|
||||||
steps {
|
|
||||||
script{
|
|
||||||
env.IMAGE = env.PR_DOCKERHUB_IMAGE
|
|
||||||
env.GITHUBIMAGE = 'ghcr.io/' + env.LS_USER + '/lspipepr-' + env.CONTAINER_NAME
|
|
||||||
env.GITLABIMAGE = 'registry.gitlab.com/linuxserver.io/' + env.LS_REPO + '/lspipepr-' + env.CONTAINER_NAME
|
|
||||||
env.QUAYIMAGE = 'quay.io/linuxserver.io/lspipepr-' + env.CONTAINER_NAME
|
|
||||||
if (env.MULTIARCH == 'true') {
|
|
||||||
env.CI_TAGS = 'amd64-' + env.EXT_RELEASE_CLEAN + '-pkg-' + env.PACKAGE_TAG + '-pr-' + env.PULL_REQUEST + '|arm32v7-' + env.EXT_RELEASE_CLEAN + '-pkg-' + env.PACKAGE_TAG + '-pr-' + env.PULL_REQUEST + '|arm64v8-' + env.EXT_RELEASE_CLEAN + '-pkg-' + env.PACKAGE_TAG + '-pr-' + env.PULL_REQUEST
|
|
||||||
} else {
|
|
||||||
env.CI_TAGS = env.EXT_RELEASE_CLEAN + '-pkg-' + env.PACKAGE_TAG + '-pr-' + env.PULL_REQUEST
|
|
||||||
}
|
|
||||||
env.VERSION_TAG = env.EXT_RELEASE_CLEAN + '-pkg-' + env.PACKAGE_TAG + '-pr-' + env.PULL_REQUEST
|
|
||||||
env.META_TAG = env.EXT_RELEASE_CLEAN + '-pkg-' + env.PACKAGE_TAG + '-pr-' + env.PULL_REQUEST
|
|
||||||
env.EXT_RELEASE_TAG = 'version-' + env.EXT_RELEASE_CLEAN
|
|
||||||
env.CODE_URL = 'https://github.com/' + env.LS_USER + '/' + env.LS_REPO + '/pull/' + env.PULL_REQUEST
|
|
||||||
env.DOCKERHUB_LINK = 'https://hub.docker.com/r/' + env.PR_DOCKERHUB_IMAGE + '/tags/'
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
|
||||||
// Run ShellCheck
|
|
||||||
stage('ShellCheck') {
|
|
||||||
when {
|
|
||||||
environment name: 'CI', value: 'true'
|
|
||||||
}
|
|
||||||
steps {
|
|
||||||
withCredentials([
|
|
||||||
string(credentialsId: 'ci-tests-s3-key-id', variable: 'S3_KEY'),
|
|
||||||
string(credentialsId: 'ci-tests-s3-secret-access-key', variable: 'S3_SECRET')
|
|
||||||
]) {
|
|
||||||
script{
|
|
||||||
env.SHELLCHECK_URL = 'https://ci-tests.linuxserver.io/' + env.IMAGE + '/' + env.META_TAG + '/shellcheck-result.xml'
|
|
||||||
}
|
|
||||||
sh '''curl -sL https://raw.githubusercontent.com/linuxserver/docker-shellcheck/master/checkrun.sh | /bin/bash'''
|
|
||||||
sh '''#! /bin/bash
|
|
||||||
docker run --rm \
|
|
||||||
-v ${WORKSPACE}:/mnt \
|
|
||||||
-e AWS_ACCESS_KEY_ID=\"${S3_KEY}\" \
|
|
||||||
-e AWS_SECRET_ACCESS_KEY=\"${S3_SECRET}\" \
|
|
||||||
ghcr.io/linuxserver/baseimage-alpine:3.17 s6-envdir -fn -- /var/run/s6/container_environment /bin/bash -c "\
|
|
||||||
apk add --no-cache py3-pip && \
|
|
||||||
pip install s3cmd && \
|
|
||||||
s3cmd put --no-preserve --acl-public -m text/xml /mnt/shellcheck-result.xml s3://ci-tests.linuxserver.io/${IMAGE}/${META_TAG}/shellcheck-result.xml" || :'''
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
|
||||||
// Use helper containers to render templated files
|
|
||||||
stage('Update-Templates') {
|
|
||||||
when {
|
|
||||||
branch "master"
|
|
||||||
environment name: 'CHANGE_ID', value: ''
|
|
||||||
expression {
|
|
||||||
env.CONTAINER_NAME != null
|
|
||||||
}
|
|
||||||
}
|
|
||||||
steps {
|
|
||||||
sh '''#! /bin/bash
|
|
||||||
set -e
|
|
||||||
TEMPDIR=$(mktemp -d)
|
|
||||||
docker pull ghcr.io/linuxserver/jenkins-builder:latest
|
|
||||||
docker run --rm -e CONTAINER_NAME=${CONTAINER_NAME} -e GITHUB_BRANCH=master -v ${TEMPDIR}:/ansible/jenkins ghcr.io/linuxserver/jenkins-builder:latest
|
|
||||||
# Stage 1 - Jenkinsfile update
|
|
||||||
if [[ "$(md5sum Jenkinsfile | awk '{ print $1 }')" != "$(md5sum ${TEMPDIR}/docker-${CONTAINER_NAME}/Jenkinsfile | awk '{ print $1 }')" ]]; then
|
|
||||||
mkdir -p ${TEMPDIR}/repo
|
|
||||||
git clone https://github.com/${LS_USER}/${LS_REPO}.git ${TEMPDIR}/repo/${LS_REPO}
|
|
||||||
cd ${TEMPDIR}/repo/${LS_REPO}
|
|
||||||
git checkout -f master
|
|
||||||
cp ${TEMPDIR}/docker-${CONTAINER_NAME}/Jenkinsfile ${TEMPDIR}/repo/${LS_REPO}/
|
|
||||||
git add Jenkinsfile
|
|
||||||
git commit -m 'Bot Updating Templated Files'
|
|
||||||
git push https://LinuxServer-CI:${GITHUB_TOKEN}@github.com/${LS_USER}/${LS_REPO}.git --all
|
|
||||||
echo "true" > /tmp/${COMMIT_SHA}-${BUILD_NUMBER}
|
|
||||||
echo "Updating Jenkinsfile"
|
|
||||||
rm -Rf ${TEMPDIR}
|
|
||||||
exit 0
|
|
||||||
else
|
|
||||||
echo "Jenkinsfile is up to date."
|
|
||||||
fi
|
|
||||||
# Stage 2 - Delete old templates
|
|
||||||
OLD_TEMPLATES=".github/ISSUE_TEMPLATE.md .github/ISSUE_TEMPLATE/issue.bug.md .github/ISSUE_TEMPLATE/issue.feature.md .github/workflows/call_invalid_helper.yml .github/workflows/stale.yml"
|
|
||||||
for i in ${OLD_TEMPLATES}; do
|
|
||||||
if [[ -f "${i}" ]]; then
|
|
||||||
TEMPLATES_TO_DELETE="${i} ${TEMPLATES_TO_DELETE}"
|
|
||||||
fi
|
|
||||||
done
|
|
||||||
if [[ -n "${TEMPLATES_TO_DELETE}" ]]; then
|
|
||||||
mkdir -p ${TEMPDIR}/repo
|
|
||||||
git clone https://github.com/${LS_USER}/${LS_REPO}.git ${TEMPDIR}/repo/${LS_REPO}
|
|
||||||
cd ${TEMPDIR}/repo/${LS_REPO}
|
|
||||||
git checkout -f master
|
|
||||||
for i in ${TEMPLATES_TO_DELETE}; do
|
|
||||||
git rm "${i}"
|
|
||||||
done
|
|
||||||
git commit -m 'Bot Updating Templated Files'
|
|
||||||
git push https://LinuxServer-CI:${GITHUB_TOKEN}@github.com/${LS_USER}/${LS_REPO}.git --all
|
|
||||||
echo "true" > /tmp/${COMMIT_SHA}-${BUILD_NUMBER}
|
|
||||||
echo "Deleting old and deprecated templates"
|
|
||||||
rm -Rf ${TEMPDIR}
|
|
||||||
exit 0
|
|
||||||
else
|
|
||||||
echo "No templates to delete"
|
|
||||||
fi
|
|
||||||
# Stage 3 - Update templates
|
|
||||||
CURRENTHASH=$(grep -hs ^ ${TEMPLATED_FILES} | md5sum | cut -c1-8)
|
|
||||||
cd ${TEMPDIR}/docker-${CONTAINER_NAME}
|
|
||||||
NEWHASH=$(grep -hs ^ ${TEMPLATED_FILES} | md5sum | cut -c1-8)
|
|
||||||
if [[ "${CURRENTHASH}" != "${NEWHASH}" ]] || ! grep -q '.jenkins-external' "${WORKSPACE}/.gitignore" 2>/dev/null; then
|
|
||||||
mkdir -p ${TEMPDIR}/repo
|
|
||||||
git clone https://github.com/${LS_USER}/${LS_REPO}.git ${TEMPDIR}/repo/${LS_REPO}
|
|
||||||
cd ${TEMPDIR}/repo/${LS_REPO}
|
|
||||||
git checkout -f master
|
|
||||||
cd ${TEMPDIR}/docker-${CONTAINER_NAME}
|
|
||||||
mkdir -p ${TEMPDIR}/repo/${LS_REPO}/.github/workflows
|
|
||||||
mkdir -p ${TEMPDIR}/repo/${LS_REPO}/.github/ISSUE_TEMPLATE
|
|
||||||
cp --parents ${TEMPLATED_FILES} ${TEMPDIR}/repo/${LS_REPO}/ || :
|
|
||||||
cd ${TEMPDIR}/repo/${LS_REPO}/
|
|
||||||
if ! grep -q '.jenkins-external' .gitignore 2>/dev/null; then
|
|
||||||
echo ".jenkins-external" >> .gitignore
|
|
||||||
git add .gitignore
|
|
||||||
fi
|
|
||||||
git add ${TEMPLATED_FILES}
|
|
||||||
git commit -m 'Bot Updating Templated Files'
|
|
||||||
git push https://LinuxServer-CI:${GITHUB_TOKEN}@github.com/${LS_USER}/${LS_REPO}.git --all
|
|
||||||
echo "true" > /tmp/${COMMIT_SHA}-${BUILD_NUMBER}
|
|
||||||
else
|
|
||||||
echo "false" > /tmp/${COMMIT_SHA}-${BUILD_NUMBER}
|
|
||||||
fi
|
|
||||||
mkdir -p ${TEMPDIR}/gitbook
|
|
||||||
git clone https://github.com/linuxserver/docker-documentation.git ${TEMPDIR}/gitbook/docker-documentation
|
|
||||||
if [[ ("${BRANCH_NAME}" == "master") || ("${BRANCH_NAME}" == "main") ]] && [[ (! -f ${TEMPDIR}/gitbook/docker-documentation/images/docker-${CONTAINER_NAME}.md) || ("$(md5sum ${TEMPDIR}/gitbook/docker-documentation/images/docker-${CONTAINER_NAME}.md | awk '{ print $1 }')" != "$(md5sum ${TEMPDIR}/docker-${CONTAINER_NAME}/.jenkins-external/docker-${CONTAINER_NAME}.md | awk '{ print $1 }')") ]]; then
|
|
||||||
cp ${TEMPDIR}/docker-${CONTAINER_NAME}/.jenkins-external/docker-${CONTAINER_NAME}.md ${TEMPDIR}/gitbook/docker-documentation/images/
|
|
||||||
cd ${TEMPDIR}/gitbook/docker-documentation/
|
|
||||||
git add images/docker-${CONTAINER_NAME}.md
|
|
||||||
git commit -m 'Bot Updating Documentation'
|
|
||||||
git push https://LinuxServer-CI:${GITHUB_TOKEN}@github.com/linuxserver/docker-documentation.git --all
|
|
||||||
fi
|
|
||||||
mkdir -p ${TEMPDIR}/unraid
|
|
||||||
git clone https://github.com/linuxserver/docker-templates.git ${TEMPDIR}/unraid/docker-templates
|
|
||||||
git clone https://github.com/linuxserver/templates.git ${TEMPDIR}/unraid/templates
|
|
||||||
if [[ -f ${TEMPDIR}/unraid/docker-templates/linuxserver.io/img/${CONTAINER_NAME}-logo.png ]]; then
|
|
||||||
sed -i "s|master/linuxserver.io/img/linuxserver-ls-logo.png|master/linuxserver.io/img/${CONTAINER_NAME}-logo.png|" ${TEMPDIR}/docker-${CONTAINER_NAME}/.jenkins-external/${CONTAINER_NAME}.xml
|
|
||||||
fi
|
|
||||||
if [[ ("${BRANCH_NAME}" == "master") || ("${BRANCH_NAME}" == "main") ]] && [[ (! -f ${TEMPDIR}/unraid/templates/unraid/${CONTAINER_NAME}.xml) || ("$(md5sum ${TEMPDIR}/unraid/templates/unraid/${CONTAINER_NAME}.xml | awk '{ print $1 }')" != "$(md5sum ${TEMPDIR}/docker-${CONTAINER_NAME}/.jenkins-external/${CONTAINER_NAME}.xml | awk '{ print $1 }')") ]]; then
|
|
||||||
cd ${TEMPDIR}/unraid/templates/
|
|
||||||
if grep -wq "${CONTAINER_NAME}" ${TEMPDIR}/unraid/templates/unraid/ignore.list; then
|
|
||||||
echo "Image is on the ignore list, marking Unraid template as deprecated"
|
|
||||||
cp ${TEMPDIR}/docker-${CONTAINER_NAME}/.jenkins-external/${CONTAINER_NAME}.xml ${TEMPDIR}/unraid/templates/unraid/
|
|
||||||
git add -u unraid/${CONTAINER_NAME}.xml
|
|
||||||
git mv unraid/${CONTAINER_NAME}.xml unraid/deprecated/${CONTAINER_NAME}.xml || :
|
|
||||||
git commit -m 'Bot Moving Deprecated Unraid Template' || :
|
|
||||||
else
|
|
||||||
cp ${TEMPDIR}/docker-${CONTAINER_NAME}/.jenkins-external/${CONTAINER_NAME}.xml ${TEMPDIR}/unraid/templates/unraid/
|
|
||||||
git add unraid/${CONTAINER_NAME}.xml
|
|
||||||
git commit -m 'Bot Updating Unraid Template'
|
|
||||||
fi
|
|
||||||
git push https://LinuxServer-CI:${GITHUB_TOKEN}@github.com/linuxserver/templates.git --all
|
|
||||||
fi
|
|
||||||
rm -Rf ${TEMPDIR}'''
|
|
||||||
script{
|
|
||||||
env.FILES_UPDATED = sh(
|
|
||||||
script: '''cat /tmp/${COMMIT_SHA}-${BUILD_NUMBER}''',
|
|
||||||
returnStdout: true).trim()
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
|
||||||
// Exit the build if the Templated files were just updated
|
|
||||||
stage('Template-exit') {
|
|
||||||
when {
|
|
||||||
branch "master"
|
|
||||||
environment name: 'CHANGE_ID', value: ''
|
|
||||||
environment name: 'FILES_UPDATED', value: 'true'
|
|
||||||
expression {
|
|
||||||
env.CONTAINER_NAME != null
|
|
||||||
}
|
|
||||||
}
|
|
||||||
steps {
|
|
||||||
script{
|
|
||||||
env.EXIT_STATUS = 'ABORTED'
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
|
||||||
/* #######################
|
|
||||||
GitLab Mirroring
|
|
||||||
####################### */
|
|
||||||
// Ping into Gitlab to mirror this repo and have a registry endpoint
|
|
||||||
stage("GitLab Mirror"){
|
|
||||||
when {
|
|
||||||
environment name: 'EXIT_STATUS', value: ''
|
|
||||||
}
|
|
||||||
steps{
|
|
||||||
sh '''curl -H "Content-Type: application/json" -H "Private-Token: ${GITLAB_TOKEN}" -X POST https://gitlab.com/api/v4/projects \
|
|
||||||
-d '{"namespace_id":'${GITLAB_NAMESPACE}',\
|
|
||||||
"name":"'${LS_REPO}'",
|
|
||||||
"mirror":true,\
|
|
||||||
"import_url":"https://github.com/linuxserver/'${LS_REPO}'.git",\
|
|
||||||
"issues_access_level":"disabled",\
|
|
||||||
"merge_requests_access_level":"disabled",\
|
|
||||||
"repository_access_level":"enabled",\
|
|
||||||
"visibility":"public"}' '''
|
|
||||||
}
|
|
||||||
}
|
|
||||||
/* #######################
|
|
||||||
Scarf.sh package registry
|
|
||||||
####################### */
|
|
||||||
// Add package to Scarf.sh and set permissions
|
|
||||||
stage("Scarf.sh package registry"){
|
|
||||||
when {
|
|
||||||
branch "master"
|
|
||||||
environment name: 'EXIT_STATUS', value: ''
|
|
||||||
}
|
|
||||||
steps{
|
|
||||||
sh '''#! /bin/bash
|
|
||||||
set -e
|
|
||||||
PACKAGE_UUID=$(curl -X GET -H "Authorization: Bearer ${SCARF_TOKEN}" https://scarf.sh/api/v1/organizations/linuxserver-ci/packages | jq -r '.[] | select(.name=="linuxserver/emulatorjs") | .uuid')
|
|
||||||
if [ -z "${PACKAGE_UUID}" ]; then
|
|
||||||
echo "Adding package to Scarf.sh"
|
|
||||||
curl -sX POST https://scarf.sh/api/v1/organizations/linuxserver-ci/packages \
|
|
||||||
-H "Authorization: Bearer ${SCARF_TOKEN}" \
|
|
||||||
-H "Content-Type: application/json" \
|
|
||||||
-d '{"name":"linuxserver/emulatorjs",\
|
|
||||||
"shortDescription":"example description",\
|
|
||||||
"libraryType":"docker",\
|
|
||||||
"website":"https://github.com/linuxserver/docker-emulatorjs",\
|
|
||||||
"backendUrl":"https://ghcr.io/linuxserver/emulatorjs",\
|
|
||||||
"publicUrl":"https://lscr.io/linuxserver/emulatorjs"}' || :
|
|
||||||
else
|
|
||||||
echo "Package already exists on Scarf.sh"
|
|
||||||
fi
|
|
||||||
'''
|
|
||||||
}
|
|
||||||
}
|
|
||||||
/* ###############
|
|
||||||
Build Container
|
|
||||||
############### */
|
|
||||||
// Build Docker container for push to LS Repo
|
|
||||||
stage('Build-Single') {
|
|
||||||
when {
|
|
||||||
expression {
|
|
||||||
env.MULTIARCH == 'false' || params.PACKAGE_CHECK == 'true'
|
|
||||||
}
|
|
||||||
environment name: 'EXIT_STATUS', value: ''
|
|
||||||
}
|
|
||||||
steps {
|
|
||||||
echo "Running on node: ${NODE_NAME}"
|
|
||||||
sh "sed -r -i 's|(^FROM .*)|\\1\\n\\nENV LSIO_FIRST_PARTY=true|g' Dockerfile"
|
|
||||||
sh "docker buildx build \
|
|
||||||
--label \"org.opencontainers.image.created=${GITHUB_DATE}\" \
|
|
||||||
--label \"org.opencontainers.image.authors=linuxserver.io\" \
|
|
||||||
--label \"org.opencontainers.image.url=https://github.com/linuxserver/docker-emulatorjs/packages\" \
|
|
||||||
--label \"org.opencontainers.image.documentation=https://docs.linuxserver.io/images/docker-emulatorjs\" \
|
|
||||||
--label \"org.opencontainers.image.source=https://github.com/linuxserver/docker-emulatorjs\" \
|
|
||||||
--label \"org.opencontainers.image.version=${EXT_RELEASE_CLEAN}-ls${LS_TAG_NUMBER}\" \
|
|
||||||
--label \"org.opencontainers.image.revision=${COMMIT_SHA}\" \
|
|
||||||
--label \"org.opencontainers.image.vendor=linuxserver.io\" \
|
|
||||||
--label \"org.opencontainers.image.licenses=GPL-3.0-only\" \
|
|
||||||
--label \"org.opencontainers.image.ref.name=${COMMIT_SHA}\" \
|
|
||||||
--label \"org.opencontainers.image.title=Emulatorjs\" \
|
|
||||||
--label \"org.opencontainers.image.description=[Emulatorjs](https://github.com/linuxserver/emulatorjs) - In browser web based emulation portable to nearly any device for many retro consoles. A mix of emulators is used between Libretro and EmulatorJS. \" \
|
|
||||||
--no-cache --pull -t ${IMAGE}:${META_TAG} --platform=linux/amd64 \
|
|
||||||
--build-arg ${BUILD_VERSION_ARG}=${EXT_RELEASE} --build-arg VERSION=\"${VERSION_TAG}\" --build-arg BUILD_DATE=${GITHUB_DATE} ."
|
|
||||||
}
|
|
||||||
}
|
|
||||||
// Build MultiArch Docker containers for push to LS Repo
|
|
||||||
stage('Build-Multi') {
|
|
||||||
when {
|
|
||||||
allOf {
|
|
||||||
environment name: 'MULTIARCH', value: 'true'
|
|
||||||
expression { params.PACKAGE_CHECK == 'false' }
|
|
||||||
}
|
|
||||||
environment name: 'EXIT_STATUS', value: ''
|
|
||||||
}
|
|
||||||
parallel {
|
|
||||||
stage('Build X86') {
|
|
||||||
steps {
|
|
||||||
echo "Running on node: ${NODE_NAME}"
|
|
||||||
sh "sed -r -i 's|(^FROM .*)|\\1\\n\\nENV LSIO_FIRST_PARTY=true|g' Dockerfile"
|
|
||||||
sh "docker buildx build \
|
|
||||||
--label \"org.opencontainers.image.created=${GITHUB_DATE}\" \
|
|
||||||
--label \"org.opencontainers.image.authors=linuxserver.io\" \
|
|
||||||
--label \"org.opencontainers.image.url=https://github.com/linuxserver/docker-emulatorjs/packages\" \
|
|
||||||
--label \"org.opencontainers.image.documentation=https://docs.linuxserver.io/images/docker-emulatorjs\" \
|
|
||||||
--label \"org.opencontainers.image.source=https://github.com/linuxserver/docker-emulatorjs\" \
|
|
||||||
--label \"org.opencontainers.image.version=${EXT_RELEASE_CLEAN}-ls${LS_TAG_NUMBER}\" \
|
|
||||||
--label \"org.opencontainers.image.revision=${COMMIT_SHA}\" \
|
|
||||||
--label \"org.opencontainers.image.vendor=linuxserver.io\" \
|
|
||||||
--label \"org.opencontainers.image.licenses=GPL-3.0-only\" \
|
|
||||||
--label \"org.opencontainers.image.ref.name=${COMMIT_SHA}\" \
|
|
||||||
--label \"org.opencontainers.image.title=Emulatorjs\" \
|
|
||||||
--label \"org.opencontainers.image.description=[Emulatorjs](https://github.com/linuxserver/emulatorjs) - In browser web based emulation portable to nearly any device for many retro consoles. A mix of emulators is used between Libretro and EmulatorJS. \" \
|
|
||||||
--no-cache --pull -t ${IMAGE}:amd64-${META_TAG} --platform=linux/amd64 \
|
|
||||||
--build-arg ${BUILD_VERSION_ARG}=${EXT_RELEASE} --build-arg VERSION=\"${VERSION_TAG}\" --build-arg BUILD_DATE=${GITHUB_DATE} ."
|
|
||||||
}
|
|
||||||
}
|
|
||||||
stage('Build ARMHF') {
|
|
||||||
agent {
|
|
||||||
label 'ARMHF'
|
|
||||||
}
|
|
||||||
steps {
|
|
||||||
echo "Running on node: ${NODE_NAME}"
|
|
||||||
echo 'Logging into Github'
|
|
||||||
sh '''#! /bin/bash
|
|
||||||
echo $GITHUB_TOKEN | docker login ghcr.io -u LinuxServer-CI --password-stdin
|
|
||||||
'''
|
|
||||||
sh "sed -r -i 's|(^FROM .*)|\\1\\n\\nENV LSIO_FIRST_PARTY=true|g' Dockerfile.armhf"
|
|
||||||
sh "docker buildx build \
|
|
||||||
--label \"org.opencontainers.image.created=${GITHUB_DATE}\" \
|
|
||||||
--label \"org.opencontainers.image.authors=linuxserver.io\" \
|
|
||||||
--label \"org.opencontainers.image.url=https://github.com/linuxserver/docker-emulatorjs/packages\" \
|
|
||||||
--label \"org.opencontainers.image.documentation=https://docs.linuxserver.io/images/docker-emulatorjs\" \
|
|
||||||
--label \"org.opencontainers.image.source=https://github.com/linuxserver/docker-emulatorjs\" \
|
|
||||||
--label \"org.opencontainers.image.version=${EXT_RELEASE_CLEAN}-ls${LS_TAG_NUMBER}\" \
|
|
||||||
--label \"org.opencontainers.image.revision=${COMMIT_SHA}\" \
|
|
||||||
--label \"org.opencontainers.image.vendor=linuxserver.io\" \
|
|
||||||
--label \"org.opencontainers.image.licenses=GPL-3.0-only\" \
|
|
||||||
--label \"org.opencontainers.image.ref.name=${COMMIT_SHA}\" \
|
|
||||||
--label \"org.opencontainers.image.title=Emulatorjs\" \
|
|
||||||
--label \"org.opencontainers.image.description=[Emulatorjs](https://github.com/linuxserver/emulatorjs) - In browser web based emulation portable to nearly any device for many retro consoles. A mix of emulators is used between Libretro and EmulatorJS. \" \
|
|
||||||
--no-cache --pull -f Dockerfile.armhf -t ${IMAGE}:arm32v7-${META_TAG} --platform=linux/arm/v7 \
|
|
||||||
--build-arg ${BUILD_VERSION_ARG}=${EXT_RELEASE} --build-arg VERSION=\"${VERSION_TAG}\" --build-arg BUILD_DATE=${GITHUB_DATE} ."
|
|
||||||
sh "docker tag ${IMAGE}:arm32v7-${META_TAG} ghcr.io/linuxserver/lsiodev-buildcache:arm32v7-${COMMIT_SHA}-${BUILD_NUMBER}"
|
|
||||||
retry(5) {
|
|
||||||
sh "docker push ghcr.io/linuxserver/lsiodev-buildcache:arm32v7-${COMMIT_SHA}-${BUILD_NUMBER}"
|
|
||||||
}
|
|
||||||
sh '''docker rmi \
|
|
||||||
${IMAGE}:arm32v7-${META_TAG} \
|
|
||||||
ghcr.io/linuxserver/lsiodev-buildcache:arm32v7-${COMMIT_SHA}-${BUILD_NUMBER} || :'''
|
|
||||||
}
|
|
||||||
}
|
|
||||||
stage('Build ARM64') {
|
|
||||||
agent {
|
|
||||||
label 'ARM64'
|
|
||||||
}
|
|
||||||
steps {
|
|
||||||
echo "Running on node: ${NODE_NAME}"
|
|
||||||
echo 'Logging into Github'
|
|
||||||
sh '''#! /bin/bash
|
|
||||||
echo $GITHUB_TOKEN | docker login ghcr.io -u LinuxServer-CI --password-stdin
|
|
||||||
'''
|
|
||||||
sh "sed -r -i 's|(^FROM .*)|\\1\\n\\nENV LSIO_FIRST_PARTY=true|g' Dockerfile.aarch64"
|
|
||||||
sh "docker buildx build \
|
|
||||||
--label \"org.opencontainers.image.created=${GITHUB_DATE}\" \
|
|
||||||
--label \"org.opencontainers.image.authors=linuxserver.io\" \
|
|
||||||
--label \"org.opencontainers.image.url=https://github.com/linuxserver/docker-emulatorjs/packages\" \
|
|
||||||
--label \"org.opencontainers.image.documentation=https://docs.linuxserver.io/images/docker-emulatorjs\" \
|
|
||||||
--label \"org.opencontainers.image.source=https://github.com/linuxserver/docker-emulatorjs\" \
|
|
||||||
--label \"org.opencontainers.image.version=${EXT_RELEASE_CLEAN}-ls${LS_TAG_NUMBER}\" \
|
|
||||||
--label \"org.opencontainers.image.revision=${COMMIT_SHA}\" \
|
|
||||||
--label \"org.opencontainers.image.vendor=linuxserver.io\" \
|
|
||||||
--label \"org.opencontainers.image.licenses=GPL-3.0-only\" \
|
|
||||||
--label \"org.opencontainers.image.ref.name=${COMMIT_SHA}\" \
|
|
||||||
--label \"org.opencontainers.image.title=Emulatorjs\" \
|
|
||||||
--label \"org.opencontainers.image.description=[Emulatorjs](https://github.com/linuxserver/emulatorjs) - In browser web based emulation portable to nearly any device for many retro consoles. A mix of emulators is used between Libretro and EmulatorJS. \" \
|
|
||||||
--no-cache --pull -f Dockerfile.aarch64 -t ${IMAGE}:arm64v8-${META_TAG} --platform=linux/arm64 \
|
|
||||||
--build-arg ${BUILD_VERSION_ARG}=${EXT_RELEASE} --build-arg VERSION=\"${VERSION_TAG}\" --build-arg BUILD_DATE=${GITHUB_DATE} ."
|
|
||||||
sh "docker tag ${IMAGE}:arm64v8-${META_TAG} ghcr.io/linuxserver/lsiodev-buildcache:arm64v8-${COMMIT_SHA}-${BUILD_NUMBER}"
|
|
||||||
retry(5) {
|
|
||||||
sh "docker push ghcr.io/linuxserver/lsiodev-buildcache:arm64v8-${COMMIT_SHA}-${BUILD_NUMBER}"
|
|
||||||
}
|
|
||||||
sh '''docker rmi \
|
|
||||||
${IMAGE}:arm64v8-${META_TAG} \
|
|
||||||
ghcr.io/linuxserver/lsiodev-buildcache:arm64v8-${COMMIT_SHA}-${BUILD_NUMBER} || :'''
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
|
||||||
// Take the image we just built and dump package versions for comparison
|
|
||||||
stage('Update-packages') {
|
|
||||||
when {
|
|
||||||
branch "master"
|
|
||||||
environment name: 'CHANGE_ID', value: ''
|
|
||||||
environment name: 'EXIT_STATUS', value: ''
|
|
||||||
}
|
|
||||||
steps {
|
|
||||||
sh '''#! /bin/bash
|
|
||||||
set -e
|
|
||||||
TEMPDIR=$(mktemp -d)
|
|
||||||
if [ "${MULTIARCH}" == "true" ] && [ "${PACKAGE_CHECK}" == "false" ]; then
|
|
||||||
LOCAL_CONTAINER=${IMAGE}:amd64-${META_TAG}
|
|
||||||
else
|
|
||||||
LOCAL_CONTAINER=${IMAGE}:${META_TAG}
|
|
||||||
fi
|
|
||||||
touch ${TEMPDIR}/package_versions.txt
|
|
||||||
docker run --rm \
|
|
||||||
-v /var/run/docker.sock:/var/run/docker.sock:ro \
|
|
||||||
-v ${TEMPDIR}:/tmp \
|
|
||||||
ghcr.io/anchore/syft:latest \
|
|
||||||
${LOCAL_CONTAINER} -o table=/tmp/package_versions.txt
|
|
||||||
NEW_PACKAGE_TAG=$(md5sum ${TEMPDIR}/package_versions.txt | cut -c1-8 )
|
|
||||||
echo "Package tag sha from current packages in buit container is ${NEW_PACKAGE_TAG} comparing to old ${PACKAGE_TAG} from github"
|
|
||||||
if [ "${NEW_PACKAGE_TAG}" != "${PACKAGE_TAG}" ]; then
|
|
||||||
git clone https://github.com/${LS_USER}/${LS_REPO}.git ${TEMPDIR}/${LS_REPO}
|
|
||||||
git --git-dir ${TEMPDIR}/${LS_REPO}/.git checkout -f master
|
|
||||||
cp ${TEMPDIR}/package_versions.txt ${TEMPDIR}/${LS_REPO}/
|
|
||||||
cd ${TEMPDIR}/${LS_REPO}/
|
|
||||||
wait
|
|
||||||
git add package_versions.txt
|
|
||||||
git commit -m 'Bot Updating Package Versions'
|
|
||||||
git push https://LinuxServer-CI:${GITHUB_TOKEN}@github.com/${LS_USER}/${LS_REPO}.git --all
|
|
||||||
echo "true" > /tmp/packages-${COMMIT_SHA}-${BUILD_NUMBER}
|
|
||||||
echo "Package tag updated, stopping build process"
|
|
||||||
else
|
|
||||||
echo "false" > /tmp/packages-${COMMIT_SHA}-${BUILD_NUMBER}
|
|
||||||
echo "Package tag is same as previous continue with build process"
|
|
||||||
fi
|
|
||||||
rm -Rf ${TEMPDIR}'''
|
|
||||||
script{
|
|
||||||
env.PACKAGE_UPDATED = sh(
|
|
||||||
script: '''cat /tmp/packages-${COMMIT_SHA}-${BUILD_NUMBER}''',
|
|
||||||
returnStdout: true).trim()
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
|
||||||
// Exit the build if the package file was just updated
|
|
||||||
stage('PACKAGE-exit') {
|
|
||||||
when {
|
|
||||||
branch "master"
|
|
||||||
environment name: 'CHANGE_ID', value: ''
|
|
||||||
environment name: 'PACKAGE_UPDATED', value: 'true'
|
|
||||||
environment name: 'EXIT_STATUS', value: ''
|
|
||||||
}
|
|
||||||
steps {
|
|
||||||
sh '''#! /bin/bash
|
|
||||||
echo "Packages were updated. Cleaning up the image and exiting."
|
|
||||||
if [ "${MULTIARCH}" == "true" ] && [ "${PACKAGE_CHECK}" == "false" ]; then
|
|
||||||
docker rmi ${IMAGE}:amd64-${META_TAG}
|
|
||||||
else
|
|
||||||
docker rmi ${IMAGE}:${META_TAG}
|
|
||||||
fi'''
|
|
||||||
script{
|
|
||||||
env.EXIT_STATUS = 'ABORTED'
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
|
||||||
// Exit the build if this is just a package check and there are no changes to push
|
|
||||||
stage('PACKAGECHECK-exit') {
|
|
||||||
when {
|
|
||||||
branch "master"
|
|
||||||
environment name: 'CHANGE_ID', value: ''
|
|
||||||
environment name: 'PACKAGE_UPDATED', value: 'false'
|
|
||||||
environment name: 'EXIT_STATUS', value: ''
|
|
||||||
expression {
|
|
||||||
params.PACKAGE_CHECK == 'true'
|
|
||||||
}
|
|
||||||
}
|
|
||||||
steps {
|
|
||||||
sh '''#! /bin/bash
|
|
||||||
echo "There are no package updates. Cleaning up the image and exiting."
|
|
||||||
if [ "${MULTIARCH}" == "true" ] && [ "${PACKAGE_CHECK}" == "false" ]; then
|
|
||||||
docker rmi ${IMAGE}:amd64-${META_TAG}
|
|
||||||
else
|
|
||||||
docker rmi ${IMAGE}:${META_TAG}
|
|
||||||
fi'''
|
|
||||||
script{
|
|
||||||
env.EXIT_STATUS = 'ABORTED'
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
|
||||||
/* #######
|
|
||||||
Testing
|
|
||||||
####### */
|
|
||||||
// Run Container tests
|
|
||||||
stage('Test') {
|
|
||||||
when {
|
|
||||||
environment name: 'CI', value: 'true'
|
|
||||||
environment name: 'EXIT_STATUS', value: ''
|
|
||||||
}
|
|
||||||
steps {
|
|
||||||
withCredentials([
|
|
||||||
string(credentialsId: 'ci-tests-s3-key-id', variable: 'S3_KEY'),
|
|
||||||
string(credentialsId: 'ci-tests-s3-secret-access-key ', variable: 'S3_SECRET')
|
|
||||||
]) {
|
|
||||||
script{
|
|
||||||
env.CI_URL = 'https://ci-tests.linuxserver.io/' + env.IMAGE + '/' + env.META_TAG + '/index.html'
|
|
||||||
}
|
|
||||||
sh '''#! /bin/bash
|
|
||||||
set -e
|
|
||||||
docker pull ghcr.io/linuxserver/ci:latest
|
|
||||||
if [ "${MULTIARCH}" == "true" ]; then
|
|
||||||
docker pull ghcr.io/linuxserver/lsiodev-buildcache:arm32v7-${COMMIT_SHA}-${BUILD_NUMBER}
|
|
||||||
docker pull ghcr.io/linuxserver/lsiodev-buildcache:arm64v8-${COMMIT_SHA}-${BUILD_NUMBER}
|
|
||||||
docker tag ghcr.io/linuxserver/lsiodev-buildcache:arm32v7-${COMMIT_SHA}-${BUILD_NUMBER} ${IMAGE}:arm32v7-${META_TAG}
|
|
||||||
docker tag ghcr.io/linuxserver/lsiodev-buildcache:arm64v8-${COMMIT_SHA}-${BUILD_NUMBER} ${IMAGE}:arm64v8-${META_TAG}
|
|
||||||
fi
|
|
||||||
docker run --rm \
|
|
||||||
--shm-size=1gb \
|
|
||||||
-v /var/run/docker.sock:/var/run/docker.sock \
|
|
||||||
-e IMAGE=\"${IMAGE}\" \
|
|
||||||
-e DELAY_START=\"${CI_DELAY}\" \
|
|
||||||
-e TAGS=\"${CI_TAGS}\" \
|
|
||||||
-e META_TAG=\"${META_TAG}\" \
|
|
||||||
-e PORT=\"${CI_PORT}\" \
|
|
||||||
-e SSL=\"${CI_SSL}\" \
|
|
||||||
-e BASE=\"${DIST_IMAGE}\" \
|
|
||||||
-e SECRET_KEY=\"${S3_SECRET}\" \
|
|
||||||
-e ACCESS_KEY=\"${S3_KEY}\" \
|
|
||||||
-e DOCKER_ENV=\"${CI_DOCKERENV}\" \
|
|
||||||
-e WEB_SCREENSHOT=\"${CI_WEB}\" \
|
|
||||||
-e WEB_AUTH=\"${CI_AUTH}\" \
|
|
||||||
-e WEB_PATH=\"${CI_WEBPATH}\" \
|
|
||||||
-e DO_REGION="ams3" \
|
|
||||||
-e DO_BUCKET="lsio-ci" \
|
|
||||||
-t ghcr.io/linuxserver/ci:latest \
|
|
||||||
python3 test_build.py'''
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
|
||||||
/* ##################
|
|
||||||
Release Logic
|
|
||||||
################## */
|
|
||||||
// If this is an amd64 only image only push a single image
|
|
||||||
stage('Docker-Push-Single') {
|
|
||||||
when {
|
|
||||||
environment name: 'MULTIARCH', value: 'false'
|
|
||||||
environment name: 'EXIT_STATUS', value: ''
|
|
||||||
}
|
|
||||||
steps {
|
|
||||||
withCredentials([
|
|
||||||
[
|
|
||||||
$class: 'UsernamePasswordMultiBinding',
|
|
||||||
credentialsId: '3f9ba4d5-100d-45b0-a3c4-633fd6061207',
|
|
||||||
usernameVariable: 'DOCKERUSER',
|
|
||||||
passwordVariable: 'DOCKERPASS'
|
|
||||||
],
|
|
||||||
[
|
|
||||||
$class: 'UsernamePasswordMultiBinding',
|
|
||||||
credentialsId: 'Quay.io-Robot',
|
|
||||||
usernameVariable: 'QUAYUSER',
|
|
||||||
passwordVariable: 'QUAYPASS'
|
|
||||||
]
|
|
||||||
]) {
|
|
||||||
retry(5) {
|
|
||||||
sh '''#! /bin/bash
|
|
||||||
set -e
|
|
||||||
echo $DOCKERPASS | docker login -u $DOCKERUSER --password-stdin
|
|
||||||
echo $GITHUB_TOKEN | docker login ghcr.io -u LinuxServer-CI --password-stdin
|
|
||||||
echo $GITLAB_TOKEN | docker login registry.gitlab.com -u LinuxServer.io --password-stdin
|
|
||||||
echo $QUAYPASS | docker login quay.io -u $QUAYUSER --password-stdin
|
|
||||||
for PUSHIMAGE in "${GITHUBIMAGE}" "${GITLABIMAGE}" "${QUAYIMAGE}" "${IMAGE}"; do
|
|
||||||
docker tag ${IMAGE}:${META_TAG} ${PUSHIMAGE}:${META_TAG}
|
|
||||||
docker tag ${PUSHIMAGE}:${META_TAG} ${PUSHIMAGE}:latest
|
|
||||||
docker tag ${PUSHIMAGE}:${META_TAG} ${PUSHIMAGE}:${EXT_RELEASE_TAG}
|
|
||||||
if [ -n "${SEMVER}" ]; then
|
|
||||||
docker tag ${PUSHIMAGE}:${META_TAG} ${PUSHIMAGE}:${SEMVER}
|
|
||||||
fi
|
|
||||||
docker push ${PUSHIMAGE}:latest
|
|
||||||
docker push ${PUSHIMAGE}:${META_TAG}
|
|
||||||
docker push ${PUSHIMAGE}:${EXT_RELEASE_TAG}
|
|
||||||
if [ -n "${SEMVER}" ]; then
|
|
||||||
docker push ${PUSHIMAGE}:${SEMVER}
|
|
||||||
fi
|
|
||||||
done
|
|
||||||
'''
|
|
||||||
}
|
|
||||||
sh '''#! /bin/bash
|
|
||||||
for DELETEIMAGE in "${GITHUBIMAGE}" "${GITLABIMAGE}" "${QUAYIMAGE}" "${IMAGE}"; do
|
|
||||||
docker rmi \
|
|
||||||
${DELETEIMAGE}:${META_TAG} \
|
|
||||||
${DELETEIMAGE}:${EXT_RELEASE_TAG} \
|
|
||||||
${DELETEIMAGE}:latest || :
|
|
||||||
if [ -n "${SEMVER}" ]; then
|
|
||||||
docker rmi ${DELETEIMAGE}:${SEMVER} || :
|
|
||||||
fi
|
|
||||||
done
|
|
||||||
'''
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
|
||||||
// If this is a multi arch release push all images and define the manifest
|
|
||||||
stage('Docker-Push-Multi') {
|
|
||||||
when {
|
|
||||||
environment name: 'MULTIARCH', value: 'true'
|
|
||||||
environment name: 'EXIT_STATUS', value: ''
|
|
||||||
}
|
|
||||||
steps {
|
|
||||||
withCredentials([
|
|
||||||
[
|
|
||||||
$class: 'UsernamePasswordMultiBinding',
|
|
||||||
credentialsId: '3f9ba4d5-100d-45b0-a3c4-633fd6061207',
|
|
||||||
usernameVariable: 'DOCKERUSER',
|
|
||||||
passwordVariable: 'DOCKERPASS'
|
|
||||||
],
|
|
||||||
[
|
|
||||||
$class: 'UsernamePasswordMultiBinding',
|
|
||||||
credentialsId: 'Quay.io-Robot',
|
|
||||||
usernameVariable: 'QUAYUSER',
|
|
||||||
passwordVariable: 'QUAYPASS'
|
|
||||||
]
|
|
||||||
]) {
|
|
||||||
retry(5) {
|
|
||||||
sh '''#! /bin/bash
|
|
||||||
set -e
|
|
||||||
echo $DOCKERPASS | docker login -u $DOCKERUSER --password-stdin
|
|
||||||
echo $GITHUB_TOKEN | docker login ghcr.io -u LinuxServer-CI --password-stdin
|
|
||||||
echo $GITLAB_TOKEN | docker login registry.gitlab.com -u LinuxServer.io --password-stdin
|
|
||||||
echo $QUAYPASS | docker login quay.io -u $QUAYUSER --password-stdin
|
|
||||||
if [ "${CI}" == "false" ]; then
|
|
||||||
docker pull ghcr.io/linuxserver/lsiodev-buildcache:arm32v7-${COMMIT_SHA}-${BUILD_NUMBER}
|
|
||||||
docker tag ghcr.io/linuxserver/lsiodev-buildcache:arm32v7-${COMMIT_SHA}-${BUILD_NUMBER} ${IMAGE}:arm32v7-${META_TAG}
|
|
||||||
docker pull ghcr.io/linuxserver/lsiodev-buildcache:arm64v8-${COMMIT_SHA}-${BUILD_NUMBER}
|
|
||||||
docker tag ghcr.io/linuxserver/lsiodev-buildcache:arm64v8-${COMMIT_SHA}-${BUILD_NUMBER} ${IMAGE}:arm64v8-${META_TAG}
|
|
||||||
fi
|
|
||||||
for MANIFESTIMAGE in "${IMAGE}" "${GITLABIMAGE}" "${GITHUBIMAGE}" "${QUAYIMAGE}"; do
|
|
||||||
docker tag ${IMAGE}:amd64-${META_TAG} ${MANIFESTIMAGE}:amd64-${META_TAG}
|
|
||||||
docker tag ${MANIFESTIMAGE}:amd64-${META_TAG} ${MANIFESTIMAGE}:amd64-latest
|
|
||||||
docker tag ${MANIFESTIMAGE}:amd64-${META_TAG} ${MANIFESTIMAGE}:amd64-${EXT_RELEASE_TAG}
|
|
||||||
docker tag ${IMAGE}:arm32v7-${META_TAG} ${MANIFESTIMAGE}:arm32v7-${META_TAG}
|
|
||||||
docker tag ${MANIFESTIMAGE}:arm32v7-${META_TAG} ${MANIFESTIMAGE}:arm32v7-latest
|
|
||||||
docker tag ${MANIFESTIMAGE}:arm32v7-${META_TAG} ${MANIFESTIMAGE}:arm32v7-${EXT_RELEASE_TAG}
|
|
||||||
docker tag ${IMAGE}:arm64v8-${META_TAG} ${MANIFESTIMAGE}:arm64v8-${META_TAG}
|
|
||||||
docker tag ${MANIFESTIMAGE}:arm64v8-${META_TAG} ${MANIFESTIMAGE}:arm64v8-latest
|
|
||||||
docker tag ${MANIFESTIMAGE}:arm64v8-${META_TAG} ${MANIFESTIMAGE}:arm64v8-${EXT_RELEASE_TAG}
|
|
||||||
if [ -n "${SEMVER}" ]; then
|
|
||||||
docker tag ${MANIFESTIMAGE}:amd64-${META_TAG} ${MANIFESTIMAGE}:amd64-${SEMVER}
|
|
||||||
docker tag ${MANIFESTIMAGE}:arm32v7-${META_TAG} ${MANIFESTIMAGE}:arm32v7-${SEMVER}
|
|
||||||
docker tag ${MANIFESTIMAGE}:arm64v8-${META_TAG} ${MANIFESTIMAGE}:arm64v8-${SEMVER}
|
|
||||||
fi
|
|
||||||
docker push ${MANIFESTIMAGE}:amd64-${META_TAG}
|
|
||||||
docker push ${MANIFESTIMAGE}:amd64-${EXT_RELEASE_TAG}
|
|
||||||
docker push ${MANIFESTIMAGE}:amd64-latest
|
|
||||||
docker push ${MANIFESTIMAGE}:arm32v7-${META_TAG}
|
|
||||||
docker push ${MANIFESTIMAGE}:arm32v7-latest
|
|
||||||
docker push ${MANIFESTIMAGE}:arm32v7-${EXT_RELEASE_TAG}
|
|
||||||
docker push ${MANIFESTIMAGE}:arm64v8-${META_TAG}
|
|
||||||
docker push ${MANIFESTIMAGE}:arm64v8-latest
|
|
||||||
docker push ${MANIFESTIMAGE}:arm64v8-${EXT_RELEASE_TAG}
|
|
||||||
if [ -n "${SEMVER}" ]; then
|
|
||||||
docker push ${MANIFESTIMAGE}:amd64-${SEMVER}
|
|
||||||
docker push ${MANIFESTIMAGE}:arm32v7-${SEMVER}
|
|
||||||
docker push ${MANIFESTIMAGE}:arm64v8-${SEMVER}
|
|
||||||
fi
|
|
||||||
docker manifest push --purge ${MANIFESTIMAGE}:latest || :
|
|
||||||
docker manifest create ${MANIFESTIMAGE}:latest ${MANIFESTIMAGE}:amd64-latest ${MANIFESTIMAGE}:arm32v7-latest ${MANIFESTIMAGE}:arm64v8-latest
|
|
||||||
docker manifest annotate ${MANIFESTIMAGE}:latest ${MANIFESTIMAGE}:arm32v7-latest --os linux --arch arm
|
|
||||||
docker manifest annotate ${MANIFESTIMAGE}:latest ${MANIFESTIMAGE}:arm64v8-latest --os linux --arch arm64 --variant v8
|
|
||||||
docker manifest push --purge ${MANIFESTIMAGE}:${META_TAG} || :
|
|
||||||
docker manifest create ${MANIFESTIMAGE}:${META_TAG} ${MANIFESTIMAGE}:amd64-${META_TAG} ${MANIFESTIMAGE}:arm32v7-${META_TAG} ${MANIFESTIMAGE}:arm64v8-${META_TAG}
|
|
||||||
docker manifest annotate ${MANIFESTIMAGE}:${META_TAG} ${MANIFESTIMAGE}:arm32v7-${META_TAG} --os linux --arch arm
|
|
||||||
docker manifest annotate ${MANIFESTIMAGE}:${META_TAG} ${MANIFESTIMAGE}:arm64v8-${META_TAG} --os linux --arch arm64 --variant v8
|
|
||||||
docker manifest push --purge ${MANIFESTIMAGE}:${EXT_RELEASE_TAG} || :
|
|
||||||
docker manifest create ${MANIFESTIMAGE}:${EXT_RELEASE_TAG} ${MANIFESTIMAGE}:amd64-${EXT_RELEASE_TAG} ${MANIFESTIMAGE}:arm32v7-${EXT_RELEASE_TAG} ${MANIFESTIMAGE}:arm64v8-${EXT_RELEASE_TAG}
|
|
||||||
docker manifest annotate ${MANIFESTIMAGE}:${EXT_RELEASE_TAG} ${MANIFESTIMAGE}:arm32v7-${EXT_RELEASE_TAG} --os linux --arch arm
|
|
||||||
docker manifest annotate ${MANIFESTIMAGE}:${EXT_RELEASE_TAG} ${MANIFESTIMAGE}:arm64v8-${EXT_RELEASE_TAG} --os linux --arch arm64 --variant v8
|
|
||||||
if [ -n "${SEMVER}" ]; then
|
|
||||||
docker manifest push --purge ${MANIFESTIMAGE}:${SEMVER} || :
|
|
||||||
docker manifest create ${MANIFESTIMAGE}:${SEMVER} ${MANIFESTIMAGE}:amd64-${SEMVER} ${MANIFESTIMAGE}:arm32v7-${SEMVER} ${MANIFESTIMAGE}:arm64v8-${SEMVER}
|
|
||||||
docker manifest annotate ${MANIFESTIMAGE}:${SEMVER} ${MANIFESTIMAGE}:arm32v7-${SEMVER} --os linux --arch arm
|
|
||||||
docker manifest annotate ${MANIFESTIMAGE}:${SEMVER} ${MANIFESTIMAGE}:arm64v8-${SEMVER} --os linux --arch arm64 --variant v8
|
|
||||||
fi
|
|
||||||
docker manifest push --purge ${MANIFESTIMAGE}:latest
|
|
||||||
docker manifest push --purge ${MANIFESTIMAGE}:${META_TAG}
|
|
||||||
docker manifest push --purge ${MANIFESTIMAGE}:${EXT_RELEASE_TAG}
|
|
||||||
if [ -n "${SEMVER}" ]; then
|
|
||||||
docker manifest push --purge ${MANIFESTIMAGE}:${SEMVER}
|
|
||||||
fi
|
|
||||||
done
|
|
||||||
'''
|
|
||||||
}
|
|
||||||
sh '''#! /bin/bash
|
|
||||||
for DELETEIMAGE in "${GITHUBIMAGE}" "${GITLABIMAGE}" "${QUAYIMAGE}" "${IMAGE}"; do
|
|
||||||
docker rmi \
|
|
||||||
${DELETEIMAGE}:amd64-${META_TAG} \
|
|
||||||
${DELETEIMAGE}:amd64-latest \
|
|
||||||
${DELETEIMAGE}:amd64-${EXT_RELEASE_TAG} \
|
|
||||||
${DELETEIMAGE}:arm32v7-${META_TAG} \
|
|
||||||
${DELETEIMAGE}:arm32v7-latest \
|
|
||||||
${DELETEIMAGE}:arm32v7-${EXT_RELEASE_TAG} \
|
|
||||||
${DELETEIMAGE}:arm64v8-${META_TAG} \
|
|
||||||
${DELETEIMAGE}:arm64v8-latest \
|
|
||||||
${DELETEIMAGE}:arm64v8-${EXT_RELEASE_TAG} || :
|
|
||||||
if [ -n "${SEMVER}" ]; then
|
|
||||||
docker rmi \
|
|
||||||
${DELETEIMAGE}:amd64-${SEMVER} \
|
|
||||||
${DELETEIMAGE}:arm32v7-${SEMVER} \
|
|
||||||
${DELETEIMAGE}:arm64v8-${SEMVER} || :
|
|
||||||
fi
|
|
||||||
done
|
|
||||||
docker rmi \
|
|
||||||
ghcr.io/linuxserver/lsiodev-buildcache:arm32v7-${COMMIT_SHA}-${BUILD_NUMBER} \
|
|
||||||
ghcr.io/linuxserver/lsiodev-buildcache:arm64v8-${COMMIT_SHA}-${BUILD_NUMBER} || :
|
|
||||||
'''
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
|
||||||
// If this is a public release tag it in the LS Github
|
|
||||||
stage('Github-Tag-Push-Release') {
|
|
||||||
when {
|
|
||||||
branch "master"
|
|
||||||
expression {
|
|
||||||
env.LS_RELEASE != env.EXT_RELEASE_CLEAN + '-ls' + env.LS_TAG_NUMBER
|
|
||||||
}
|
|
||||||
environment name: 'CHANGE_ID', value: ''
|
|
||||||
environment name: 'EXIT_STATUS', value: ''
|
|
||||||
}
|
|
||||||
steps {
|
|
||||||
echo "Pushing New tag for current commit ${META_TAG}"
|
|
||||||
sh '''curl -H "Authorization: token ${GITHUB_TOKEN}" -X POST https://api.github.com/repos/${LS_USER}/${LS_REPO}/git/tags \
|
|
||||||
-d '{"tag":"'${META_TAG}'",\
|
|
||||||
"object": "'${COMMIT_SHA}'",\
|
|
||||||
"message": "Tagging Release '${EXT_RELEASE_CLEAN}'-ls'${LS_TAG_NUMBER}' to master",\
|
|
||||||
"type": "commit",\
|
|
||||||
"tagger": {"name": "LinuxServer Jenkins","email": "jenkins@linuxserver.io","date": "'${GITHUB_DATE}'"}}' '''
|
|
||||||
echo "Pushing New release for Tag"
|
|
||||||
sh '''#! /bin/bash
|
|
||||||
curl -H "Authorization: token ${GITHUB_TOKEN}" -s https://api.github.com/repos/${EXT_USER}/${EXT_REPO}/releases/latest | jq '. |.body' | sed 's:^.\\(.*\\).$:\\1:' > releasebody.json
|
|
||||||
echo '{"tag_name":"'${META_TAG}'",\
|
|
||||||
"target_commitish": "master",\
|
|
||||||
"name": "'${META_TAG}'",\
|
|
||||||
"body": "**LinuxServer Changes:**\\n\\n'${LS_RELEASE_NOTES}'\\n\\n**'${EXT_REPO}' Changes:**\\n\\n' > start
|
|
||||||
printf '","draft": false,"prerelease": false}' >> releasebody.json
|
|
||||||
paste -d'\\0' start releasebody.json > releasebody.json.done
|
|
||||||
curl -H "Authorization: token ${GITHUB_TOKEN}" -X POST https://api.github.com/repos/${LS_USER}/${LS_REPO}/releases -d @releasebody.json.done'''
|
|
||||||
}
|
|
||||||
}
|
|
||||||
// Use helper container to sync the current README on master to the dockerhub endpoint
|
|
||||||
stage('Sync-README') {
|
|
||||||
when {
|
|
||||||
environment name: 'CHANGE_ID', value: ''
|
|
||||||
environment name: 'EXIT_STATUS', value: ''
|
|
||||||
}
|
|
||||||
steps {
|
|
||||||
withCredentials([
|
|
||||||
[
|
|
||||||
$class: 'UsernamePasswordMultiBinding',
|
|
||||||
credentialsId: '3f9ba4d5-100d-45b0-a3c4-633fd6061207',
|
|
||||||
usernameVariable: 'DOCKERUSER',
|
|
||||||
passwordVariable: 'DOCKERPASS'
|
|
||||||
]
|
|
||||||
]) {
|
|
||||||
sh '''#! /bin/bash
|
|
||||||
set -e
|
|
||||||
TEMPDIR=$(mktemp -d)
|
|
||||||
docker pull ghcr.io/linuxserver/jenkins-builder:latest
|
|
||||||
docker run --rm -e CONTAINER_NAME=${CONTAINER_NAME} -e GITHUB_BRANCH="${BRANCH_NAME}" -v ${TEMPDIR}:/ansible/jenkins ghcr.io/linuxserver/jenkins-builder:latest
|
|
||||||
docker pull ghcr.io/linuxserver/readme-sync
|
|
||||||
docker run --rm=true \
|
|
||||||
-e DOCKERHUB_USERNAME=$DOCKERUSER \
|
|
||||||
-e DOCKERHUB_PASSWORD=$DOCKERPASS \
|
|
||||||
-e GIT_REPOSITORY=${LS_USER}/${LS_REPO} \
|
|
||||||
-e DOCKER_REPOSITORY=${IMAGE} \
|
|
||||||
-e GIT_BRANCH=master \
|
|
||||||
-v ${TEMPDIR}/docker-${CONTAINER_NAME}:/mnt \
|
|
||||||
ghcr.io/linuxserver/readme-sync bash -c 'node sync'
|
|
||||||
rm -Rf ${TEMPDIR} '''
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
|
||||||
// If this is a Pull request send the CI link as a comment on it
|
|
||||||
stage('Pull Request Comment') {
|
|
||||||
when {
|
|
||||||
not {environment name: 'CHANGE_ID', value: ''}
|
|
||||||
environment name: 'CI', value: 'true'
|
|
||||||
environment name: 'EXIT_STATUS', value: ''
|
|
||||||
}
|
|
||||||
steps {
|
|
||||||
sh '''curl -H "Authorization: token ${GITHUB_TOKEN}" -X POST https://api.github.com/repos/${LS_USER}/${LS_REPO}/issues/${PULL_REQUEST}/comments \
|
|
||||||
-d '{"body": "I am a bot, here are the test results for this PR: \\n'${CI_URL}' \\n'${SHELLCHECK_URL}'"}' '''
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
|
||||||
/* ######################
|
|
||||||
Send status to Discord
|
|
||||||
###################### */
|
|
||||||
post {
|
|
||||||
always {
|
|
||||||
script{
|
|
||||||
if (env.EXIT_STATUS == "ABORTED"){
|
|
||||||
sh 'echo "build aborted"'
|
|
||||||
}
|
|
||||||
else if (currentBuild.currentResult == "SUCCESS"){
|
|
||||||
sh ''' curl -X POST -H "Content-Type: application/json" --data '{"avatar_url": "https://raw.githubusercontent.com/linuxserver/docker-templates/master/linuxserver.io/img/jenkins-avatar.png","embeds": [{"color": 1681177,\
|
|
||||||
"description": "**Build:** '${BUILD_NUMBER}'\\n**CI Results:** '${CI_URL}'\\n**ShellCheck Results:** '${SHELLCHECK_URL}'\\n**Status:** Success\\n**Job:** '${RUN_DISPLAY_URL}'\\n**Change:** '${CODE_URL}'\\n**External Release:**: '${RELEASE_LINK}'\\n**DockerHub:** '${DOCKERHUB_LINK}'\\n"}],\
|
|
||||||
"username": "Jenkins"}' ${BUILDS_DISCORD} '''
|
|
||||||
}
|
|
||||||
else {
|
|
||||||
sh ''' curl -X POST -H "Content-Type: application/json" --data '{"avatar_url": "https://raw.githubusercontent.com/linuxserver/docker-templates/master/linuxserver.io/img/jenkins-avatar.png","embeds": [{"color": 16711680,\
|
|
||||||
"description": "**Build:** '${BUILD_NUMBER}'\\n**CI Results:** '${CI_URL}'\\n**ShellCheck Results:** '${SHELLCHECK_URL}'\\n**Status:** failure\\n**Job:** '${RUN_DISPLAY_URL}'\\n**Change:** '${CODE_URL}'\\n**External Release:**: '${RELEASE_LINK}'\\n**DockerHub:** '${DOCKERHUB_LINK}'\\n"}],\
|
|
||||||
"username": "Jenkins"}' ${BUILDS_DISCORD} '''
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
|
||||||
cleanup {
|
|
||||||
cleanWs()
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
|
||||||
213
README.md
213
README.md
@ -1,10 +1,9 @@
|
|||||||
<!-- DO NOT EDIT THIS FILE MANUALLY -->
|
<!-- DO NOT EDIT THIS FILE MANUALLY -->
|
||||||
<!-- Please read the https://github.com/linuxserver/docker-emulatorjs/blob/master/.github/CONTRIBUTING.md -->
|
<!-- Please read https://github.com/linuxserver/docker-emulatorjs/blob/master/.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://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.")
|
||||||
@ -21,15 +20,24 @@ 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.
|
* [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
|
||||||
|
|
||||||
|
# DEPRECATION NOTICE
|
||||||
|
This image is deprecated. We will not offer support for this image and it will not be updated.
|
||||||
|
|
||||||
|
|
||||||
|
Please consider these alternatives:
|
||||||
|
https://github.com/gaseous-project/gaseous-server
|
||||||
|
https://github.com/rommapp/romm/
|
||||||
|
https://github.com/webrcade/webrcade
|
||||||
|
|
||||||
# [linuxserver/emulatorjs](https://github.com/linuxserver/docker-emulatorjs)
|
# [linuxserver/emulatorjs](https://github.com/linuxserver/docker-emulatorjs)
|
||||||
|
|
||||||
[](https://scarf.sh/gateway/linuxserver-ci/docker/linuxserver%2Femulatorjs)
|
[](https://scarf.sh)
|
||||||
[](https://github.com/linuxserver/docker-emulatorjs)
|
[](https://github.com/linuxserver/docker-emulatorjs)
|
||||||
[](https://github.com/linuxserver/docker-emulatorjs/releases)
|
[](https://github.com/linuxserver/docker-emulatorjs/releases)
|
||||||
[](https://github.com/linuxserver/docker-emulatorjs/packages)
|
[](https://github.com/linuxserver/docker-emulatorjs/packages)
|
||||||
@ -46,7 +54,7 @@ Find us at:
|
|||||||
|
|
||||||
## 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/emulatorjs:latest` should retrieve the correct image for your arch, but you can also pull specific arch images via tags.
|
Simply pulling `lscr.io/linuxserver/emulatorjs:latest` should retrieve the correct image for your arch, but you can also pull specific arch images via tags.
|
||||||
|
|
||||||
@ -56,7 +64,7 @@ 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\> |
|
| armhf | ❌ | |
|
||||||
|
|
||||||
## Application Setup
|
## Application Setup
|
||||||
|
|
||||||
@ -66,23 +74,21 @@ The Backend can be accessed at:
|
|||||||
|
|
||||||
The first thing you will need to do is click to download the default art/configs from this interface, this will setup a skeleton directory in your `/data` mount. From there add roms to the respective `roms` directories and follow the on screen instructions to add them to your web frontend running on port 80.
|
The first thing you will need to do is click to download the default art/configs from this interface, this will setup a skeleton directory in your `/data` mount. From there add roms to the respective `roms` directories and follow the on screen instructions to add them to your web frontend running on port 80.
|
||||||
|
|
||||||
The frontend application has been initially optimized around being used with a standard gamepad (more specifically for modern Xbox consoles that have chromium based Edge browsers). The navigation revolves around the up/down/left/right keys to browse the menus and launch games.
|
**I understand there may be some confusion as to project naming, but when this project (linuxserver/emulatorjs) started it was meant to be a simple frontend for self hosting folks to use the at the time deobfuscated code of [https://www.emulatorjs.com/](https://www.emulatorjs.com/) that [ethanaobrien](https://github.com/ethanaobrien) was working on. Since then [EmulatorJS](https://github.com/EmulatorJS/EmulatorJS) has evolved into it's own amazing project based on [Libretro](https://github.com/libretro) cores that have been highly optimized to function for web. This project mostly contains custom built libretro cores found [here](https://github.com/linuxserver/libretro-cores). So in general despite the naming of this project and the logo this is just a docker container with a web based backend for generating a useable self hosted emulation website and is in no way affiliated with [EmulatorJS](https://github.com/EmulatorJS/EmulatorJS).**
|
||||||
Mobile browsers will function, just keep in mind compatibility will be reduced especially for CD based games.
|
|
||||||
|
|
||||||
**It is important to note that some of the current emulators used for this frontend are obfuscated code, efforts are being made to [reverse engineer it](https://github.com/ethanaobrien/emulatorjs/) but you should know it can potentially reach out to third party services if you manually enable features like netplay (this should never happen in a stock setup). The point of this message is that on top of the de-obfuscation effort there is also effort to stop using binary blobs and shift to built from source libretro emscripten blobs, for now this web based emulation stack is the best for useability and compatibility. We are in the process to transitioning to libretro cores for emulators, currently 27/30 emulators have been replaced.**
|
**This container (outside of the profile functionality) only generates a static set of files that can be hosted on any web provider even object storage. Everything runs in the client's browser and there are no dependencies on this container. To extract/copy this website it is at the path `/emulatorjs/frontend` inside the container. If you are happy with the catalouge you have created and no longer want to run stuff like the IPFS backend or want to upload these files to some other hosting provider you can simply copy the contents of that directory and kill off this container. This container can also be started without IPFS once you collection is set using the environment variable `-e DISABLE_IPFS=true`.**
|
||||||
|
|
||||||
**For Xbox users please click the select button a couple times after launching a game to ensure the B button does not trigger a "back" action in the browser. (official name "view button" it is the two small squares) Exiting the controller mode and back to browser controls can be triggered by holding the start button for 3 seconds. (official name "menu button" the three lines) You will be unable to use features like save states and modify controller layouts on the emulatorjs based emulators currently as I have not determined a methodology of re-entering controller mode once you exit it. All normal game saves will function given you exit the game play screen cleanly using the B button for back this includes multi disc games for psx. Your game saves are stored in browser storage by hostname so if you make any changes to your local hosted setup (port or IP) the saves will not follow with it. For libretro based emulators you can use the button combination start+select+L+R to access the libretro menu and change settings/save or load/etc.**
|
### Read Only Rom Mounts
|
||||||
|
|
||||||
**We know about most of the oddities like crackling sound for some emulators, rendering issues, and games unreliably auto launching to fullscreen. In general full CD games on the Xbox web browser do not seem to work due to their size if you have a chd/pbp less than 450 megs it will run. Edge on Xbox has some kind of undocumented ram limitation of about a gigabyte. Until all emulators are transitioned to libretro cores the oddities of using self hosted EmulatorJS will not be something that can or should be solved using hacky workarounds interacting with obfuscated code. Just keep in mind these are full blown machine emulators running in Javascript in a browser, do not expect bare metal performance.**
|
**Mounting in existing rom directories Read Only can be achieved by using a special root path `/roms`, For example for NES:**
|
||||||
|
|
||||||
Mounting in existing rom directories can be achieved by pointing to the default folder structure, IE lets say you would like to mount your NES library:
|
`-v /path/to/nes/roms:/roms/nes:ro`
|
||||||
|
|
||||||
`-v /path/to/nes/roms:/data/nes/roms`
|
The folder names for systems are:
|
||||||
|
|
||||||
The folder names are:
|
|
||||||
* 3do
|
* 3do
|
||||||
* arcade
|
* arcade
|
||||||
* atari2600
|
* atari2600
|
||||||
|
* atari5200
|
||||||
* atari7800
|
* atari7800
|
||||||
* colecovision
|
* colecovision
|
||||||
* doom
|
* doom
|
||||||
@ -111,15 +117,35 @@ The folder names are:
|
|||||||
* vectrex
|
* vectrex
|
||||||
* ws
|
* ws
|
||||||
|
|
||||||
|
### Compatible and Tested Browsers
|
||||||
|
|
||||||
|
**Chromium Based Browsers**- This is the golden standard whether desktop or on mobile (Android) Chrome/Chromium/Brave/Edge should always be used. They have the best performance when it comes to WebAssembly.
|
||||||
|
|
||||||
|
**Firefox**- This will work (at reduced performance though) without tested controller support.
|
||||||
|
|
||||||
|
**Safari iOS**- Safari performs well and has controller support though in recent updates the amount of ram available to a single tab (~265MB) makes it impossible to run n64 emulation or anything CD based. Do not use [WKWebView](https://developer.apple.com/documentation/webkit/wkwebview) applications like Chrome or Firefox on iOS they will not be detected properly in the client software. Your best bet in iOS is to add the web page to your home screen from Safari and launch from there to get a full screen interface.
|
||||||
|
|
||||||
|
**Edge Xbox Series X/S**- This also performs well and was the basis of this project though recent console updates have knocked the ram available to a single tab from 1GB to 128MB making it impossible to run CD based games or n64.
|
||||||
|
|
||||||
|
### Navigation Basics
|
||||||
|
|
||||||
|
**Retroarch Menu**- The Retroarch menu can be accessed using F1 on keyboard, start/select/R1/L1 at the same time on controller, or pressing the button in the top left in touch mode.
|
||||||
|
|
||||||
|
**Fast Scrolling**- Items in the menu can be scrolled by letter by using PgUp/PgDn on the keyboard or the R1/L1 buttons on controller. In touch mode scrolling can be sped up by touching and dragging (while holding) either up or down.
|
||||||
|
|
||||||
|
**For Xbox users please click the select button a couple times after launching a game to ensure the B button does not trigger a "back" action in the browser. (official name "view button" it is the two small squares) Exiting the controller mode and back to browser controls can be triggered by holding the start button for 3 seconds. (official name "menu button" the three lines)**
|
||||||
|
|
||||||
## 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 flaged 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:
|
||||||
emulatorjs:
|
emulatorjs:
|
||||||
image: lscr.io/linuxserver/emulatorjs:latest
|
image: lscr.io/linuxserver/emulatorjs:latest
|
||||||
@ -155,17 +181,16 @@ docker run -d \
|
|||||||
-v /path/to/data:/data \
|
-v /path/to/data:/data \
|
||||||
--restart unless-stopped \
|
--restart unless-stopped \
|
||||||
lscr.io/linuxserver/emulatorjs:latest
|
lscr.io/linuxserver/emulatorjs:latest
|
||||||
|
|
||||||
```
|
```
|
||||||
|
|
||||||
## 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 3000` | Rom/artwork management interface, used to generate/manage config files and download artwork |
|
| `-p 3000:3000` | Rom/artwork management interface, used to generate/manage config files and download artwork |
|
||||||
| `-p 80` | Emulation frontend containing static web files used to browse and launch games |
|
| `-p 80:80` | Emulation frontend containing static web files used to browse and launch games |
|
||||||
| `-p 4001` | IPFS peering port, if you want to participate in the P2P network to distribute frontend artwork please forward this to the Internet |
|
| `-p 4001` | IPFS peering port, if you want to participate in the P2P network to distribute frontend artwork please forward this to the Internet |
|
||||||
| `-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 |
|
||||||
@ -181,10 +206,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
|
||||||
|
|
||||||
@ -193,15 +218,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
|
||||||
@ -212,53 +242,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 emulatorjs /bin/bash`
|
* Shell access whilst the container is running:
|
||||||
* To monitor the logs of the container in realtime: `docker logs -f emulatorjs`
|
|
||||||
* container version number
|
```bash
|
||||||
* `docker inspect -f '{{ index .Config.Labels "build_version" }}' emulatorjs`
|
docker exec -it emulatorjs /bin/bash
|
||||||
* image version number
|
```
|
||||||
* `docker inspect -f '{{ index .Config.Labels "build_version" }}' lscr.io/linuxserver/emulatorjs:latest`
|
|
||||||
|
* To monitor the logs of the container in realtime:
|
||||||
|
|
||||||
|
```bash
|
||||||
|
docker logs -f emulatorjs
|
||||||
|
```
|
||||||
|
|
||||||
|
* Container version number:
|
||||||
|
|
||||||
|
```bash
|
||||||
|
docker inspect -f '{{ index .Config.Labels "build_version" }}' emulatorjs
|
||||||
|
```
|
||||||
|
|
||||||
|
* Image version number:
|
||||||
|
|
||||||
|
```bash
|
||||||
|
docker inspect -f '{{ index .Config.Labels "build_version" }}' lscr.io/linuxserver/emulatorjs:latest
|
||||||
|
```
|
||||||
|
|
||||||
## 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 emulatorjs`
|
* All images:
|
||||||
* Let compose update all containers as necessary: `docker-compose up -d`
|
|
||||||
* or update a single container: `docker-compose up -d emulatorjs`
|
```bash
|
||||||
* You can also remove the old dangling images: `docker image prune`
|
docker-compose pull
|
||||||
|
```
|
||||||
|
|
||||||
|
* Single image:
|
||||||
|
|
||||||
|
```bash
|
||||||
|
docker-compose pull emulatorjs
|
||||||
|
```
|
||||||
|
|
||||||
|
* Update containers:
|
||||||
|
* All containers:
|
||||||
|
|
||||||
|
```bash
|
||||||
|
docker-compose up -d
|
||||||
|
```
|
||||||
|
|
||||||
|
* Single container:
|
||||||
|
|
||||||
|
```bash
|
||||||
|
docker-compose up -d emulatorjs
|
||||||
|
```
|
||||||
|
|
||||||
|
* 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/emulatorjs:latest`
|
* Update the image:
|
||||||
* Stop the running container: `docker stop emulatorjs`
|
|
||||||
* Delete the container: `docker rm emulatorjs`
|
```bash
|
||||||
|
docker pull lscr.io/linuxserver/emulatorjs:latest
|
||||||
|
```
|
||||||
|
|
||||||
|
* Stop the running container:
|
||||||
|
|
||||||
|
```bash
|
||||||
|
docker stop emulatorjs
|
||||||
|
```
|
||||||
|
|
||||||
|
* Delete the container:
|
||||||
|
|
||||||
|
```bash
|
||||||
|
docker rm emulatorjs
|
||||||
|
```
|
||||||
|
|
||||||
* 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 emulatorjs
|
|
||||||
```
|
|
||||||
|
|
||||||
* 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
|
||||||
|
|
||||||
@ -273,16 +351,27 @@ docker build \
|
|||||||
-t lscr.io/linuxserver/emulatorjs:latest .
|
-t lscr.io/linuxserver/emulatorjs: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`.
|
||||||
|
|
||||||
## Versions
|
## Versions
|
||||||
|
|
||||||
|
* **28.01.24:** - Skip IPFS config if DISABLE_IPFS is set as env variable.
|
||||||
|
* **27.01.24:** - Add atari5200 support.
|
||||||
|
* **24.01.24:** - Pin node back on aarch64 as well for compatibility.
|
||||||
|
* **23.01.24:** - Add logic to symlink out RO rom directories to support upgrades.
|
||||||
|
* **14.01.24:** - Update remaining cores for melonds and yabause threaded to fix audio issues.
|
||||||
|
* **11.01.24:** - Use Node 16 on x86 image to restore metadata uploads in backend, update psx core to current.
|
||||||
|
* **07.01.24:** - Update to use new Mupen64 plus core by default.
|
||||||
|
* **06.01.24:** - Update many emulators to fix audio issues and use latest codebases.
|
||||||
|
* **29.12.23:** - Rebase to Alpine 3.19, add option to launch without IPFS.
|
||||||
|
* **09.08.23:** - Rebase to Alpine 3.18, migrate to s6v3.
|
||||||
|
* **06.07.23:** - Deprecate armhf. As announced [here](https://www.linuxserver.io/blog/a-farewell-to-arm-hf)
|
||||||
* **24.11.22:** - Update IPFS links for chdman.
|
* **24.11.22:** - Update IPFS links for chdman.
|
||||||
* **04.04.22:** - Ingest pre-built chdman bins during build time.
|
* **04.04.22:** - Ingest pre-built chdman bins during build time.
|
||||||
* **23.02.22:** - Update ingestion point for emulatorjs bins.
|
* **23.02.22:** - Update ingestion point for emulatorjs bins.
|
||||||
|
|||||||
@ -6,6 +6,7 @@ external_type: github_stable
|
|||||||
release_type: stable
|
release_type: stable
|
||||||
release_tag: latest
|
release_tag: latest
|
||||||
ls_branch: master
|
ls_branch: master
|
||||||
|
build_armhf: false
|
||||||
repo_vars:
|
repo_vars:
|
||||||
- EXT_GIT_BRANCH = 'master'
|
- EXT_GIT_BRANCH = 'master'
|
||||||
- EXT_USER = 'linuxserver'
|
- EXT_USER = 'linuxserver'
|
||||||
|
|||||||
3115
package_versions.txt
3115
package_versions.txt
File diff suppressed because it is too large
Load Diff
164
readme-vars.yml
164
readme-vars.yml
@ -2,103 +2,115 @@
|
|||||||
|
|
||||||
# project information
|
# project information
|
||||||
project_name: emulatorjs
|
project_name: emulatorjs
|
||||||
|
project_deprecation_status: true
|
||||||
|
project_deprecation_message: "Please consider these alternatives: \nhttps://github.com/gaseous-project/gaseous-server\nhttps://github.com/rommapp/romm/\nhttps://github.com/webrcade/webrcade\n"
|
||||||
project_url: "https://github.com/linuxserver/emulatorjs"
|
project_url: "https://github.com/linuxserver/emulatorjs"
|
||||||
project_logo: "https://raw.githubusercontent.com/linuxserver/docker-templates/master/linuxserver.io/img/emulatorjs-logo.png"
|
project_logo: "https://raw.githubusercontent.com/linuxserver/docker-templates/master/linuxserver.io/img/emulatorjs-logo.png"
|
||||||
project_blurb: |
|
project_blurb: |
|
||||||
[{{ project_name|capitalize }}]({{ project_url }}) - In browser web based emulation portable to nearly any device for many retro consoles. A mix of emulators is used between Libretro and EmulatorJS.
|
[{{ project_name|capitalize }}]({{ project_url }}) - In browser web based emulation portable to nearly any device for many retro consoles. A mix of emulators is used between Libretro and EmulatorJS.
|
||||||
project_lsio_github_repo_url: "https://github.com/linuxserver/docker-{{ project_name }}"
|
project_lsio_github_repo_url: "https://github.com/linuxserver/docker-{{ project_name }}"
|
||||||
|
project_categories: "Games"
|
||||||
# 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"}
|
|
||||||
|
|
||||||
# container parameters
|
# container parameters
|
||||||
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/config", desc: "Path to store user profiles" }
|
- {vol_path: "/config", vol_host_path: "/path/to/config", desc: "Path to store user profiles"}
|
||||||
- { vol_path: "/data", vol_host_path: "/path/to/data", desc: "Path to store roms/artwork" }
|
- {vol_path: "/data", vol_host_path: "/path/to/data", desc: "Path to store roms/artwork"}
|
||||||
param_usage_include_ports: true
|
param_usage_include_ports: true
|
||||||
param_ports:
|
param_ports:
|
||||||
- { external_port: "3000", internal_port: "3000", port_desc: "Rom/artwork management interface, used to generate/manage config files and download artwork" }
|
- {external_port: "3000", internal_port: "3000", port_desc: "Rom/artwork management interface, used to generate/manage config files and download artwork"}
|
||||||
- { external_port: "80", internal_port: "80", port_desc: "Emulation frontend containing static web files used to browse and launch games" }
|
- {external_port: "80", internal_port: "80", port_desc: "Emulation frontend containing static web files used to browse and launch games"}
|
||||||
param_usage_include_env: true
|
param_usage_include_env: true
|
||||||
param_env_vars:
|
param_env_vars:
|
||||||
- { env_var: "TZ", env_value: "Europe/London", desc: "Specify a timezone to use EG Europe/London"}
|
- {env_var: "TZ", env_value: "Europe/London", desc: "Specify a timezone to use EG Europe/London"}
|
||||||
# optional variables
|
# optional variables
|
||||||
opt_param_usage_include_ports: true
|
opt_param_usage_include_ports: true
|
||||||
opt_param_ports:
|
opt_param_ports:
|
||||||
- { external_port: "4001", internal_port: "4001", port_desc: "IPFS peering port, if you want to participate in the P2P network to distribute frontend artwork please forward this to the Internet" }
|
- {external_port: "4001", internal_port: "4001", port_desc: "IPFS peering port, if you want to participate in the P2P network to distribute frontend artwork please forward this to the Internet"}
|
||||||
opt_param_usage_include_env: true
|
opt_param_usage_include_env: true
|
||||||
opt_param_env_vars:
|
opt_param_env_vars:
|
||||||
- { env_var: "SUBFOLDER", env_value: "/", desc: "Specify a subfolder for reverse proxies IE '/FOLDER/'"}
|
- {env_var: "SUBFOLDER", env_value: "/", desc: "Specify a subfolder for reverse proxies IE '/FOLDER/'"}
|
||||||
|
|
||||||
# application setup block
|
# application setup block
|
||||||
app_setup_block_enabled: true
|
app_setup_block_enabled: true
|
||||||
app_setup_block: |
|
app_setup_block: "The Backend can be accessed at:\n\n* http://yourhost:3000/\n\nThe first thing you will need to do is click to download the default art/configs from this interface, this will setup a skeleton directory in your `/data` mount. From there add roms to the respective `roms` directories and follow the on screen instructions to add them to your web frontend running on port 80.\n\n**I understand there may be some confusion as to project naming, but when this project (linuxserver/emulatorjs) started it was meant to be a simple frontend for self hosting folks to use the at the time deobfuscated code of [https://www.emulatorjs.com/](https://www.emulatorjs.com/) that [ethanaobrien](https://github.com/ethanaobrien) was working on. Since then [EmulatorJS](https://github.com/EmulatorJS/EmulatorJS) has evolved into it's own amazing project based on [Libretro](https://github.com/libretro) cores that have been highly optimized to function for web. This project mostly contains custom built libretro cores found [here](https://github.com/linuxserver/libretro-cores). So in general despite the naming of this project and the logo this is just a docker container with a web based backend for generating a useable self hosted emulation website and is in no way affiliated with [EmulatorJS](https://github.com/EmulatorJS/EmulatorJS).**\n\n**This container (outside of the profile functionality) only generates a static set of files that can be hosted on any web provider even object storage. Everything runs in the client's browser and there are no dependencies on this container. To extract/copy this website it is at the path `/emulatorjs/frontend` inside the container. If you are happy with the catalouge you have created and no longer want to run stuff like the IPFS backend or want to upload these files to some other hosting provider you can simply copy the contents of that directory and kill off this container. This container can also be started without IPFS once you collection is set using the environment variable `-e DISABLE_IPFS=true`.**\n\n### Read Only Rom Mounts\n\n**Mounting in existing rom directories Read Only can be achieved by using a special root path `/roms`, For example for NES:**\n\n`-v /path/to/nes/roms:/roms/nes:ro`\n\nThe folder names for systems are:\n* 3do\n* arcade\n* atari2600\n* atari5200\n* atari7800\n* colecovision\n* doom\n* gb\n* gba\n* gbc\n* jaguar\n* lynx\n* msx\n* n64\n* nds\n* nes\n* ngp\n* odyssey2\n* pce\n* psx\n* sega32x\n* segaCD\n* segaGG\n* segaMD\n* segaMS\n* segaSaturn\n* segaSG\n* snes\n* vb\n* vectrex\n* ws\n\n### Compatible and Tested Browsers \n\n**Chromium Based Browsers**- This is the golden standard whether desktop or on mobile (Android) Chrome/Chromium/Brave/Edge should always be used. They have the best performance when it comes to WebAssembly.\n\n**Firefox**- This will work (at reduced performance though) without tested controller support.\n\n**Safari iOS**- Safari performs well and has controller support though in recent updates the amount of ram available to a single tab (~265MB) makes it impossible to run n64 emulation or anything CD based. Do not use [WKWebView](https://developer.apple.com/documentation/webkit/wkwebview) applications like Chrome or Firefox on iOS they will not be detected properly in the client software. Your best bet in iOS is to add the web page to your home screen from Safari and launch from there to get a full screen interface.\n\n**Edge Xbox Series X/S**- This also performs well and was the basis of this project though recent console updates have knocked the ram available to a single tab from 1GB to 128MB making it impossible to run CD based games or n64.\n\n### Navigation Basics\n\n**Retroarch Menu**- The Retroarch menu can be accessed using F1 on keyboard, start/select/R1/L1 at the same time on controller, or pressing the button in the top left in touch mode.\n\n**Fast Scrolling**- Items in the menu can be scrolled by letter by using PgUp/PgDn on the keyboard or the R1/L1 buttons on controller. In touch mode scrolling can be sped up by touching and dragging (while holding) either up or down.\n\n**For Xbox users please click the select button a couple times after launching a game to ensure the B button does not trigger a \"back\" action in the browser. (official name \"view button\" it is the two small squares) Exiting the controller mode and back to browser controls can be triggered by holding the start button for 3 seconds. (official name \"menu button\" the three lines)**\n"
|
||||||
The Backend can be accessed at:
|
# init diagram
|
||||||
|
init_diagram: |
|
||||||
* http://yourhost:3000/
|
"emulatorjs:latest": {
|
||||||
|
docker-mods
|
||||||
The first thing you will need to do is click to download the default art/configs from this interface, this will setup a skeleton directory in your `/data` mount. From there add roms to the respective `roms` directories and follow the on screen instructions to add them to your web frontend running on port 80.
|
base {
|
||||||
|
fix-attr +\nlegacy cont-init
|
||||||
The frontend application has been initially optimized around being used with a standard gamepad (more specifically for modern Xbox consoles that have chromium based Edge browsers). The navigation revolves around the up/down/left/right keys to browse the menus and launch games.
|
}
|
||||||
Mobile browsers will function, just keep in mind compatibility will be reduced especially for CD based games.
|
docker-mods -> base
|
||||||
|
legacy-services
|
||||||
**It is important to note that some of the current emulators used for this frontend are obfuscated code, efforts are being made to [reverse engineer it](https://github.com/ethanaobrien/emulatorjs/) but you should know it can potentially reach out to third party services if you manually enable features like netplay (this should never happen in a stock setup). The point of this message is that on top of the de-obfuscation effort there is also effort to stop using binary blobs and shift to built from source libretro emscripten blobs, for now this web based emulation stack is the best for useability and compatibility. We are in the process to transitioning to libretro cores for emulators, currently 27/30 emulators have been replaced.**
|
custom services
|
||||||
|
init-services -> legacy-services
|
||||||
**For Xbox users please click the select button a couple times after launching a game to ensure the B button does not trigger a "back" action in the browser. (official name "view button" it is the two small squares) Exiting the controller mode and back to browser controls can be triggered by holding the start button for 3 seconds. (official name "menu button" the three lines) You will be unable to use features like save states and modify controller layouts on the emulatorjs based emulators currently as I have not determined a methodology of re-entering controller mode once you exit it. All normal game saves will function given you exit the game play screen cleanly using the B button for back this includes multi disc games for psx. Your game saves are stored in browser storage by hostname so if you make any changes to your local hosted setup (port or IP) the saves will not follow with it. For libretro based emulators you can use the button combination start+select+L+R to access the libretro menu and change settings/save or load/etc.**
|
init-services -> custom services
|
||||||
|
custom services -> legacy-services
|
||||||
**We know about most of the oddities like crackling sound for some emulators, rendering issues, and games unreliably auto launching to fullscreen. In general full CD games on the Xbox web browser do not seem to work due to their size if you have a chd/pbp less than 450 megs it will run. Edge on Xbox has some kind of undocumented ram limitation of about a gigabyte. Until all emulators are transitioned to libretro cores the oddities of using self hosted EmulatorJS will not be something that can or should be solved using hacky workarounds interacting with obfuscated code. Just keep in mind these are full blown machine emulators running in Javascript in a browser, do not expect bare metal performance.**
|
legacy-services -> ci-service-check
|
||||||
|
init-migrations -> init-adduser
|
||||||
Mounting in existing rom directories can be achieved by pointing to the default folder structure, IE lets say you would like to mount your NES library:
|
init-os-end -> init-config
|
||||||
|
init-config -> init-config-end
|
||||||
`-v /path/to/nes/roms:/data/nes/roms`
|
init-emulatorjs-config -> init-config-end
|
||||||
|
init-os-end -> init-crontab-config
|
||||||
The folder names are:
|
init-mods-end -> init-custom-files
|
||||||
* 3do
|
init-config-end -> init-deprecate
|
||||||
* arcade
|
init-adduser -> init-device-perms
|
||||||
* atari2600
|
init-config -> init-emulatorjs-config
|
||||||
* atari7800
|
base -> init-envfile
|
||||||
* colecovision
|
base -> init-migrations
|
||||||
* doom
|
base -> init-mods
|
||||||
* gb
|
init-config-end -> init-mods
|
||||||
* gba
|
init-mods -> init-mods-end
|
||||||
* gbc
|
init-mods-package-install -> init-mods-end
|
||||||
* jaguar
|
init-mods -> init-mods-package-install
|
||||||
* lynx
|
base -> init-os-end
|
||||||
* msx
|
init-adduser -> init-os-end
|
||||||
* n64
|
init-device-perms -> init-os-end
|
||||||
* nds
|
init-envfile -> init-os-end
|
||||||
* nes
|
init-migrations -> init-os-end
|
||||||
* ngp
|
init-custom-files -> init-services
|
||||||
* odyssey2
|
init-deprecate -> init-services
|
||||||
* pce
|
init-mods-end -> init-services
|
||||||
* psx
|
init-services -> svc-backend
|
||||||
* sega32x
|
svc-backend -> legacy-services
|
||||||
* segaCD
|
init-services -> svc-cron
|
||||||
* segaGG
|
svc-cron -> legacy-services
|
||||||
* segaMD
|
init-services -> svc-ipfs
|
||||||
* segaMS
|
svc-ipfs -> legacy-services
|
||||||
* segaSaturn
|
init-services -> svc-nginx
|
||||||
* segaSG
|
svc-nginx -> legacy-services
|
||||||
* snes
|
init-services -> svc-profile
|
||||||
* vb
|
svc-profile -> legacy-services
|
||||||
* vectrex
|
}
|
||||||
* ws
|
Base Images: {
|
||||||
|
"baseimage-alpine:3.19"
|
||||||
|
}
|
||||||
|
"emulatorjs:latest" <- Base Images
|
||||||
# changelog
|
# changelog
|
||||||
changelogs:
|
changelogs:
|
||||||
- { date: "24.11.22:", desc: "Update IPFS links for chdman." }
|
- {date: "28.01.24:", desc: "Skip IPFS config if DISABLE_IPFS is set as env variable."}
|
||||||
- { date: "04.04.22:", desc: "Ingest pre-built chdman bins during build time." }
|
- {date: "27.01.24:", desc: "Add atari5200 support."}
|
||||||
- { date: "23.02.22:", desc: "Update ingestion point for emulatorjs bins." }
|
- {date: "24.01.24:", desc: "Pin node back on aarch64 as well for compatibility."}
|
||||||
- { date: "25.01.22:", desc: "Allow users to mount in existing rom directories." }
|
- {date: "23.01.24:", desc: "Add logic to symlink out RO rom directories to support upgrades."}
|
||||||
- { date: "14.01.22:", desc: "Add profile paths and rebase to Alpine 3.15." }
|
- {date: "14.01.24:", desc: "Update remaining cores for melonds and yabause threaded to fix audio issues."}
|
||||||
- { date: "04.01.22:", desc: "Add headers needed for Threaded emulators." }
|
- {date: "11.01.24:", desc: "Use Node 16 on x86 image to restore metadata uploads in backend, update psx core to current."}
|
||||||
- { date: "29.11.21:", desc: "Add wasm mime type to NGINX." }
|
- {date: "07.01.24:", desc: "Update to use new Mupen64 plus core by default."}
|
||||||
- { date: "26.11.21:", desc: "Configure IPFS in a lower power mode, use homebuilt blobs for emu cores." }
|
- {date: "06.01.24:", desc: "Update many emulators to fix audio issues and use latest codebases."}
|
||||||
- { date: "19.11.21:", desc: "Pin retroarch version." }
|
- {date: "29.12.23:", desc: "Rebase to Alpine 3.19, add option to launch without IPFS."}
|
||||||
- { date: "14.11.21:", desc: "Update default cores to ingest." }
|
- {date: "09.08.23:", desc: "Rebase to Alpine 3.18, migrate to s6v3."}
|
||||||
- { date: "23.10.21:", desc: "Initial release." }
|
- {date: "06.07.23:", desc: "Deprecate armhf. As announced [here](https://www.linuxserver.io/blog/a-farewell-to-arm-hf)"}
|
||||||
|
- {date: "24.11.22:", desc: "Update IPFS links for chdman."}
|
||||||
|
- {date: "04.04.22:", desc: "Ingest pre-built chdman bins during build time."}
|
||||||
|
- {date: "23.02.22:", desc: "Update ingestion point for emulatorjs bins."}
|
||||||
|
- {date: "25.01.22:", desc: "Allow users to mount in existing rom directories."}
|
||||||
|
- {date: "14.01.22:", desc: "Add profile paths and rebase to Alpine 3.15."}
|
||||||
|
- {date: "04.01.22:", desc: "Add headers needed for Threaded emulators."}
|
||||||
|
- {date: "29.11.21:", desc: "Add wasm mime type to NGINX."}
|
||||||
|
- {date: "26.11.21:", desc: "Configure IPFS in a lower power mode, use homebuilt blobs for emu cores."}
|
||||||
|
- {date: "19.11.21:", desc: "Pin retroarch version."}
|
||||||
|
- {date: "14.11.21:", desc: "Update default cores to ingest."}
|
||||||
|
- {date: "23.10.21:", desc: "Initial release."}
|
||||||
|
|||||||
@ -1,45 +0,0 @@
|
|||||||
#!/usr/bin/with-contenv bash
|
|
||||||
|
|
||||||
# permissions
|
|
||||||
chown abc:abc \
|
|
||||||
/data
|
|
||||||
|
|
||||||
# ipfs config
|
|
||||||
if [ ! -d "/data/.ipfs" ]; then
|
|
||||||
HOME=/data ipfs init --profile lowpower
|
|
||||||
chown -R abc:abc /data/.ipfs
|
|
||||||
fi
|
|
||||||
|
|
||||||
# link user data to frontend
|
|
||||||
if [ ! -L '/emulatorjs/frontend/user' ]; then
|
|
||||||
ln -s /data /emulatorjs/frontend/user
|
|
||||||
fi
|
|
||||||
|
|
||||||
# Default profile directory
|
|
||||||
if [ ! -d '/config/profile/default' ]; then
|
|
||||||
mkdir -p /config/profile/default
|
|
||||||
echo "input_menu_toggle_gamepad_combo = 3
|
|
||||||
system_directory = /home/web_user/retroarch/system/" > /config/profile/default/retroarch.cfg
|
|
||||||
chown -R abc:abc /config/profile
|
|
||||||
fi
|
|
||||||
if [ ! -f '/config/profile/profile.json' ]; then
|
|
||||||
echo '{}' > /config/profile/profile.json
|
|
||||||
chown -R abc:abc /config/profile
|
|
||||||
fi
|
|
||||||
|
|
||||||
# nginx mime types
|
|
||||||
cp /defaults/mime.types /etc/nginx/mime.types
|
|
||||||
|
|
||||||
# nginx body cache
|
|
||||||
chown -R abc:root /var/lib/nginx
|
|
||||||
|
|
||||||
# allow users to mount in rom dirs
|
|
||||||
DIRS='3do atari2600 atari7800 colecovision doom gba lynx n64 nes odyssey2 psx segaCD segaMD segaSaturn snes vb ws arcade atari5200 gb gbc jaguar msx nds ngp pce sega32x segaGG segaMS segaSG vectrex'
|
|
||||||
for DIR in ${DIRS}; do
|
|
||||||
if [ -d "/data/${DIR}" ]; then
|
|
||||||
chown abc:abc "/data/${DIR}"
|
|
||||||
fi
|
|
||||||
if [ -d "/data/${DIR}/roms" ]; then
|
|
||||||
chown abc:abc "/data/${DIR}/roms"
|
|
||||||
fi
|
|
||||||
done
|
|
||||||
21
root/etc/s6-overlay/s6-rc.d/init-deprecate/run
Executable file
21
root/etc/s6-overlay/s6-rc.d/init-deprecate/run
Executable file
@ -0,0 +1,21 @@
|
|||||||
|
#!/usr/bin/with-contenv bash
|
||||||
|
# shellcheck shell=bash
|
||||||
|
|
||||||
|
echo '
|
||||||
|
╔════════════════════════════════════════════════════╗
|
||||||
|
╠════════════════════════════════════════════════════╣
|
||||||
|
║ ║
|
||||||
|
║ This image is deprecated. ║
|
||||||
|
║ We will not offer support for this image ║
|
||||||
|
║ and it will not be updated. ║
|
||||||
|
║ ║
|
||||||
|
╠════════════════════════════════════════════════════╣
|
||||||
|
╚════════════════════════════════════════════════════╝
|
||||||
|
|
||||||
|
Please consider these alternatives:
|
||||||
|
https://github.com/gaseous-project/gaseous-server
|
||||||
|
https://github.com/rommapp/romm/
|
||||||
|
https://github.com/webrcade/webrcade
|
||||||
|
|
||||||
|
|
||||||
|
══════════════════════════════════════════════════════'
|
||||||
1
root/etc/s6-overlay/s6-rc.d/init-deprecate/type
Normal file
1
root/etc/s6-overlay/s6-rc.d/init-deprecate/type
Normal file
@ -0,0 +1 @@
|
|||||||
|
oneshot
|
||||||
0
root/etc/s6-overlay/s6-rc.d/init-deprecate/up
Normal file
0
root/etc/s6-overlay/s6-rc.d/init-deprecate/up
Normal file
55
root/etc/s6-overlay/s6-rc.d/init-emulatorjs-config/run
Executable file
55
root/etc/s6-overlay/s6-rc.d/init-emulatorjs-config/run
Executable file
@ -0,0 +1,55 @@
|
|||||||
|
#!/usr/bin/with-contenv bash
|
||||||
|
# shellcheck shell=bash
|
||||||
|
|
||||||
|
# permissions
|
||||||
|
lsiown abc:abc \
|
||||||
|
/data
|
||||||
|
|
||||||
|
# check if ipfs is disabled
|
||||||
|
if [ -z ${DISABLE_IPFS+x} ]; then
|
||||||
|
|
||||||
|
# ipfs migrate check on startup
|
||||||
|
if [[ -d "/data/.ipfs" ]]; then
|
||||||
|
echo "[ipfs-upgrade] Checking if fs-repo needs to be upgraded (this may take some time)"
|
||||||
|
HOME=/data s6-setuidgid abc /usr/bin/fs-repo-migrations -y -to 15
|
||||||
|
fi
|
||||||
|
|
||||||
|
# ipfs config
|
||||||
|
if [[ ! -d "/data/.ipfs" ]]; then
|
||||||
|
HOME=/data ipfs init --profile lowpower
|
||||||
|
lsiown -R abc:abc /data/.ipfs
|
||||||
|
fi
|
||||||
|
fi
|
||||||
|
|
||||||
|
# link user data to frontend
|
||||||
|
if [[ ! -L '/emulatorjs/frontend/user' ]]; then
|
||||||
|
ln -s /data /emulatorjs/frontend/user
|
||||||
|
fi
|
||||||
|
|
||||||
|
# Default profile directory
|
||||||
|
if [[ ! -d '/config/profile/default' ]]; then
|
||||||
|
mkdir -p /config/profile/default
|
||||||
|
echo "input_menu_toggle_gamepad_combo = 3
|
||||||
|
system_directory = /home/web_user/retroarch/system/" >/config/profile/default/retroarch.cfg
|
||||||
|
lsiown -R abc:abc /config/profile
|
||||||
|
fi
|
||||||
|
if [[ ! -f '/config/profile/profile.json' ]]; then
|
||||||
|
echo '{}' >/config/profile/profile.json
|
||||||
|
lsiown -R abc:abc /config/profile
|
||||||
|
fi
|
||||||
|
|
||||||
|
# nginx mime types
|
||||||
|
cp /defaults/mime.types /etc/nginx/mime.types
|
||||||
|
|
||||||
|
# nginx body cache
|
||||||
|
lsiown -R abc:root /var/lib/nginx
|
||||||
|
|
||||||
|
# allow users to mount in ro rom dirs
|
||||||
|
DIRS='3do atari2600 atari5200 atari7800 colecovision doom gba lynx n64 nes odyssey2 psx segaCD segaMD segaSaturn snes vb ws arcade atari5200 gb gbc jaguar msx nds ngp pce sega32x segaGG segaMS segaSG vectrex'
|
||||||
|
for DIR in ${DIRS}; do
|
||||||
|
if [[ -d "/roms/${DIR}" ]] && [[ ! -L "/data/${DIR}/roms" ]]; then
|
||||||
|
mkdir -p "/data/${DIR}"
|
||||||
|
ln -s "/roms/${DIR}" "/data/${DIR}/roms"
|
||||||
|
lsiown abc:abc "/data/${DIR}"
|
||||||
|
fi
|
||||||
|
done
|
||||||
1
root/etc/s6-overlay/s6-rc.d/init-emulatorjs-config/type
Normal file
1
root/etc/s6-overlay/s6-rc.d/init-emulatorjs-config/type
Normal file
@ -0,0 +1 @@
|
|||||||
|
oneshot
|
||||||
1
root/etc/s6-overlay/s6-rc.d/init-emulatorjs-config/up
Normal file
1
root/etc/s6-overlay/s6-rc.d/init-emulatorjs-config/up
Normal file
@ -0,0 +1 @@
|
|||||||
|
/etc/s6-overlay/s6-rc.d/init-emulatorjs-config/run
|
||||||
1
root/etc/s6-overlay/s6-rc.d/svc-backend/notification-fd
Normal file
1
root/etc/s6-overlay/s6-rc.d/svc-backend/notification-fd
Normal file
@ -0,0 +1 @@
|
|||||||
|
3
|
||||||
6
root/etc/s6-overlay/s6-rc.d/svc-backend/run
Executable file
6
root/etc/s6-overlay/s6-rc.d/svc-backend/run
Executable file
@ -0,0 +1,6 @@
|
|||||||
|
#!/usr/bin/with-contenv bash
|
||||||
|
# shellcheck shell=bash
|
||||||
|
|
||||||
|
HOME=/data exec \
|
||||||
|
s6-notifyoncheck -d -n 300 -w 1000 -c "nc -z localhost 3000" \
|
||||||
|
cd /emulatorjs s6-setuidgid abc node index.js
|
||||||
1
root/etc/s6-overlay/s6-rc.d/svc-backend/type
Normal file
1
root/etc/s6-overlay/s6-rc.d/svc-backend/type
Normal file
@ -0,0 +1 @@
|
|||||||
|
longrun
|
||||||
1
root/etc/s6-overlay/s6-rc.d/svc-ipfs/notification-fd
Normal file
1
root/etc/s6-overlay/s6-rc.d/svc-ipfs/notification-fd
Normal file
@ -0,0 +1 @@
|
|||||||
|
4
|
||||||
10
root/etc/s6-overlay/s6-rc.d/svc-ipfs/run
Executable file
10
root/etc/s6-overlay/s6-rc.d/svc-ipfs/run
Executable file
@ -0,0 +1,10 @@
|
|||||||
|
#!/usr/bin/with-contenv bash
|
||||||
|
# shellcheck shell=bash
|
||||||
|
|
||||||
|
if [ ! -z ${DISABLE_IPFS+x} ]; then
|
||||||
|
sleep infinity
|
||||||
|
fi
|
||||||
|
|
||||||
|
HOME=/data exec \
|
||||||
|
s6-notifyoncheck -d -n 300 -w 1000 -c "nc -z localhost 4001" \
|
||||||
|
s6-setuidgid abc ipfs daemon
|
||||||
1
root/etc/s6-overlay/s6-rc.d/svc-ipfs/type
Normal file
1
root/etc/s6-overlay/s6-rc.d/svc-ipfs/type
Normal file
@ -0,0 +1 @@
|
|||||||
|
longrun
|
||||||
1
root/etc/s6-overlay/s6-rc.d/svc-nginx/notification-fd
Normal file
1
root/etc/s6-overlay/s6-rc.d/svc-nginx/notification-fd
Normal file
@ -0,0 +1 @@
|
|||||||
|
5
|
||||||
10
root/etc/s6-overlay/s6-rc.d/svc-nginx/run
Executable file
10
root/etc/s6-overlay/s6-rc.d/svc-nginx/run
Executable file
@ -0,0 +1,10 @@
|
|||||||
|
#!/usr/bin/with-contenv bash
|
||||||
|
# shellcheck shell=bash
|
||||||
|
|
||||||
|
if pgrep -f "[n]ginx:" > /dev/null; then
|
||||||
|
pkill -ef [n]ginx:
|
||||||
|
fi
|
||||||
|
|
||||||
|
exec \
|
||||||
|
s6-notifyoncheck -d -n 300 -w 1000 -c "nc -z localhost 80" \
|
||||||
|
/usr/sbin/nginx -c /etc/nginx/nginx.conf
|
||||||
1
root/etc/s6-overlay/s6-rc.d/svc-nginx/type
Normal file
1
root/etc/s6-overlay/s6-rc.d/svc-nginx/type
Normal file
@ -0,0 +1 @@
|
|||||||
|
longrun
|
||||||
1
root/etc/s6-overlay/s6-rc.d/svc-profile/notification-fd
Normal file
1
root/etc/s6-overlay/s6-rc.d/svc-profile/notification-fd
Normal file
@ -0,0 +1 @@
|
|||||||
|
6
|
||||||
6
root/etc/s6-overlay/s6-rc.d/svc-profile/run
Executable file
6
root/etc/s6-overlay/s6-rc.d/svc-profile/run
Executable file
@ -0,0 +1,6 @@
|
|||||||
|
#!/usr/bin/with-contenv bash
|
||||||
|
# shellcheck shell=bash
|
||||||
|
|
||||||
|
HOME=/config exec \
|
||||||
|
s6-notifyoncheck -d -n 300 -w 1000 -c "nc -z localhost 3001" \
|
||||||
|
cd /emulatorjs s6-setuidgid abc node profile.js
|
||||||
1
root/etc/s6-overlay/s6-rc.d/svc-profile/type
Normal file
1
root/etc/s6-overlay/s6-rc.d/svc-profile/type
Normal file
@ -0,0 +1 @@
|
|||||||
|
longrun
|
||||||
@ -1,5 +0,0 @@
|
|||||||
#!/usr/bin/with-contenv bash
|
|
||||||
|
|
||||||
cd /emulatorjs || exit
|
|
||||||
HOME=/data exec \
|
|
||||||
s6-setuidgid abc node index.js
|
|
||||||
@ -1,4 +0,0 @@
|
|||||||
#!/usr/bin/with-contenv bash
|
|
||||||
|
|
||||||
HOME=/data exec \
|
|
||||||
s6-setuidgid abc ipfs daemon
|
|
||||||
@ -1,7 +0,0 @@
|
|||||||
#!/usr/bin/with-contenv bash
|
|
||||||
|
|
||||||
if pgrep -f "[n]ginx:" > /dev/null; then
|
|
||||||
pkill -ef [n]ginx:
|
|
||||||
fi
|
|
||||||
|
|
||||||
exec /usr/sbin/nginx -c /etc/nginx/nginx.conf
|
|
||||||
@ -1,5 +0,0 @@
|
|||||||
#!/usr/bin/with-contenv bash
|
|
||||||
|
|
||||||
cd /emulatorjs || exit
|
|
||||||
HOME=/config exec \
|
|
||||||
s6-setuidgid abc node profile.js
|
|
||||||
Loading…
x
Reference in New Issue
Block a user