Merge branch 'optional-forgejo-fed' into 'main'
Added optional support for installation of forge-fed branch See merge request domaindrivenarchitecture/c4k-forgejo!4merge-requests/5/merge
commit
a73ab9b683
@ -0,0 +1,28 @@
|
|||||||
|
#!/usr/bin/env bash
|
||||||
|
|
||||||
|
# set things
|
||||||
|
set -o nounset
|
||||||
|
set -o xtrace
|
||||||
|
set -o errexit
|
||||||
|
set -eo pipefail
|
||||||
|
|
||||||
|
# dirs
|
||||||
|
srcDir="/home/$USER/repo/c4k/c4k-forgejo/public/js/"
|
||||||
|
srcName="main.js"
|
||||||
|
targetDir="/home/$USER/repo/website/dda-io/content/templates/js/"
|
||||||
|
targetName="c4k-gitea.js"
|
||||||
|
|
||||||
|
echo "build test"
|
||||||
|
shadow-cljs compile test
|
||||||
|
|
||||||
|
echo "test"
|
||||||
|
node target/node-tests.js
|
||||||
|
|
||||||
|
echo "build frontend"
|
||||||
|
shadow-cljs compile frontend
|
||||||
|
|
||||||
|
echo "move and rename file"
|
||||||
|
cp $srcDir$srcName $targetDir$targetName
|
||||||
|
|
||||||
|
echo "run"
|
||||||
|
(cd $targetDir; lein ring server)
|
@ -1,22 +0,0 @@
|
|||||||
#!/usr/bin/env bash
|
|
||||||
|
|
||||||
# set things
|
|
||||||
set -o nounset
|
|
||||||
set -o xtrace
|
|
||||||
set -o errexit
|
|
||||||
set -eo pipefail
|
|
||||||
|
|
||||||
# dirs
|
|
||||||
srcDir="/home/$USER/"
|
|
||||||
srcName="main.js"
|
|
||||||
targetDir="/home/$USER/"
|
|
||||||
targetName="c4k-forgejo.js"
|
|
||||||
|
|
||||||
echo "build"
|
|
||||||
shadow-cljs compile frontend
|
|
||||||
|
|
||||||
echo "move and rename file"
|
|
||||||
cp $srcDir$srcName $targetDir$targetName
|
|
||||||
|
|
||||||
echo "build"
|
|
||||||
(cd $targetDir; lein ring server)
|
|
@ -0,0 +1,51 @@
|
|||||||
|
from os import environ
|
||||||
|
from pybuilder.core import task, init
|
||||||
|
from ddadevops import *
|
||||||
|
import logging
|
||||||
|
|
||||||
|
name = 'c4k-forgejo-fed'
|
||||||
|
MODULE = 'docker'
|
||||||
|
PROJECT_ROOT_PATH = '../..'
|
||||||
|
|
||||||
|
class MyBuild(DevopsDockerBuild):
|
||||||
|
pass
|
||||||
|
|
||||||
|
@init
|
||||||
|
def initialize(project):
|
||||||
|
project.build_depends_on('ddadevops>=0.15.5')
|
||||||
|
stage = 'prod'
|
||||||
|
dockerhub_user = environ.get('DOCKERHUB_USER')
|
||||||
|
if not dockerhub_user:
|
||||||
|
dockerhub_user = gopass_field_from_path('meissa/web/docker.com', 'login')
|
||||||
|
dockerhub_password = environ.get('DOCKERHUB_PASSWORD')
|
||||||
|
if not dockerhub_password:
|
||||||
|
dockerhub_password = gopass_password_from_path('meissa/web/docker.com')
|
||||||
|
tag = environ.get('CI_COMMIT_TAG')
|
||||||
|
if not tag:
|
||||||
|
tag = get_tag_from_latest_commit()
|
||||||
|
config = create_devops_docker_build_config(
|
||||||
|
stage, PROJECT_ROOT_PATH, MODULE, dockerhub_user, dockerhub_password, docker_publish_tag=tag)
|
||||||
|
build = MyBuild(project, config)
|
||||||
|
build.initialize_build_dir()
|
||||||
|
|
||||||
|
|
||||||
|
@task
|
||||||
|
def image(project):
|
||||||
|
build = get_devops_build(project)
|
||||||
|
build.image()
|
||||||
|
|
||||||
|
@task
|
||||||
|
def drun(project):
|
||||||
|
build = get_devops_build(project)
|
||||||
|
build.drun()
|
||||||
|
|
||||||
|
@task
|
||||||
|
def publish(project):
|
||||||
|
build = get_devops_build(project)
|
||||||
|
build.dockerhub_login()
|
||||||
|
build.dockerhub_publish()
|
||||||
|
|
||||||
|
@task
|
||||||
|
def test(project):
|
||||||
|
build = get_devops_build(project)
|
||||||
|
build.test()
|
@ -0,0 +1,74 @@
|
|||||||
|
#Build stage
|
||||||
|
FROM docker.io/library/golang:1.20.4-alpine3.18 AS build-env
|
||||||
|
|
||||||
|
ARG GOPROXY
|
||||||
|
ENV GOPROXY ${GOPROXY:-direct}
|
||||||
|
|
||||||
|
#ARG GITEA_VERSION
|
||||||
|
ARG TAGS="sqlite sqlite_unlock_notify"
|
||||||
|
ENV TAGS "bindata timetzdata $TAGS"
|
||||||
|
ARG CGO_EXTRA_CFLAGS
|
||||||
|
|
||||||
|
ENV FORGEJO_GIT_URL "https://codeberg.org/forgejo/forgejo.git"
|
||||||
|
ENV FORGEJO_BRANCH "forgejo-federation"
|
||||||
|
|
||||||
|
#Build deps
|
||||||
|
RUN apk --no-cache add build-base git nodejs npm
|
||||||
|
|
||||||
|
#Setup repo
|
||||||
|
RUN git clone --single-branch --branch ${FORGEJO_BRANCH} ${FORGEJO_GIT_URL} ${GOPATH}/src/code.gitea.io/gitea
|
||||||
|
|
||||||
|
WORKDIR ${GOPATH}/src/code.gitea.io/gitea
|
||||||
|
|
||||||
|
#Checkout version if set
|
||||||
|
RUN make clean-all build
|
||||||
|
|
||||||
|
# Begin env-to-ini build
|
||||||
|
RUN go build contrib/environment-to-ini/environment-to-ini.go
|
||||||
|
|
||||||
|
# Run stage
|
||||||
|
FROM docker.io/library/alpine:3.18
|
||||||
|
LABEL maintainer="contact@forgejo.org"
|
||||||
|
|
||||||
|
EXPOSE 22 3000
|
||||||
|
|
||||||
|
RUN apk --no-cache add \
|
||||||
|
bash \
|
||||||
|
ca-certificates \
|
||||||
|
curl \
|
||||||
|
gettext \
|
||||||
|
git \
|
||||||
|
linux-pam \
|
||||||
|
openssh \
|
||||||
|
s6 \
|
||||||
|
sqlite \
|
||||||
|
su-exec \
|
||||||
|
gnupg
|
||||||
|
|
||||||
|
RUN addgroup \
|
||||||
|
-S -g 1000 \
|
||||||
|
git && \
|
||||||
|
adduser \
|
||||||
|
-S -H -D \
|
||||||
|
-h /data/git \
|
||||||
|
-s /bin/bash \
|
||||||
|
-u 1000 \
|
||||||
|
-G git \
|
||||||
|
git && \
|
||||||
|
echo "git:*" | chpasswd -e
|
||||||
|
|
||||||
|
ENV USER git
|
||||||
|
ENV GITEA_CUSTOM /data/gitea
|
||||||
|
|
||||||
|
VOLUME ["/data"]
|
||||||
|
|
||||||
|
ENTRYPOINT ["/usr/bin/entrypoint"]
|
||||||
|
CMD ["/bin/s6-svscan", "/etc/s6"]
|
||||||
|
|
||||||
|
COPY --from=build-env /go/src/code.gitea.io/gitea/docker/root /
|
||||||
|
COPY --from=build-env /go/src/code.gitea.io/gitea/gitea /app/gitea/gitea
|
||||||
|
COPY --from=build-env /go/src/code.gitea.io/gitea/environment-to-ini /usr/local/bin/environment-to-ini
|
||||||
|
COPY --from=build-env /go/src/code.gitea.io/gitea/contrib/autocompletion/bash_autocomplete /etc/profile.d/gitea_bash_autocomplete.sh
|
||||||
|
RUN chmod 755 /usr/bin/entrypoint /app/gitea/gitea /usr/local/bin/gitea /usr/local/bin/environment-to-ini
|
||||||
|
RUN chmod 755 /etc/s6/gitea/* /etc/s6/openssh/* /etc/s6/.s6-svscan/*
|
||||||
|
RUN chmod 644 /etc/profile.d/gitea_bash_autocomplete.sh
|
@ -0,0 +1,10 @@
|
|||||||
|
FROM c4k-forgejo-fed
|
||||||
|
|
||||||
|
RUN apk --no-cache add openjdk11-jre-headless
|
||||||
|
|
||||||
|
RUN curl -L -o /tmp/serverspec.jar \
|
||||||
|
https://github.com/DomainDrivenArchitecture/dda-serverspec-crate/releases/download/2.0.0/dda-serverspec-standalone.jar
|
||||||
|
|
||||||
|
COPY serverspec.edn /tmp/serverspec.edn
|
||||||
|
|
||||||
|
RUN java -jar /tmp/serverspec.jar /tmp/serverspec.edn -v
|
@ -0,0 +1,8 @@
|
|||||||
|
{:file [{:path "/usr/bin/entrypoint" :mod "755"}
|
||||||
|
{:path "/app/gitea/gitea" :mod "755"}
|
||||||
|
{:path "/usr/local/bin/gitea" :mod "755"}
|
||||||
|
{:path "/usr/local/bin/environment-to-ini" :mod "755"}
|
||||||
|
{:path "/etc/s6/gitea/" :mod "755"}
|
||||||
|
{:path "/etc/s6/openssh/" :mod "755"}
|
||||||
|
{:path "/etc/s6/.s6-svscan/" :mod "755"}
|
||||||
|
{:path "/etc/profile.d/gitea_bash_autocomplete.sh" :mod "644"}]}
|
Loading…
Reference in New Issue