Compare commits
54 Commits
| Author | SHA1 | Date | |
|---|---|---|---|
| 6d98e00785 | |||
| 9746514b48 | |||
| 45959b6444 | |||
| 61976fa2af | |||
| 75bf25d041 | |||
| 20e2b5d51b | |||
| 11dcd2625a | |||
| 0649fece72 | |||
| dec1e12add | |||
| 5aee8beff8 | |||
| 18fc839376 | |||
| 6445cfac59 | |||
| c223a84285 | |||
| 93a478a8b8 | |||
| c2ee52ac4d | |||
| a23671e961 | |||
| 745e2378af | |||
| bee8958456 | |||
| 0d58811815 | |||
| 7ae17012da | |||
| 73bd9a4581 | |||
| 9d9529db67 | |||
| 1ae6ea877d | |||
| f642a4ad2d | |||
| d733b7cdb5 | |||
| 3865cedb49 | |||
| 13c0f3c598 | |||
| aa95a2bf14 | |||
| ee6c5f360a | |||
| c665ad8d28 | |||
| 64899eb244 | |||
| d91e9f90de | |||
| 99250bfbdb | |||
| 41aae2641a | |||
| cf6cf7b776 | |||
| 942051f799 | |||
| 9366bb40a0 | |||
| d575115b0e | |||
| fc3415be5b | |||
| 5c40392fc4 | |||
| b9cb003834 | |||
| 6df9527db8 | |||
| cc85f4c476 | |||
| 9d11f308c4 | |||
| 3b544fc61f | |||
| 8a26981a06 | |||
| df42190f94 | |||
| 35cbac9328 | |||
| 3245bac439 | |||
| a2fc48b06b | |||
| 57991727fa | |||
| 4cbb470ff5 | |||
| 9bac7be2b6 | |||
| 33995326a8 |
@@ -1,69 +0,0 @@
|
|||||||
name: ci/cd to build and push docker image in private registry
|
|
||||||
|
|
||||||
#https://docs.docker.com/build/ci/github-actions/push-multi-registries/
|
|
||||||
#https://www.devsync.se/ci/cd/docker/2023/10/27/gitea-runner-build-docker-containers.html
|
|
||||||
|
|
||||||
on:
|
|
||||||
push:
|
|
||||||
tags:
|
|
||||||
- '*'
|
|
||||||
|
|
||||||
jobs:
|
|
||||||
build-push-docker-image:
|
|
||||||
# see on runner /data/.runner to add label (test => test:docker://debian:bullseye)
|
|
||||||
runs-on: test
|
|
||||||
container: debian:bullseye
|
|
||||||
# runs-on: ubuntu-latest
|
|
||||||
# container: node:16-bullseye
|
|
||||||
|
|
||||||
steps:
|
|
||||||
- name: Show version and repository
|
|
||||||
run: echo "Runner working on repository ${{ gitea.repository }} and on tag ${{ gitea.ref_name }}"
|
|
||||||
|
|
||||||
- name: Install dnsutils and git (github actions)
|
|
||||||
run: |
|
|
||||||
apt-get update
|
|
||||||
apt-get -y install dnsutils git
|
|
||||||
|
|
||||||
- name: Install node (github actions)
|
|
||||||
run: |
|
|
||||||
apt-get update && apt-get install -y ca-certificates curl gnupg
|
|
||||||
install -m 0755 -d /etc/apt/keyrings
|
|
||||||
curl -fsSL https://deb.nodesource.com/gpgkey/nodesource-repo.gpg.key | gpg --dearmor -o /etc/apt/keyrings/nodesource.gpg
|
|
||||||
NODE_MAJOR=${{ vars.NODE_MAJOR_VERSION }}
|
|
||||||
echo "deb [signed-by=/etc/apt/keyrings/nodesource.gpg] https://deb.nodesource.com/node_$NODE_MAJOR.x nodistro main" | tee /etc/apt/sources.list.d/nodesource.list
|
|
||||||
apt-get update && apt-get install nodejs -y
|
|
||||||
|
|
||||||
- name: Git clone private repository
|
|
||||||
uses: actions/checkout@v4
|
|
||||||
with:
|
|
||||||
repository: ${{ gitea.repository }}
|
|
||||||
token: ${{ secrets.ACCESS_TOKEN_GIT }}
|
|
||||||
|
|
||||||
- name: Install Docker
|
|
||||||
run: |
|
|
||||||
apt-get update
|
|
||||||
apt-get -y install ca-certificates curl gnupg
|
|
||||||
install -m 0755 -d /etc/apt/keyrings
|
|
||||||
curl -fsSL https://download.docker.com/linux/debian/gpg | gpg --dearmor -o /etc/apt/keyrings/docker.gpg
|
|
||||||
chmod a+r /etc/apt/keyrings/docker.gpg
|
|
||||||
echo "deb [arch="$(dpkg --print-architecture)" signed-by=/etc/apt/keyrings/docker.gpg] https://download.docker.com/linux/debian "$(. /etc/os-release && echo "$VERSION_CODENAME")" stable" | tee /etc/apt/sources.list.d/docker.list > /dev/null
|
|
||||||
apt-get update
|
|
||||||
apt-get -y install docker-ce docker-ce-cli containerd.io docker-buildx-plugin
|
|
||||||
|
|
||||||
- name: Login to docker private registry
|
|
||||||
uses: docker/login-action@v3
|
|
||||||
with:
|
|
||||||
registry: ${{ vars.REGISTRY_DOCKER }}
|
|
||||||
username: ${{ secrets.REGISTRY_DOCKER_USER }}
|
|
||||||
password: ${{ secrets.REGISTRY_DOCKER_PASS }}
|
|
||||||
|
|
||||||
- name: Build and push image in registry
|
|
||||||
uses: docker/build-push-action@v5
|
|
||||||
with:
|
|
||||||
context: .
|
|
||||||
push: true
|
|
||||||
tags: ${{ vars.REGISTRY_DOCKER }}/${{ vars.DOCKER_IMAGE_NAME }}:latest,${{ vars.REGISTRY_DOCKER }}/${{ vars.DOCKER_IMAGE_NAME }}:${{ gitea.ref_name }}
|
|
||||||
|
|
||||||
- name: Show docker images
|
|
||||||
run: docker images
|
|
||||||
69
.gitea/workflows/build_push_internal_docker.yml
Normal file
69
.gitea/workflows/build_push_internal_docker.yml
Normal file
@@ -0,0 +1,69 @@
|
|||||||
|
name: ci/cd to build and push docker image debian_runner in private registry
|
||||||
|
|
||||||
|
#https://docs.docker.com/build/ci/github-actions/push-multi-registries/
|
||||||
|
#https://www.devsync.se/ci/cd/docker/2023/10/27/gitea-runner-build-docker-containers.html
|
||||||
|
|
||||||
|
on:
|
||||||
|
push:
|
||||||
|
tags:
|
||||||
|
# Be carefull, conflict with package-deb *.*.*, don't use more than on dot *.* (ex: 2.5-runner)
|
||||||
|
- '*-runner'
|
||||||
|
|
||||||
|
jobs:
|
||||||
|
build-and-push:
|
||||||
|
#! see on runner /data/.runner to add label (test => test:docker://debian:bullseye)
|
||||||
|
# runs-on: test
|
||||||
|
# container: debian:bullseye
|
||||||
|
# runs-on: ubuntu-latest
|
||||||
|
# container: node:16-bullseye
|
||||||
|
runs-on: ubuntu-runner
|
||||||
|
container:
|
||||||
|
image: docker
|
||||||
|
# container:
|
||||||
|
# image: ${{ vars.REGISTRY_DOCKER }}/${{ vars.DOCKER_IMAGE_RUNNER }}:latest
|
||||||
|
# credentials:
|
||||||
|
# username: ${{ secrets.REGISTRY_DOCKER_USER }}
|
||||||
|
# password: ${{ secrets.REGISTRY_DOCKER_PASS }}
|
||||||
|
|
||||||
|
|
||||||
|
steps:
|
||||||
|
- name: Show Information
|
||||||
|
run: echo "Runner ${{ runner.os }} working on repository ${{ gitea.repository }} and on tag ${{ gitea.ref_name }}"
|
||||||
|
- name: login & clone & build & push
|
||||||
|
run: |
|
||||||
|
echo "${{ secrets.REGISTRY_DOCKER_PASS }}" | docker login -u ${{ secrets.REGISTRY_DOCKER_USER }} --password-stdin ${{ vars.REGISTRY_DOCKER }}
|
||||||
|
git clone https://${{ secrets.REGISTRY_DOCKER_PASS }}@${{ vars.REGISTRY_DOCKER }}/${{ secrets.REGISTRY_DOCKER_USER }}/${{ vars.DOCKER_IMAGE_NAME }}
|
||||||
|
cd ${{ vars.DOCKER_IMAGE_NAME }}
|
||||||
|
docker buildx b . -t ${{ vars.REGISTRY_DOCKER }}/${{ vars.DOCKER_IMAGE_NAME }}
|
||||||
|
docker tag ${{ vars.DOCKER_IMAGE_NAME }} ${{ vars.REGISTRY_DOCKER }}/${{ vars.DOCKER_IMAGE_NAME }}:${{ gitea.ref_name }}
|
||||||
|
docker tag ${{ vars.DOCKER_IMAGE_NAME }} ${{ vars.REGISTRY_DOCKER }}/${{ vars.DOCKER_IMAGE_NAME }}:latest
|
||||||
|
docker push ${{ vars.REGISTRY_DOCKER }}/${{ vars.DOCKER_IMAGE_NAME }}:${{ gitea.ref_name }}
|
||||||
|
docker push ${{ vars.REGISTRY_DOCKER }}/${{ vars.DOCKER_IMAGE_NAME }}:latest
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
# - name: Git clone private repository
|
||||||
|
# uses: actions/checkout@v4
|
||||||
|
# with:
|
||||||
|
# repository: ${{ gitea.repository }}
|
||||||
|
# token: ${{ secrets.REPO_PULL_GITEA }}
|
||||||
|
|
||||||
|
# - name: Login to docker private registry
|
||||||
|
# uses: docker/login-action@v3
|
||||||
|
# with:
|
||||||
|
# registry: ${{ vars.REGISTRY_DOCKER }}
|
||||||
|
# username: ${{ secrets.REGISTRY_DOCKER_USER }}
|
||||||
|
# password: ${{ secrets.REGISTRY_DOCKER_PASS }}
|
||||||
|
|
||||||
|
|
||||||
|
# - run: git --help
|
||||||
|
|
||||||
|
# - name: Build and push image in registry
|
||||||
|
# uses: docker/build-push-action@v5
|
||||||
|
# with:
|
||||||
|
# context: .
|
||||||
|
# push: true
|
||||||
|
# tags: ${{ vars.REGISTRY_DOCKER }}/${{ vars.DOCKER_IMAGE_NAME }}:latest,${{ vars.REGISTRY_DOCKER }}/${{ vars.DOCKER_IMAGE_NAME }}:${{ gitea.ref_name }}
|
||||||
|
|
||||||
|
# - name: Output
|
||||||
|
# run: echo "Runner push on ${{ vars.REGISTRY_DOCKER }} image ${{ vars.DOCKER_IMAGE_NAME }} tag ${{ gitea.ref_name }}"
|
||||||
55
.gitea/workflows/build_push_package_deb.yml
Normal file
55
.gitea/workflows/build_push_package_deb.yml
Normal file
@@ -0,0 +1,55 @@
|
|||||||
|
name: build_package_deb
|
||||||
|
|
||||||
|
env:
|
||||||
|
PACKAGE_NAME: test3
|
||||||
|
DEB_OS_TARGET: bullseye
|
||||||
|
GIT_REPO_URL: gitea.jingoh.fr
|
||||||
|
MAINTAINER: jingoh
|
||||||
|
ARCH: amd64
|
||||||
|
|
||||||
|
on:
|
||||||
|
push:
|
||||||
|
tags:
|
||||||
|
- '*-samplescript'
|
||||||
|
|
||||||
|
jobs:
|
||||||
|
build-package-push-repo:
|
||||||
|
runs-on: debian-bullseye-node
|
||||||
|
steps:
|
||||||
|
- name: Git clone private repository
|
||||||
|
uses: actions/checkout@v4
|
||||||
|
with:
|
||||||
|
repository: ${{ gitea.repository }}
|
||||||
|
token: ${{ secrets.REPO_PULL_GITEA }}
|
||||||
|
|
||||||
|
- name: create sample script
|
||||||
|
run: |
|
||||||
|
mkdir -p .debpkg/usr/bin
|
||||||
|
mkdir -p .debpkg/usr/lib/samplescript
|
||||||
|
echo -e "echo sample" > .debpkg/usr/bin/samplescript
|
||||||
|
chmod +x .debpkg/usr/bin/samplescript
|
||||||
|
echo -e "a=1" > .debpkg/usr/lib/samplescript/samplescript.conf
|
||||||
|
|
||||||
|
# create DEBIAN directory if you want to add other pre/post scripts
|
||||||
|
mkdir -p .debpkg/DEBIAN
|
||||||
|
echo -e "echo postinst" > .debpkg/DEBIAN/postinst
|
||||||
|
chmod +x .debpkg/DEBIAN/postinst
|
||||||
|
|
||||||
|
- uses: jiro4989/build-deb-action@v3
|
||||||
|
with:
|
||||||
|
package: ${{ env.PACKAGE_NAME }}
|
||||||
|
package_root: .debpkg
|
||||||
|
maintainer: ${{ env.MAINTAINER }}
|
||||||
|
version: ${{ gitea.ref_name }}
|
||||||
|
arch: 'amd64'
|
||||||
|
depends: 'libc6 (>= 2.2.1), git'
|
||||||
|
desc: 'this is sample package.'
|
||||||
|
|
||||||
|
- name: Push packages
|
||||||
|
run: |
|
||||||
|
curl --user ${{ vars.REPO_GITEA_USER }}:${{ secrets.PACKAGE_PUSH_REPO }} \
|
||||||
|
--upload-file ${{ env.PACKAGE_NAME }}_${{ gitea.ref_name }}_${{ env.ARCH }}.deb \
|
||||||
|
https://${{ env.GIT_REPO_URL }}/api/packages/${{ vars.REPO_GITEA_USER }}/debian/pool/${{ env.DEB_OS_TARGET }}/main/upload
|
||||||
|
|
||||||
|
- name: Output
|
||||||
|
run: echo "Runner push on ${{ env.GIT_REPO_URL }} with user ${{ vars.REPO_GITEA_USER }} package ${{ env.PACKAGE_NAME }} os ${{ env.DEB_OS_TARGET }} tag ${{ gitea.ref_name }}"
|
||||||
38
.gitea/workflows/build_push_public_docker.yml
Normal file
38
.gitea/workflows/build_push_public_docker.yml
Normal file
@@ -0,0 +1,38 @@
|
|||||||
|
name: ci/cd to build and push docker image wafwoof in private registry
|
||||||
|
|
||||||
|
on:
|
||||||
|
push:
|
||||||
|
tags:
|
||||||
|
# Be carefull, conflict with package-deb *.*.*, don't use more than on dot *.* (ex: 2.5-runner)
|
||||||
|
- '*-waf'
|
||||||
|
|
||||||
|
env:
|
||||||
|
GIT_REPO: wafw00f
|
||||||
|
GIT_SERVER: https://github.com/EnableSecurity
|
||||||
|
|
||||||
|
jobs:
|
||||||
|
build-and-push:
|
||||||
|
#! see on runner /data/.runner to add label (test => test:docker://debian:bullseye)
|
||||||
|
# runs-on: test
|
||||||
|
# container: debian:bullseye
|
||||||
|
# runs-on: ubuntu-latest
|
||||||
|
# container: node:16-bullseye
|
||||||
|
runs-on: ubuntu-runner
|
||||||
|
container:
|
||||||
|
image: docker
|
||||||
|
|
||||||
|
steps:
|
||||||
|
- name: Show Information
|
||||||
|
run: echo "Runner ${{ runner.os }} working on repository ${{ gitea.repository }} and on tag ${{ gitea.ref_name }}"
|
||||||
|
|
||||||
|
- name: clone & build & push
|
||||||
|
run: |
|
||||||
|
echo "${{ secrets.REGISTRY_DOCKER_PASS }}" | docker login -u ${{ secrets.REGISTRY_DOCKER_USER }} --password-stdin ${{ vars.REGISTRY_DOCKER }}
|
||||||
|
git clone https://${{ env.GIT_SERVER }}/${{ env.GIT_REPO }}
|
||||||
|
cd ${{ env.GIT_REPO }}
|
||||||
|
docker buildx b . -t ${{ vars.DOCKER_IMAGE_WAFWOOF }}
|
||||||
|
docker tag ${{ vars.DOCKER_IMAGE_WAFWOOF }} ${{ vars.REGISTRY_DOCKER }}/${{ vars.DOCKER_IMAGE_WAFWOOF }}
|
||||||
|
docker push ${{ vars.REGISTRY_DOCKER }}/${{ vars.DOCKER_IMAGE_WAFWOOF }}
|
||||||
|
|
||||||
|
- name: Output
|
||||||
|
run: echo "Runner push on ${{ vars.REGISTRY_DOCKER }} image ${{ vars.DOCKER_IMAGE_WAFWOOF }} tag ${{ gitea.ref_name }}"
|
||||||
@@ -1,29 +1,25 @@
|
|||||||
name: Gitea Actions Demo
|
name: Gitea Actions Demo
|
||||||
run-name: ${{ gitea.actor }} is testing out Gitea Actions 🚀
|
run-name: ${{ gitea.actor }} is testing out Gitea Actions 🚀
|
||||||
on: [never]
|
# on: [push]
|
||||||
|
on:
|
||||||
|
push:
|
||||||
|
tags:
|
||||||
|
- '*-demo'
|
||||||
## Exemple https://github.com/actions/starter-workflows/blob/main/ci/docker-publish.yml
|
## Exemple https://github.com/actions/starter-workflows/blob/main/ci/docker-publish.yml
|
||||||
|
|
||||||
jobs:
|
jobs:
|
||||||
Explore-Gitea-Actions:
|
Explore-Gitea-Actions:
|
||||||
runs-on: ubuntu-latest
|
runs-on: debian-bullseye-node
|
||||||
steps:
|
steps:
|
||||||
- run: echo "🎉 The job was automatically triggered by a ${{ gitea.event_name }} event. Test 4zet"
|
- run: echo "🎉 The job was automatically triggered by a ${{ gitea.event_name }} event. Test 4zet"
|
||||||
- run: echo "🐧 This job is now running on a ${{ runner.os }} server hosted by Gitea!"
|
- run: echo "🐧 This job is now running on a ${{ runner.os }} server hosted by Gitea!"
|
||||||
- run: echo "🔎 The name of your branch is ${{ gitea.ref }} and your repository is ${{ gitea.repository }}."
|
- run: echo "🔎 The name of your branch is ${{ gitea.ref }} and your repository is ${{ gitea.repository }}."
|
||||||
- name: Checkout private tools
|
|
||||||
uses: actions/checkout@v3
|
|
||||||
with:
|
|
||||||
# tape git@gitea.jingoh.fr port 22 et pas port 443 cet ane (should be ssh://gitea.jingoh.fr:443/$repository au lieu de ssh://gitea.jingoh.fr:$repository)
|
|
||||||
repository: staffadmin/gitea-runner
|
|
||||||
persist-credentials: false
|
|
||||||
ssh-strict: false
|
|
||||||
token: ${{ secrets.GH_PAT }} # `GH_PAT` is a secret that contains your PAT
|
|
||||||
ssh-known-hosts: ${{ secrets.SSH_KNOWN_GITEA }}
|
|
||||||
- run: echo "💡 The ${{ gitea.repository }} repository has been cloned to the runner."
|
- run: echo "💡 The ${{ gitea.repository }} repository has been cloned to the runner."
|
||||||
- run: echo "🖥️ The workflow is now ready to test your code on the runner."
|
- run: echo "🖥️ The workflow is now ready to test your code on the runner."
|
||||||
- run: echo "lala"
|
|
||||||
- name: List files in the repository
|
|
||||||
run: |
|
|
||||||
ls ${{ gitea.workspace }}
|
|
||||||
- run: echo "🍏 This job's status is ${{ job.status }}."
|
- run: echo "🍏 This job's status is ${{ job.status }}."
|
||||||
|
- name: Git clone private repository
|
||||||
|
uses: actions/checkout@v3
|
||||||
|
with:
|
||||||
|
repository: staffadmin/semaphore
|
||||||
|
ref: main
|
||||||
|
token: ${{ secrets.REPO_PULL_GITEA }}
|
||||||
31
Dockerfile
31
Dockerfile
@@ -1,9 +1,30 @@
|
|||||||
|
|
||||||
# Container image that runs your code
|
# Container image that runs your code
|
||||||
FROM alpine:3.10
|
FROM debian:bullseye
|
||||||
|
|
||||||
# Copies your code file from your action repository to the filesystem path `/` of the container
|
ENV NODE_MAJOR 16
|
||||||
COPY entrypoint.sh /entrypoint.sh
|
|
||||||
|
|
||||||
# Code file to execute when the docker container starts up (`entrypoint.sh`)
|
# install dependancies packages
|
||||||
ENTRYPOINT ["/entrypoint.sh"]
|
RUN apt-get update \
|
||||||
|
&& apt-get install -y curl \
|
||||||
|
dnsutils \
|
||||||
|
git \
|
||||||
|
ca-certificates \
|
||||||
|
gnupg
|
||||||
|
|
||||||
|
# NODE
|
||||||
|
RUN install -m 0755 -d /etc/apt/keyrings
|
||||||
|
RUN curl -fsSL https://deb.nodesource.com/gpgkey/nodesource-repo.gpg.key | gpg --dearmor -o /etc/apt/keyrings/nodesource.gpg
|
||||||
|
RUN echo "deb [signed-by=/etc/apt/keyrings/nodesource.gpg] https://deb.nodesource.com/node_$NODE_MAJOR.x nodistro main" | tee /etc/apt/sources.list.d/nodesource.list
|
||||||
|
|
||||||
|
# DOCKER
|
||||||
|
RUN curl -fsSL https://download.docker.com/linux/debian/gpg | gpg --dearmor -o /etc/apt/keyrings/docker.gpg
|
||||||
|
RUN chmod a+r /etc/apt/keyrings/docker.gpg
|
||||||
|
RUN echo "deb [arch="$(dpkg --print-architecture)" signed-by=/etc/apt/keyrings/docker.gpg] https://download.docker.com/linux/debian "$(. /etc/os-release && echo "$VERSION_CODENAME")" stable" | tee /etc/apt/sources.list.d/docker.list > /dev/null
|
||||||
|
|
||||||
|
RUN apt-get update \
|
||||||
|
&& apt-get install -y nodejs \
|
||||||
|
docker-ce \
|
||||||
|
docker-ce-cli \
|
||||||
|
containerd.io \
|
||||||
|
docker-buildx-plugin
|
||||||
17
README.md
17
README.md
@@ -1,13 +1,8 @@
|
|||||||
Création d'un nouveau dépôt en ligne de commande
|
# Docker debian runner
|
||||||
|
|
||||||
touch README.md
|
This project should own all docker build/push runner
|
||||||
git init
|
|
||||||
git checkout -b main
|
|
||||||
git add README.md
|
|
||||||
git commit -m "first commit"
|
|
||||||
git remote add origin ssh://git@gitea.jingoh.fr:443/staffadmin/gitea-runner.git
|
|
||||||
git push -u origin main
|
|
||||||
Soumission d'un dépôt existant par ligne de commande
|
|
||||||
|
|
||||||
git remote add origin ssh://git@gitea.jingoh.fr:443/staffadmin/gitea-runner.git
|
* debian_runner
|
||||||
git push -u origin main
|
* wafwoof
|
||||||
|
|
||||||
|
Build deb package and push on gitea repo example
|
||||||
@@ -1,5 +0,0 @@
|
|||||||
#!/bin/sh -l
|
|
||||||
|
|
||||||
echo "Hello $1"
|
|
||||||
time=$(date)
|
|
||||||
echo "time=$time" >> $GITHUB_OUTPUT
|
|
||||||
Reference in New Issue
Block a user