Compare commits
27 Commits
Author | SHA1 | Date | |
---|---|---|---|
40ede07ab0 | |||
5165759558 | |||
10f73b96ec | |||
5097e551e2 | |||
820d2d8c51 | |||
eb5c12ca91 | |||
2d1c9f7418 | |||
3c2e0cdcb8 | |||
66c2c3b6a2 | |||
b92f6688c7 | |||
85d00a53f6 | |||
529abe67b1 | |||
2bef46ea1b | |||
19d1e60d2f | |||
2da770623f | |||
e90966970a | |||
a54a46b0a6 | |||
a719e5f820 | |||
3c4f656ec8 | |||
e0e6bf2507 | |||
84908c0a24 | |||
762169f563 | |||
066078f23c | |||
f201287a9b | |||
4fd8dd78ef | |||
16139755e5 | |||
8e960419b4 |
@ -6,7 +6,7 @@
|
||||
"vscode": {
|
||||
"extensions": [
|
||||
"Shopify.ruby-lsp",
|
||||
"ms-azuretools.vscode-docker"
|
||||
"docker.docker"
|
||||
]
|
||||
}
|
||||
},
|
||||
|
7
.dockerignore
Normal file
7
.dockerignore
Normal file
@ -0,0 +1,7 @@
|
||||
**/.git
|
||||
**/.gitignore
|
||||
/.devcontainer
|
||||
/.gitea
|
||||
/.github
|
||||
/.vscode
|
||||
/charts
|
23
.gitea/workflows/lint.yaml
Normal file
23
.gitea/workflows/lint.yaml
Normal file
@ -0,0 +1,23 @@
|
||||
---
|
||||
name: Ruby Lint
|
||||
on:
|
||||
push:
|
||||
branches:
|
||||
- "**"
|
||||
pull_request:
|
||||
jobs:
|
||||
lint:
|
||||
runs-on: ubuntu-latest
|
||||
steps:
|
||||
- name: Checkout
|
||||
uses: actions/checkout@11bd71901bbe5b1630ceea73d27597364c9af683 # v4.2.2
|
||||
|
||||
- name: Ruby Setup
|
||||
uses: ruby/setup-ruby@dffc446db9ba5a0c4446edb5bca1c5c473a806c5 # v1.235.0
|
||||
with:
|
||||
ruby-version: '3.4'
|
||||
bundler-cache: true
|
||||
|
||||
- name: Standard Ruby
|
||||
run: bundle exec standardrb
|
||||
|
@ -1,65 +1,16 @@
|
||||
---
|
||||
name: Gitea Actions Demo
|
||||
run-name: ${{ gitea.actor }} is testing out Gitea Actions 🚀
|
||||
|
||||
name: Release
|
||||
on:
|
||||
schedule:
|
||||
- cron: "0 10 * * *"
|
||||
- cron: "0 0 * * *"
|
||||
push:
|
||||
branches:
|
||||
- "**"
|
||||
- main
|
||||
tags:
|
||||
- "v*.*.*"
|
||||
pull_request:
|
||||
|
||||
jobs:
|
||||
lint:
|
||||
runs-on: ubuntu-latest
|
||||
permissions:
|
||||
checks: write
|
||||
contents: write
|
||||
steps:
|
||||
- name: Login to Docker
|
||||
uses: docker/login-action@74a5d142397b4f367a81961eba4e8cd7edddf772 # v3.4.0
|
||||
with:
|
||||
username: ${{ vars.DOCKERHUB_USERNAME }}
|
||||
password: ${{ secrets.DOCKERHUB_TOKEN }}
|
||||
|
||||
- name: Checkout
|
||||
uses: actions/checkout@11bd71901bbe5b1630ceea73d27597364c9af683 # v4.2.2
|
||||
|
||||
- name: Ruby Setup
|
||||
uses: ruby/setup-ruby@dffc446db9ba5a0c4446edb5bca1c5c473a806c5 # v1.235.0
|
||||
with:
|
||||
ruby-version: '3.4'
|
||||
bundler-cache: true
|
||||
|
||||
- run: bundle install
|
||||
|
||||
- name: Standard Ruby
|
||||
run: bundle exec standardrb
|
||||
|
||||
|
||||
test:
|
||||
needs: lint
|
||||
runs-on: ubuntu-latest
|
||||
steps:
|
||||
- name: Checkout
|
||||
uses: actions/checkout@11bd71901bbe5b1630ceea73d27597364c9af683 # v4.2.2
|
||||
|
||||
- name: Test
|
||||
uses: ruby/setup-ruby@dffc446db9ba5a0c4446edb5bca1c5c473a806c5 # v1.235.0
|
||||
with:
|
||||
ruby-version: '3.4'
|
||||
bundler-cache: true
|
||||
|
||||
- run: bundle exec rake
|
||||
|
||||
docker:
|
||||
needs: test
|
||||
runs-on: ubuntu-latest
|
||||
container:
|
||||
image: catthehacker/ubuntu:act-latest
|
||||
env:
|
||||
DOCKER_ORG: ryanc
|
||||
DOCKER_LATEST: latest
|
||||
@ -85,6 +36,9 @@ jobs:
|
||||
printf "GITHUB_SHA=%s\n" "$GITHUB_SHA"
|
||||
printf "VERSION=%s\n" "$VERSION" | tee -a "$GITHUB_OUTPUT"
|
||||
|
||||
- name: Set up QEMU
|
||||
uses: docker/setup-qemu-action@29109295f81e9208d7d86ff1c6c12d2833863392 # v3.6.0
|
||||
|
||||
- name: Set up Docker Buildx
|
||||
uses: docker/setup-buildx-action@b5ca514318bd6ebac0fb2aedd5d36ec1b5c232a2 # v3.10.0
|
||||
|
||||
@ -105,7 +59,8 @@ jobs:
|
||||
latest=auto
|
||||
bake-target: docker-metadata-action
|
||||
tags: |
|
||||
type=schedule
|
||||
type=schedule,pattern=nightly
|
||||
type=edge
|
||||
type=ref,event=branch
|
||||
type=ref,event=pr
|
||||
type=semver,pattern={{version}}
|
||||
@ -124,7 +79,8 @@ jobs:
|
||||
latest=auto
|
||||
suffix=-alpine,onlatest=true
|
||||
tags: |
|
||||
type=schedule
|
||||
type=schedule,pattern=nightly
|
||||
type=edge
|
||||
type=ref,event=branch
|
||||
type=ref,event=pr
|
||||
type=semver,pattern={{version}}
|
22
.gitea/workflows/test.yaml
Normal file
22
.gitea/workflows/test.yaml
Normal file
@ -0,0 +1,22 @@
|
||||
---
|
||||
name: Ruby Test
|
||||
on:
|
||||
push:
|
||||
branches:
|
||||
- "**"
|
||||
pull_request:
|
||||
jobs:
|
||||
test:
|
||||
runs-on: ubuntu-latest
|
||||
steps:
|
||||
- name: Checkout
|
||||
uses: actions/checkout@11bd71901bbe5b1630ceea73d27597364c9af683 # v4.2.2
|
||||
|
||||
- name: Test
|
||||
uses: ruby/setup-ruby@dffc446db9ba5a0c4446edb5bca1c5c473a806c5 # v1.235.0
|
||||
with:
|
||||
ruby-version: '3.4'
|
||||
bundler-cache: true
|
||||
|
||||
- run: bundle exec rake
|
||||
|
42
Dockerfile
42
Dockerfile
@ -1,42 +0,0 @@
|
||||
ARG RUBY_VERSION="3.4.3"
|
||||
FROM ruby:${RUBY_VERSION} AS base
|
||||
|
||||
WORKDIR /app
|
||||
|
||||
RUN <<EOT
|
||||
apt-get update
|
||||
gem update --system --no-document
|
||||
gem install -N bundler
|
||||
EOT
|
||||
|
||||
|
||||
FROM base AS build
|
||||
|
||||
RUN <<EOT
|
||||
apt-get install --yes gcc make
|
||||
EOT
|
||||
|
||||
COPY Gemfile* .
|
||||
|
||||
RUN <<EOT
|
||||
bundle config set --local without development
|
||||
bundle install
|
||||
EOT
|
||||
|
||||
|
||||
FROM base
|
||||
|
||||
ENV PORT=4567
|
||||
|
||||
# RUN useradd ruby --home /app --shell /bin/sh
|
||||
RUN useradd --home /app --create-home app
|
||||
|
||||
USER app:app
|
||||
|
||||
COPY --from=build /usr/local/bundle /usr/local/bundle
|
||||
COPY --from=build --chown=app:app /app /app
|
||||
|
||||
COPY --chown=app:app . .
|
||||
|
||||
EXPOSE 4567
|
||||
CMD [ "puma", "--bind", "0.0.0.0", "--port", "$PORT" ]
|
1
Gemfile
1
Gemfile
@ -3,7 +3,6 @@ source "https://rubygems.org"
|
||||
gem "sinatra"
|
||||
gem "sinatra-contrib"
|
||||
gem "puma"
|
||||
gem "rackup"
|
||||
|
||||
gem "anyflake"
|
||||
gem "ksuid"
|
||||
|
@ -45,8 +45,6 @@ GEM
|
||||
rack (>= 3.0.0)
|
||||
rack-test (2.2.0)
|
||||
rack (>= 1.3)
|
||||
rackup (2.2.1)
|
||||
rack (>= 3)
|
||||
rainbow (3.1.1)
|
||||
rake (13.2.1)
|
||||
rbs (3.9.2)
|
||||
@ -138,7 +136,6 @@ DEPENDENCIES
|
||||
nanoid
|
||||
puma
|
||||
rack-test
|
||||
rackup
|
||||
rake
|
||||
rspec
|
||||
ruby-lsp
|
||||
|
14
app.rb
14
app.rb
@ -21,11 +21,9 @@ $LOAD_PATH.unshift File.dirname(__FILE__) + "/lib"
|
||||
|
||||
require "config"
|
||||
|
||||
VERSION = "0.2.0"
|
||||
VERSION = "0.2.2"
|
||||
|
||||
CHUNK_SIZE = 1024**2
|
||||
SESSION_SECRET_HEX_LENGTH = 64
|
||||
JWT_SECRET_HEX_LENGTH = 64
|
||||
DEFAULT_FLAKEY = 50
|
||||
|
||||
NAME = "kubernaut".freeze
|
||||
@ -380,19 +378,21 @@ get "/pid", provides: "json" do
|
||||
jsonify({ppid: ppid, pid: Process.pid}, pretty:)
|
||||
end
|
||||
|
||||
get "/token" do
|
||||
get "/token", provides: "json" do
|
||||
pretty = params.key? :pretty
|
||||
|
||||
exp = Time.now.to_i + SECONDS_PER_MINUTE * 2
|
||||
payload = {name: "anonymous", exp: exp, jti: Random.uuid}
|
||||
expires_at = Time.at(exp).to_datetime
|
||||
token = JWT.encode payload, JWT_SECRET, "HS256"
|
||||
token = JWT.encode payload, config.jwt_secret.unwrap, "HS256"
|
||||
x = {token: token, expires_at: expires_at}
|
||||
|
||||
jsonify x
|
||||
jsonify x, pretty:
|
||||
end
|
||||
|
||||
get "/token/validate" do
|
||||
token = req_headers["authorization"].split[1]
|
||||
payload = JWT.decode token, JWT_SECRET, true, algorithm: "HS256"
|
||||
payload = JWT.decode token, config.jwt_secret.unwrap, true, algorithm: "HS256"
|
||||
|
||||
jsonify payload
|
||||
end
|
||||
|
@ -15,10 +15,10 @@ type: application
|
||||
# This is the chart version. This version number should be incremented each time you make changes
|
||||
# to the chart and its templates, including the app version.
|
||||
# Versions are expected to follow Semantic Versioning (https://semver.org/)
|
||||
version: 0.2.0
|
||||
version: 0.2.2
|
||||
|
||||
# This is the version number of the application being deployed. This version number should be
|
||||
# incremented each time you make changes to the application. Versions are not expected to
|
||||
# follow Semantic Versioning. They should reflect the version the application is using.
|
||||
# It is recommended to use it with quotes.
|
||||
appVersion: "0.2.0"
|
||||
appVersion: "0.2.2"
|
||||
|
@ -1,34 +1,38 @@
|
||||
ARG RUBY_VERSION="3.4.3"
|
||||
FROM docker.io/library/ruby:${RUBY_VERSION}-alpine AS base
|
||||
|
||||
WORKDIR /kubernaut
|
||||
|
||||
RUN <<EOT
|
||||
apk update -q
|
||||
apk add bash
|
||||
rm -rf /var/cache/apk
|
||||
gem update --system --no-document
|
||||
gem install -N bundler
|
||||
EOT
|
||||
ARG BASE_REGISTRY="docker.io"
|
||||
FROM ${BASE_REGISTRY}/ruby:${RUBY_VERSION}-alpine AS base
|
||||
|
||||
ENV RACK_ENV="production" \
|
||||
BUNDLE_DEPLOYMENT=true \
|
||||
BUNDLE_PATH="/usr/local/bundle" \
|
||||
BUNDLE_WITHOUT="development test"
|
||||
BUNDLE_WITHOUT="development test" \
|
||||
RUBY_YJIT_ENABLE=true
|
||||
|
||||
WORKDIR /kubernaut
|
||||
|
||||
RUN \
|
||||
--mount=type=cache,id=var-cache-apk,target=/var/cache/apk,sharing=locked \
|
||||
apk update -q; \
|
||||
apk add bash jemalloc
|
||||
|
||||
RUN \
|
||||
--mount=type=cache,id=usr-local-bundle-cache,target=${BUNDLE_PATH},sharing=locked \
|
||||
gem update --system --no-document; \
|
||||
gem install -N bundler
|
||||
|
||||
FROM base AS build
|
||||
|
||||
RUN <<EOT
|
||||
apk add musl-dev gcc make
|
||||
rm -rf /var/cache/apk
|
||||
EOT
|
||||
RUN \
|
||||
--mount=type=cache,id=var-cache-apk,target=/var/cache/apk,sharing=locked \
|
||||
apk update -q; \
|
||||
apk add musl-dev gcc make; \
|
||||
apk add bash jemalloc
|
||||
|
||||
COPY Gemfile Gemfile.lock ./
|
||||
|
||||
RUN <<EOT
|
||||
RUN \
|
||||
--mount=type=cache,id=usr-local-bundle-ruby-cache,target=${BUNDLE_PATH}/ruby/3.4.0/cache,sharing=locked \
|
||||
bundle install
|
||||
rm -rf ~/.bundle/ "${BUNDLE_PATH}"/ruby/*/cache "${BUNDLE_PATH}"/ruby/*/bundler/gems/*/.git
|
||||
EOT
|
||||
|
||||
COPY . .
|
||||
|
||||
@ -36,10 +40,9 @@ FROM base
|
||||
|
||||
ENV PORT=4567
|
||||
|
||||
RUN <<EOT
|
||||
addgroup --system --gid 666 kubernaut
|
||||
RUN \
|
||||
addgroup --system --gid 666 kubernaut; \
|
||||
adduser --system --uid 666 --ingroup kubernaut --shell /bin/bash --disabled-password kubernaut
|
||||
EOT
|
||||
|
||||
COPY --from=build "${BUNDLE_PATH}" "${BUNDLE_PATH}"
|
||||
COPY --from=build /kubernaut /kubernaut
|
||||
|
@ -1,34 +1,46 @@
|
||||
ARG RUBY_VERSION="3.4.3"
|
||||
FROM docker.io/library/ruby:${RUBY_VERSION}-slim-bookworm AS base
|
||||
|
||||
WORKDIR /kubernaut
|
||||
|
||||
RUN <<EOT
|
||||
apt-get update -qq
|
||||
rm -rf /var/lib/apt/lists /var/cache/apt/archives
|
||||
gem update --system --no-document
|
||||
gem install -N bundler
|
||||
EOT
|
||||
ARG BASE_REGISTRY="docker.io"
|
||||
ARG DEBIAN_VERSION="bookworm"
|
||||
FROM ${BASE_REGISTRY}/ruby:${RUBY_VERSION}-slim-${DEBIAN_VERSION} AS base
|
||||
|
||||
ENV RACK_ENV="production" \
|
||||
BUNDLE_DEPLOYMENT=true \
|
||||
BUNDLE_PATH="/usr/local/bundle" \
|
||||
BUNDLE_WITHOUT="development test"
|
||||
BUNDLE_WITHOUT="development test" \
|
||||
RUBY_YJIT_ENABLE=true
|
||||
|
||||
WORKDIR /kubernaut
|
||||
|
||||
RUN rm -f /etc/apt/apt.conf.d/docker-clean
|
||||
|
||||
RUN \
|
||||
--mount=type=cache,id=var-cache-apt,target=/var/cache/apt,sharing=locked \
|
||||
--mount=type=cache,id=var-lib-apt,target=/var/lib/apt,sharing=locked \
|
||||
apt-get update -qq; \
|
||||
apt-get install --yes --no-install-recommends \
|
||||
libjemalloc2
|
||||
|
||||
RUN \
|
||||
--mount=type=cache,id=usr-local-bundle-cache,target=${BUNDLE_PATH},sharing=locked \
|
||||
gem update --system --no-document; \
|
||||
gem install -N bundler
|
||||
|
||||
ENV DEBIAN_FRONTEND="noninteractive"
|
||||
|
||||
FROM base AS build
|
||||
|
||||
RUN <<EOT
|
||||
apt-get update -qq
|
||||
apt-get install --yes --no-install-recommends gcc make libc-dev
|
||||
rm -rf /var/lib/apt/lists /var/cache/apt/archives
|
||||
EOT
|
||||
RUN \
|
||||
--mount=type=cache,id=var-cache-apt,target=/var/cache/apt,sharing=locked \
|
||||
--mount=type=cache,id=var-lib-apt,target=/var/lib/apt,sharing=locked \
|
||||
apt-get update -qq; \
|
||||
apt-get install --yes --no-install-recommends \
|
||||
build-essential
|
||||
|
||||
COPY Gemfile Gemfile.lock ./
|
||||
|
||||
RUN <<EOT
|
||||
RUN \
|
||||
--mount=type=cache,id=usr-local-bundle-ruby-cache,target=${BUNDLE_PATH}/ruby/3.4.0/cache,sharing=locked \
|
||||
bundle install
|
||||
rm -rf ~/.bundle/ "${BUNDLE_PATH}"/ruby/*/cache "${BUNDLE_PATH}"/ruby/*/bundler/gems/*/.git
|
||||
EOT
|
||||
|
||||
COPY . .
|
||||
|
||||
@ -36,10 +48,9 @@ FROM base
|
||||
|
||||
ENV PORT=4567
|
||||
|
||||
RUN <<EOT
|
||||
groupadd --system --gid 666 kubernaut
|
||||
RUN \
|
||||
groupadd --system --gid 666 kubernaut; \
|
||||
useradd --system --uid 666 --gid kubernaut --create-home --shell /bin/bash kubernaut
|
||||
EOT
|
||||
|
||||
COPY --from=build "${BUNDLE_PATH}" "${BUNDLE_PATH}"
|
||||
COPY --from=build /kubernaut /kubernaut
|
||||
|
@ -7,4 +7,9 @@ ruby --version
|
||||
printf "rubygems %s\n" "$(gem --version)"
|
||||
bundle version
|
||||
|
||||
if [ -z "${LD_PRELOAD+x}" ]; then
|
||||
LD_PRELOAD="$(find /usr/lib -name libjemalloc.so.2 -print -quit)"
|
||||
export LD_PRELOAD
|
||||
fi
|
||||
|
||||
exec "${@}"
|
||||
|
@ -16,18 +16,24 @@ spec:
|
||||
spec:
|
||||
containers:
|
||||
- name: kubernaut
|
||||
image: git.kill0.net/ryanc/kubernaut:0.2.0
|
||||
image: git.kill0.net/ryanc/kubernaut:0.2.2
|
||||
imagePullPolicy: Always
|
||||
ports:
|
||||
- name: sinatra-web
|
||||
containerPort: 4567
|
||||
env:
|
||||
- name: SESSION_SECRET
|
||||
- name: KUBERNAUT_SESSION_SECRET
|
||||
valueFrom:
|
||||
secretKeyRef:
|
||||
name: kubernaut-session-secret
|
||||
name: kubernaut
|
||||
key: session_secret
|
||||
optional: true
|
||||
- name: KUBERNAUT_JWT_SECRET
|
||||
valueFrom:
|
||||
secretKeyRef:
|
||||
name: kubernaut
|
||||
key: jwt_secret
|
||||
optional: true
|
||||
envFrom:
|
||||
- configMapRef:
|
||||
name: kubernaut-configmap
|
||||
|
@ -3,7 +3,6 @@ apiVersion: kustomize.config.k8s.io/v1beta1
|
||||
kind: Kustomization
|
||||
namespace: kubernaut
|
||||
resources:
|
||||
- secret.yaml
|
||||
- configmap.yaml
|
||||
- deployment.yaml
|
||||
- hpa.yaml
|
||||
|
@ -1,15 +0,0 @@
|
||||
---
|
||||
apiVersion: bitnami.com/v1alpha1
|
||||
kind: SealedSecret
|
||||
metadata:
|
||||
creationTimestamp: null
|
||||
name: kubernaut-session-secret
|
||||
namespace: kubernaut
|
||||
spec:
|
||||
encryptedData:
|
||||
session_secret: AgCY08t0AU418znEZt5d252J+lH+fwYki2g6jdJpfdRfVQjnA+b52P0KWrs/x5pB0PKab6Z3JY/Tz0SQCaoIsCR4IzUO3a095aulRqb6Qr1Lz8udBVta4JJMZLmo26tuUfVHlpD1d6J8rkBSm8vzckFLkOA1Wfl/9rS3K4qwiDogA5pI0ULghFkeEx1yKdRwPq0k8PuvOvLUJ6oNq3e5n+B/BrVWdQ+7XQxUq/AMANJrDbe+RD33f99LArHYA7bFMbY8YRazXSTAkeunpTlxTjuGZKYvJKupo29LHz2OVbZVX/hI0nZkdVpcgqvbxF6Vw9CuCeAmtKYl7A3qsAWqDLUdP3hRLsk2P9RDNhEzYWh4ml8APzziWzihdJbGEjwLy7HsHgKslM0XbBnRQDlxp/JtvcWdjQp33A+QOON32zOKHi+qJjDYyGebS1+xkPbnyb1MPSJVAtFpj7dlLbFekLFDZEbXuJYUl1wKdFOIjJHmNK/MTEV2kOhtiVj/aeKgSXwor9hR7Uxzs5ZSawp9uWw+hpr58EX6I+RtfO4yjFC6FjnagiU6SlI1Q2F7/nv82g1UWTYMpNN5bduS1YFWmsnXvK+W7YQHpSForr5ndtCSHmclbXb5Fc33sywC5u6Bi2Gu5/MW6d73BOog5BC3QtOuEQ044Q+cuU3RIlKADBqKLzZmHlmukyyGuZfXJnGjlWGKp3J1KecucTo6XC9QHpUkjXEKdlE63mOI1VuOGyBIHl60v4bnWiBg+aDZVHipz4JLKsVB0HOgBBK7+tOX6tr1GDG/F7Nz/i9ebzUV6i8Ec1jHf+2ZcTtBkNXBIkHc84+4Qd33/gOuP+lizLfIhfQ3DFWbwyfYumpVbeapyYhB0CE=
|
||||
template:
|
||||
metadata:
|
||||
creationTimestamp: null
|
||||
name: kubernaut-session-secret
|
||||
namespace: kubernaut
|
@ -1,5 +1,8 @@
|
||||
require "sensitive"
|
||||
|
||||
SESSION_SECRET_HEX_LENGTH = 64
|
||||
JWT_SECRET_HEX_LENGTH = 64
|
||||
|
||||
class Config
|
||||
attr_accessor :cat
|
||||
|
||||
@ -9,7 +12,7 @@ class Config
|
||||
@prefix = prefix
|
||||
@cat = cat
|
||||
|
||||
session_secret ||= ENV.fetch "SESSION_SECRET" do
|
||||
session_secret ||= fetch_env "SESSION_SECRET" do
|
||||
SecureRandom.hex SESSION_SECRET_HEX_LENGTH
|
||||
end
|
||||
|
||||
|
Loading…
x
Reference in New Issue
Block a user