versioned updates, init cleaned up

This commit is contained in:
aptalca
2022-02-11 13:30:05 -05:00
parent 2e3e95e194
commit eab09ae1b3
4 changed files with 65 additions and 29 deletions
+15 -4
View File
@@ -3,9 +3,9 @@ name: Build Image
on: [push, pull_request, workflow_dispatch]
env:
ENDPOINT: "linuxserver/mods" #don't modify
BASEIMAGE: "code-server" #replace
MODNAME: "julia" #replace
ENDPOINT: "linuxserver/mods"
BASEIMAGE: "code-server"
MODNAME: "julia"
jobs:
build:
@@ -15,14 +15,21 @@ jobs:
- name: Build image
run: |
docker build --no-cache -t ${{ github.sha }} .
# Set version
JULIA_VERSION=$(curl -sfX GET "https://api.github.com/repos/JuliaLang/julia/releases/latest" | jq -r '. | .tag_name' | sed 's|^v||')
echo "JULIA_VERSION=${JULIA_VERSION}" >> $GITHUB_ENV
docker build --no-cache --build-arg JULIA_VERSION="${JULIA_VERSION}" -t ${{ github.sha }} .
- name: Tag image
if: ${{ github.ref == format('refs/heads/{0}-{1}', env.BASEIMAGE, env.MODNAME) }}
run: |
docker tag ${{ github.sha }} ${ENDPOINT}:${BASEIMAGE}-${MODNAME}
docker tag ${{ github.sha }} ${ENDPOINT}:${BASEIMAGE}-${MODNAME}-${{ env.JULIA_VERSION }}
docker tag ${{ github.sha }} ${ENDPOINT}:${BASEIMAGE}-${MODNAME}-${{ env.JULIA_VERSION }}-${{ github.sha }}
docker tag ${{ github.sha }} ${ENDPOINT}:${BASEIMAGE}-${MODNAME}-${{ github.sha }}
docker tag ${{ github.sha }} ghcr.io/${ENDPOINT}:${BASEIMAGE}-${MODNAME}
docker tag ${{ github.sha }} ghcr.io/${ENDPOINT}:${BASEIMAGE}-${MODNAME}-${{ env.JULIA_VERSION }}
docker tag ${{ github.sha }} ghcr.io/${ENDPOINT}:${BASEIMAGE}-${MODNAME}-${{ env.JULIA_VERSION }}-${{ github.sha }}
docker tag ${{ github.sha }} ghcr.io/${ENDPOINT}:${BASEIMAGE}-${MODNAME}-${{ github.sha }}
- name: Credential check
@@ -47,6 +54,8 @@ jobs:
- name: Push tags to GitHub Container Registry
if: ${{ github.ref == format('refs/heads/{0}-{1}', env.BASEIMAGE, env.MODNAME) && env.CR_USER && env.CR_PAT }}
run: |
docker push ghcr.io/${ENDPOINT}:${BASEIMAGE}-${MODNAME}-${{ env.JULIA_VERSION }}
docker push ghcr.io/${ENDPOINT}:${BASEIMAGE}-${MODNAME}-${{ env.JULIA_VERSION }}-${{ github.sha }}
docker push ghcr.io/${ENDPOINT}:${BASEIMAGE}-${MODNAME}-${{ github.sha }}
docker push ghcr.io/${ENDPOINT}:${BASEIMAGE}-${MODNAME}
@@ -58,5 +67,7 @@ jobs:
- name: Push tags to DockerHub
if: ${{ github.ref == format('refs/heads/{0}-{1}', env.BASEIMAGE, env.MODNAME) && env.DOCKERUSER && env.DOCKERPASS }}
run: |
docker push ${ENDPOINT}:${BASEIMAGE}-${MODNAME}-${{ env.JULIA_VERSION }}
docker push ${ENDPOINT}:${BASEIMAGE}-${MODNAME}-${{ env.JULIA_VERSION }}-${{ github.sha }}
docker push ${ENDPOINT}:${BASEIMAGE}-${MODNAME}-${{ github.sha }}
docker push ${ENDPOINT}:${BASEIMAGE}-${MODNAME}
+33 -2
View File
@@ -1,6 +1,37 @@
FROM ghcr.io/linuxserver/baseimage-alpine:3.15 as buildstage
ARG JULIA_VERSION
RUN \
apk add --no-cache \
curl \
jq && \
if [ -z "${JULIA_VERSION}" ]; then \
JULIA_VERSION=$(curl -sX GET "https://api.github.com/repos/JuliaLang/julia/releases/latest" \
| jq -r '. | .tag_name' \
| sed 's|^v||'); \
fi && \
JULIA_MIN_VERSION=$(echo "${JULIA_VERSION}" | cut -d. -f 1,2) && \
mkdir -p /root-layer/julia-bins && \
echo "**** Downloading x86_64 binary ****" && \
curl -f --retry 3 --retry-connrefused \
"https://julialang-s3.julialang.org/bin/linux/x64/${JULIA_MIN_VERSION}/julia-${JULIA_VERSION}-linux-x86_64.tar.gz" -o \
"/root-layer/julia-bins/julia-x86_64.tar.gz" && \
echo "**** Downloading armv7l binary ****" && \
curl -f --retry 3 --retry-connrefused \
"https://julialang-s3.julialang.org/bin/linux/armv7l/${JULIA_MIN_VERSION}/julia-${JULIA_VERSION}-linux-armv7l.tar.gz" -o \
"/root-layer/julia-bins/julia-armv7l.tar.gz" && \
echo "**** Downloading aarch64 binary ****" && \
curl -f --retry 3 --retry-connrefused \
"https://julialang-s3.julialang.org/bin/linux/aarch64/${JULIA_MIN_VERSION}/julia-${JULIA_VERSION}-linux-aarch64.tar.gz" -o \
"/root-layer/julia-bins/julia-aarch64.tar.gz"
COPY root/ /root-layer/
# runtime stage
FROM scratch
LABEL maintainer="MateoPeri"
# copy local files
COPY root/ /
# Add files from buildstage
COPY --from=buildstage /root-layer/ /
+2
View File
@@ -5,3 +5,5 @@ This mod adds a Julia dev environment to code-server, to be installed/updated du
In code-server docker arguments, set an environment variable `DOCKER_MODS=linuxserver/mods:code-server-julia`
If adding multiple mods, enter them in an array separated by `|`, such as `DOCKER_MODS=linuxserver/mods:code-server-julia|linuxserver/mods:code-server-mod2`
By default, the latest stable version of Julia will be installed. If you'd like to install a different version, you can specify the version as a tag, from a list of published tags: https://hub.docker.com/r/linuxserver/mods/tags?page=1&name=code-server-julia (ie. `DOCKER_MODS=linuxserver/mods:code-server-julia-1.7.2`).
+15 -23
View File
@@ -1,30 +1,22 @@
#!/usr/bin/with-contenv bash
gh_latest() {
curl -s https://api.github.com/repos/$1/$2/releases/latest \
| grep "tag_name" \
| cut -d : -f 2,3 \
| tr -d '\"\ v,'
}
# replace these with specific versions if needed (i.e 1.7.2 for Julia)
JULIA_VERSION=$(gh_latest julialang julia)
# Julia
cd /home/root
curl -so julia.tar.gz https://julialang-s3.julialang.org/bin/linux/x64/`echo ${JULIA_VERSION} | cut -d. -f 1,2`/julia-${JULIA_VERSION}-linux-x86_64.tar.gz
tar fxz julia.tar.gz
rm -R julia.tar.gz
ln -s $(pwd)/julia-${JULIA_VERSION}/bin/julia /usr/local/bin/julia
if [ -d "/julia-bins" ]; then
echo "**** Installing/updating Julia ****"
ARCH=$(uname -m)
mkdir -p /julia
tar xf "/julia-bins/julia-${ARCH}.tar.gz" -C \
/julia --strip-components=1
rm -rf /usr/local/bin/julia
ln -s /julia/bin/julia /usr/local/bin/julia
chmod +x /julia/bin/julia
else
echo "**** Latest stable version of Julia already installed ****"
fi
echo "**** Installing vscode extensions julia, julia-formatter and better-toml ****"
# extensions
install-extension julia-vscode.julia-vscode
# latex-input
install-extension yellpika.latex-input
# vscode-format-context-menu
install-extension lacroixdavid1.vscode-format-context-menu
install-extension julialang.language-julia
# vscode-julia-formatter
install-extension singularitti.vscode-julia-formatter
# better-toml
install-extension bungcip.better-toml
install-extension bungcip.better-toml