mirror of
https://github.com/mentos1386/dotfiles.git
synced 2025-01-31 08:45:46 +00:00
feat(fedora): remove fedora and only use ubuntu
This commit is contained in:
parent
fb66e8ace0
commit
28ae807b54
6 changed files with 39 additions and 180 deletions
76
.github/workflows/fedora.yaml
vendored
76
.github/workflows/fedora.yaml
vendored
|
@ -1,76 +0,0 @@
|
||||||
name: fedora
|
|
||||||
|
|
||||||
on:
|
|
||||||
schedule:
|
|
||||||
- cron: '0 6 * * *'
|
|
||||||
pull_request:
|
|
||||||
branches: main
|
|
||||||
push:
|
|
||||||
branches: main
|
|
||||||
tags:
|
|
||||||
- v*
|
|
||||||
|
|
||||||
jobs:
|
|
||||||
fedora:
|
|
||||||
runs-on: ubuntu-latest
|
|
||||||
steps:
|
|
||||||
- name: Checkout
|
|
||||||
uses: actions/checkout@v2
|
|
||||||
- name: Prepare
|
|
||||||
id: prepare
|
|
||||||
run: |
|
|
||||||
DOCKER_IMAGE=ghcr.io/mentos1386/workspace-fedora
|
|
||||||
DOCKER_PLATFORMS=linux/amd64,linux/arm64
|
|
||||||
VERSION=edge
|
|
||||||
|
|
||||||
if [[ $GITHUB_REF == refs/tags/* ]]; then
|
|
||||||
VERSION=${GITHUB_REF#refs/tags/v}
|
|
||||||
fi
|
|
||||||
if [ "${{ github.event_name }}" = "schedule" ]; then
|
|
||||||
VERSION=nightly
|
|
||||||
fi
|
|
||||||
|
|
||||||
TAGS="--tag ${DOCKER_IMAGE}:${VERSION}"
|
|
||||||
if [[ $VERSION =~ ^[0-9]{1,3}\.[0-9]{1,3}\.[0-9]{1,3}$ ]]; then
|
|
||||||
TAGS="$TAGS --tag ${DOCKER_IMAGE}:latest"
|
|
||||||
fi
|
|
||||||
|
|
||||||
echo ::set-output name=docker_image::${DOCKER_IMAGE}
|
|
||||||
echo ::set-output name=version::${VERSION}
|
|
||||||
echo ::set-output name=buildx_args::--platform ${DOCKER_PLATFORMS} \
|
|
||||||
--build-arg VERSION=${VERSION} \
|
|
||||||
--build-arg BUILD_DATE=$(date -u +'%Y-%m-%dT%H:%M:%SZ') \
|
|
||||||
--build-arg VCS_REF=${GITHUB_SHA::8} \
|
|
||||||
--cache-from "type=local,src=/tmp/.buildx-cache" \
|
|
||||||
--cache-to "type=local,dest=/tmp/.buildx-cache" \
|
|
||||||
${TAGS} --file ./Dockerfile.fedora .
|
|
||||||
- name: Cache Docker layers
|
|
||||||
uses: actions/cache@v2
|
|
||||||
with:
|
|
||||||
path: /tmp/.buildx-cache
|
|
||||||
key: ${{ runner.os }}-fedora-${{ github.sha }}
|
|
||||||
restore-keys: |
|
|
||||||
${{ runner.os }}-fedora-
|
|
||||||
- name: Set up QEMU
|
|
||||||
uses: docker/setup-qemu-action@v1
|
|
||||||
- name: Set up Docker Buildx
|
|
||||||
uses: docker/setup-buildx-action@v1
|
|
||||||
- name: Docker Buildx (build)
|
|
||||||
run: |
|
|
||||||
docker buildx build --output "type=image,push=false" ${{ steps.prepare.outputs.buildx_args }}
|
|
||||||
- name: Login to Github Registry
|
|
||||||
if: success() && github.event_name != 'pull_request'
|
|
||||||
uses: docker/login-action@v1
|
|
||||||
with:
|
|
||||||
registry: ghcr.io
|
|
||||||
username: ${{ github.repository_owner }}
|
|
||||||
password: ${{ secrets.CR_PAT }}
|
|
||||||
- name: Docker Buildx (push)
|
|
||||||
if: success() && github.event_name != 'pull_request'
|
|
||||||
run: |
|
|
||||||
docker buildx build --output "type=image,push=true" ${{ steps.prepare.outputs.buildx_args }}
|
|
||||||
- name: Inspect image
|
|
||||||
if: always() && github.event_name != 'pull_request'
|
|
||||||
run: |
|
|
||||||
docker buildx imagetools inspect ${{ steps.prepare.outputs.docker_image }}:${{ steps.prepare.outputs.version }}
|
|
||||||
|
|
|
@ -1,70 +0,0 @@
|
||||||
# vim: set fenc=utf-8 ts=2 sw=2 sts=2 et ft=Dockerfile :
|
|
||||||
FROM fedora:33
|
|
||||||
|
|
||||||
LABEL maintainer="Tine <mentos1386> Jozelj <tine@tjo.space>"
|
|
||||||
LABEL org.opencontainers.image.source https://github.com/mentos1386/workspace
|
|
||||||
|
|
||||||
ARG SSH_USER="${SSH_USER:-tine}"
|
|
||||||
|
|
||||||
SHELL ["/bin/bash", "-c"]
|
|
||||||
|
|
||||||
RUN set -ueox pipefail \
|
|
||||||
&& dnf -y update \
|
|
||||||
&& dnf -y install \
|
|
||||||
ca-certificates \
|
|
||||||
mosh \
|
|
||||||
openssh-server \
|
|
||||||
psmisc \
|
|
||||||
util-linux-user \
|
|
||||||
&& adduser "${SSH_USER}" \
|
|
||||||
&& dnf clean all \
|
|
||||||
&& rm -rf /tmp/* /var/tmp/*
|
|
||||||
|
|
||||||
# Install available packages
|
|
||||||
RUN set -ueox pipefail \
|
|
||||||
&& dnf -y update \
|
|
||||||
&& dnf -y install \
|
|
||||||
git \
|
|
||||||
tmux \
|
|
||||||
vim \
|
|
||||||
zsh \
|
|
||||||
&& dnf clean all \
|
|
||||||
&& rm -rf /tmp/* /var/tmp/*
|
|
||||||
|
|
||||||
# Install other packages
|
|
||||||
COPY --from=ghcr.io/mentos1386/starship:0.47.0 /starship /usr/local/bin/starship
|
|
||||||
COPY --from=ghcr.io/mentos1386/kubectl:1.20.0 /kubectl /usr/local/bin/kubectl
|
|
||||||
|
|
||||||
# Create .dotfiles
|
|
||||||
COPY --chown=${SSH_USER}:${SSH_USER} dotfiles /home/${SSH_USER}/.dotfiles
|
|
||||||
|
|
||||||
# Set ZSH for SSH_USER
|
|
||||||
RUN chsh -s $(which zsh) ${SSH_USER}
|
|
||||||
|
|
||||||
# User Configuration
|
|
||||||
USER "${SSH_USER}"
|
|
||||||
|
|
||||||
# GIT
|
|
||||||
RUN ln -s /home/${SSH_USER}/.dotfiles/git/gitconfig /home/${SSH_USER}/.gitconfig
|
|
||||||
# ZSH
|
|
||||||
RUN ln -s /home/${SSH_USER}/.dotfiles/zsh/zshrc /home/${SSH_USER}/.zshrc
|
|
||||||
# TMUX
|
|
||||||
RUN ln -s /home/${SSH_USER}/.dotfiles/tmux/tmux.conf /home/${SSH_USER}/.tmux.conf
|
|
||||||
# VIM
|
|
||||||
RUN mkdir -p "/home/${SSH_USER}/.config" \
|
|
||||||
&& ln -s "/home/${SSH_USER}/.dotfiles/nvim" "/home/${SSH_USER}/.config/nvim" \
|
|
||||||
&& ln -s "/home/${SSH_USER}/.dotfiles/nvim/vimrc" "/home/${SSH_USER}/.vimrc" \
|
|
||||||
&& git clone --depth 1 https://github.com/Shougo/dein.vim "/home/${SSH_USER}/.cache/vim/dein/repos/github.com/Shougo/dein.vim" \
|
|
||||||
&& vim -V1 -es -i NONE -N --noplugin -u "/home/${SSH_USER}/.config/nvim/config/vimrc" \
|
|
||||||
-c "try | call dein#clear_state() | call dein#update() | finally | messages | qall! | endtry"
|
|
||||||
# SSH
|
|
||||||
RUN mkdir -p /home/${SSH_USER}/.ssh \
|
|
||||||
&& ln -s /home/${SSH_USER}/.dotfiles/ssh/authorized_keys /home/${SSH_USER}/.ssh/authorized_keys
|
|
||||||
|
|
||||||
# Start SSH Daemon
|
|
||||||
USER root
|
|
||||||
EXPOSE 22/tcp
|
|
||||||
EXPOSE 22022/udp
|
|
||||||
RUN mkdir -p /run/sshd
|
|
||||||
CMD ["/usr/sbin/sshd", "-D", "-e", "-f", "/etc/ssh/sshd_config"]
|
|
||||||
|
|
|
@ -5,10 +5,7 @@ LABEL maintainer="Tine <mentos1386> Jozelj <tine@tjo.space>"
|
||||||
LABEL org.opencontainers.image.source https://github.com/mentos1386/workspace
|
LABEL org.opencontainers.image.source https://github.com/mentos1386/workspace
|
||||||
|
|
||||||
ARG SSH_USER="${SSH_USER:-blink}"
|
ARG SSH_USER="${SSH_USER:-blink}"
|
||||||
ARG SSH_PASSWORD="${SSH_PASSWORD:-blink}"
|
|
||||||
|
|
||||||
RUN apt update && apt install -y locales && rm -rf /var/lib/apt/lists/* \
|
|
||||||
&& localedef -i en_US -c -f UTF-8 -A /usr/share/locale/locale.alias en_US.UTF-8
|
|
||||||
ENV LANG en_US.UTF-8
|
ENV LANG en_US.UTF-8
|
||||||
ENV LANGUAGE en_US:en
|
ENV LANGUAGE en_US:en
|
||||||
ENV LC_ALL en_US.UTF-8
|
ENV LC_ALL en_US.UTF-8
|
||||||
|
@ -19,38 +16,64 @@ RUN set -ueox pipefail \
|
||||||
&& DEBIAN_FRONTEND=noninteractive \
|
&& DEBIAN_FRONTEND=noninteractive \
|
||||||
&& apt-get -yqq update \
|
&& apt-get -yqq update \
|
||||||
&& apt-get -yqq --no-install-recommends --no-install-suggests install \
|
&& apt-get -yqq --no-install-recommends --no-install-suggests install \
|
||||||
git \
|
|
||||||
ca-certificates \
|
ca-certificates \
|
||||||
locales \
|
locales \
|
||||||
mosh \
|
mosh \
|
||||||
openssh-server \
|
openssh-server \
|
||||||
psmisc \
|
psmisc \
|
||||||
tmux \
|
|
||||||
vim \
|
|
||||||
&& adduser --quiet --gecos '' --disabled-password --add_extra_groups "${SSH_USER}" \
|
&& adduser --quiet --gecos '' --disabled-password --add_extra_groups "${SSH_USER}" \
|
||||||
&& echo -e "${SSH_PASSWORD}\n${SSH_PASSWORD}" | passwd "${SSH_USER}" \
|
|
||||||
&& apt-get -yqq clean all \
|
&& apt-get -yqq clean all \
|
||||||
&& rm -rf /var/lib/apt/lists/* \
|
&& rm -rf /var/lib/apt/lists/* \
|
||||||
/tmp/* \
|
/tmp/* \
|
||||||
/var/tmp/*
|
/var/tmp/*
|
||||||
|
|
||||||
COPY . "/home/${SSH_USER}/.dotfiles"/
|
# Install available packages
|
||||||
RUN chown -R "${SSH_USER}:${SSH_USER}" "/home/${SSH_USER}/.dotfiles"
|
RUN set -ueox pipefail \
|
||||||
|
&& DEBIAN_FRONTEND=noninteractive \
|
||||||
|
&& apt-get -yqq --no-install-recommends --no-install-suggests install \
|
||||||
|
&& git \
|
||||||
|
&& tmux \
|
||||||
|
&& vim \
|
||||||
|
&& zsh \
|
||||||
|
&& apt-get -yqq clean all \
|
||||||
|
&& rm -rf /var/lib/apt/lists/* \
|
||||||
|
/tmp/* \
|
||||||
|
/var/tmp/*
|
||||||
|
|
||||||
|
# Install other packages
|
||||||
|
COPY --from=ghcr.io/mentos1386/starship:0.47.0 /starship /usr/local/bin/starship
|
||||||
|
COPY --from=ghcr.io/mentos1386/kubectl:1.20.0 /kubectl /usr/local/bin/kubectl
|
||||||
|
|
||||||
|
# Create .dotfiles
|
||||||
|
COPY --chown=${SSH_USER}:${SSH_USER} dotfiles /home/${SSH_USER}/.dotfiles
|
||||||
|
|
||||||
|
# Set ZSH for SSH_USER
|
||||||
|
RUN chsh -s $(which zsh) ${SSH_USER}
|
||||||
|
|
||||||
|
# User Configuration
|
||||||
USER "${SSH_USER}"
|
USER "${SSH_USER}"
|
||||||
|
|
||||||
RUN ln -s "/home/${SSH_USER}/.dotfiles/tmux/tmux.conf" "/home/${SSH_USER}/.tmux.conf" \
|
# GIT
|
||||||
&& mkdir -p "/home/${SSH_USER}/.config" \
|
RUN ln -s /home/${SSH_USER}/.dotfiles/git/gitconfig /home/${SSH_USER}/.gitconfig
|
||||||
|
# ZSH
|
||||||
|
RUN ln -s /home/${SSH_USER}/.dotfiles/zsh/zshrc /home/${SSH_USER}/.zshrc
|
||||||
|
# TMUX
|
||||||
|
RUN ln -s /home/${SSH_USER}/.dotfiles/tmux/tmux.conf /home/${SSH_USER}/.tmux.conf
|
||||||
|
# VIM
|
||||||
|
RUN mkdir -p "/home/${SSH_USER}/.config" \
|
||||||
&& ln -s "/home/${SSH_USER}/.dotfiles/nvim" "/home/${SSH_USER}/.config/nvim" \
|
&& ln -s "/home/${SSH_USER}/.dotfiles/nvim" "/home/${SSH_USER}/.config/nvim" \
|
||||||
&& ln -s "/home/${SSH_USER}/.dotfiles/nvim/vimrc" "/home/${SSH_USER}/.vimrc" \
|
&& ln -s "/home/${SSH_USER}/.dotfiles/nvim/vimrc" "/home/${SSH_USER}/.vimrc" \
|
||||||
&& git clone --depth 1 https://github.com/Shougo/dein.vim "/home/${SSH_USER}/.cache/vim/dein/repos/github.com/Shougo/dein.vim" \
|
&& git clone --depth 1 https://github.com/Shougo/dein.vim "/home/${SSH_USER}/.cache/vim/dein/repos/github.com/Shougo/dein.vim" \
|
||||||
&& vim -V1 -es -i NONE -N --noplugin -u "/home/${SSH_USER}/.config/nvim/config/vimrc" \
|
&& vim -V1 -es -i NONE -N --noplugin -u "/home/${SSH_USER}/.config/nvim/config/vimrc" \
|
||||||
-c "try | call dein#clear_state() | call dein#update() | finally | messages | qall! | endtry"
|
-c "try | call dein#clear_state() | call dein#update() | finally | messages | qall! | endtry"
|
||||||
|
# SSH
|
||||||
|
RUN mkdir -p /home/${SSH_USER}/.ssh \
|
||||||
|
&& ln -s /home/${SSH_USER}/.dotfiles/ssh/authorized_keys /home/${SSH_USER}/.ssh/authorized_keys
|
||||||
|
|
||||||
|
# Start SSH Daemon
|
||||||
USER root
|
USER root
|
||||||
EXPOSE 22/tcp
|
EXPOSE 22/tcp
|
||||||
EXPOSE 22022/udp
|
EXPOSE 22022/udp
|
||||||
|
|
||||||
RUN mkdir -p /run/sshd
|
RUN mkdir -p /run/sshd
|
||||||
CMD ["/usr/sbin/sshd", "-D", "-e", "-f", "/etc/ssh/sshd_config"]
|
CMD ["/usr/sbin/sshd", "-D", "-e", "-f", "/etc/ssh/sshd_config"]
|
||||||
|
|
||||||
|
|
15
Makefile
15
Makefile
|
@ -1,8 +1,3 @@
|
||||||
|
|
||||||
.PHONY: build-fedora
|
|
||||||
build-fedora:
|
|
||||||
@docker buildx build --load -t env-fedora -f Dockerfile.fedora .
|
|
||||||
|
|
||||||
.PHONY: build-ubuntu
|
.PHONY: build-ubuntu
|
||||||
build-ubuntu:
|
build-ubuntu:
|
||||||
@docker buildx build --load -t env-ubuntu -f Dockerfile.ubuntu .
|
@docker buildx build --load -t env-ubuntu -f Dockerfile.ubuntu .
|
||||||
|
@ -18,20 +13,18 @@ build-package-kubectl:
|
||||||
.PHONY: build-packages
|
.PHONY: build-packages
|
||||||
build-packages: package-kubectl package-starship
|
build-packages: package-kubectl package-starship
|
||||||
|
|
||||||
build: packages fedora ubuntu
|
build: packages ubuntu
|
||||||
|
|
||||||
.PHONY: template
|
.PHONY: template
|
||||||
template:
|
template:
|
||||||
@go run ./main.go template package-action > .github/workflows/packages.yaml
|
@go run ./main.go template package-action > .github/workflows/packages.yaml
|
||||||
@go run ./main.go template ubuntu-action > .github/workflows/ubuntu.yaml
|
@go run ./main.go template ubuntu-action > .github/workflows/ubuntu.yaml
|
||||||
@go run ./main.go template fedora-action > .github/workflows/fedora.yaml
|
|
||||||
|
|
||||||
pull:
|
pull:
|
||||||
@docker pull ghcr.io/mentos1386/workspace-fedora:edge
|
@docker pull ghcr.io/mentos1386/workspace-ubuntu:edge
|
||||||
#@docker pull ghcr.io/mentos1386/workspace-ubuntu:edge
|
|
||||||
@docker pull ghcr.io/mentos1386/starship:0.47.0
|
@docker pull ghcr.io/mentos1386/starship:0.47.0
|
||||||
@docker pull ghcr.io/mentos1386/kubectl:1.20.0
|
@docker pull ghcr.io/mentos1386/kubectl:1.20.0
|
||||||
|
|
||||||
run-fedora:
|
run-ubuntu:
|
||||||
@docker run -it --rm --workdir /home/tine --user tine ghcr.io/mentos1386/workspace-fedora:edge zsh
|
@docker run -it --rm --workdir /home/tine --user tine ghcr.io/mentos1386/workspace-ubuntu:edge zsh
|
||||||
|
|
||||||
|
|
|
@ -1,5 +1,4 @@
|
||||||
![Ubuntu](https://github.com/mentos1386/workspace/workflows/ubuntu/badge.svg)
|
![Ubuntu](https://github.com/mentos1386/workspace/workflows/ubuntu/badge.svg)
|
||||||
![Fedora](https://github.com/mentos1386/workspace/workflows/fedora/badge.svg)
|
|
||||||
![Packages](https://github.com/mentos1386/workspace/workflows/packages/badge.svg)
|
![Packages](https://github.com/mentos1386/workspace/workflows/packages/badge.svg)
|
||||||
|
|
||||||
my workspace as a docker container
|
my workspace as a docker container
|
||||||
|
|
|
@ -1,13 +1,3 @@
|
||||||
##
|
|
||||||
# Fedora
|
|
||||||
[templates."fedora-action"]
|
|
||||||
template = "templates/actions/workspace.yaml.tmpl"
|
|
||||||
|
|
||||||
[templates."fedora-action".vars]
|
|
||||||
name = "fedora"
|
|
||||||
repository = "ghcr.io/mentos1386"
|
|
||||||
platforms = "linux/amd64,linux/arm64"
|
|
||||||
|
|
||||||
##
|
##
|
||||||
# Ubuntu
|
# Ubuntu
|
||||||
[templates."ubuntu-action"]
|
[templates."ubuntu-action"]
|
||||||
|
|
Loading…
Reference in a new issue