Merge branch 'master' into users-fix2

This commit is contained in:
Cyber 2025-11-09 19:40:27 +01:00 committed by GitHub
commit 5e90e4487f
No known key found for this signature in database
GPG Key ID: B5690EEEBB952194
8 changed files with 146 additions and 2 deletions

8
.dockerignore Normal file
View File

@ -0,0 +1,8 @@
.github/
.husky/
.idea/
.vscode/
node_modules/
dist/
files/

50
.github/workflows/publish-image.yml vendored Normal file
View File

@ -0,0 +1,50 @@
name: Publish Image
on:
release:
types: [published]
env:
REGISTRY: ghcr.io
IMAGE_NAME: ${{ github.repository }}
jobs:
build-and-push-image:
runs-on: ubuntu-latest
permissions:
contents: read
packages: write
attestations: write
id-token: write
steps:
- name: Checkout repository
uses: actions/checkout@v5
- name: Log in to the Container registry
uses: docker/login-action@v3
with:
registry: ${{ env.REGISTRY }}
username: ${{ github.actor }}
password: ${{ secrets.GITHUB_TOKEN }}
- name: Extract metadata (tags, labels) for Docker
id: meta
uses: docker/metadata-action@v5
with:
images: ${{ env.REGISTRY }}/${{ env.IMAGE_NAME }}
- name: Build and push Docker image
id: push
uses: docker/build-push-action@v6
with:
context: .
push: true
tags: ${{ steps.meta.outputs.tags }}
labels: ${{ steps.meta.outputs.labels }}
- name: Generate artifact attestation
uses: actions/attest-build-provenance@v3
with:
subject-name: ${{ env.REGISTRY }}/${{ env.IMAGE_NAME}}
subject-digest: ${{ steps.push.outputs.digest }}
push-to-registry: true

75
Dockerfile Normal file
View File

@ -0,0 +1,75 @@
ARG DEBIAN_CODE=trixie
ARG NODE_VERSION=24
ARG PYTHON_VERSION=3.13
ARG USER_NAME=spacebar
ARG USER_GROUP=$USER_NAME
ARG USER_UID=1000
ARG USER_GID=1000
ARG BASEDIR=/spacebar
FROM python:${PYTHON_VERSION}-slim-${DEBIAN_CODE} AS base_python
FROM node:${NODE_VERSION}-${DEBIAN_CODE}-slim AS base
COPY --from=base_python /usr/local/bin/python* /usr/local/bin/
COPY --from=base_python /usr/local/bin/pip* /usr/local/bin/
COPY --from=base_python /usr/local/lib/python* /usr/local/lib/
COPY --from=base_python /usr/local/lib/libpython* /usr/local/lib/
FROM base AS builder
ARG BRANCH
WORKDIR /build
RUN apt-get update && \
apt-get install -y --no-install-recommends build-essential pkg-config && \
rm -rf /var/lib/apt/lists/*
WORKDIR /build/server
COPY . .
RUN npm i \
&& npm run setup
FROM base AS final
ARG USER_NAME
ARG USER_GROUP
ARG USER_UID
ARG USER_GID
ARG BASEDIR
RUN mkdir -p "${BASEDIR}/server" \
&& chown -R "${USER_UID}:${USER_GID}" "${BASEDIR}"
RUN deluser node 2>/dev/null || true \
&& delgroup node 2>/dev/null || true \
&& rm -fr /home/node 2>/dev/null || true \
&& addgroup --gid "$USER_GID" "$USER_GROUP" \
&& adduser \
--disabled-password \
--gecos "" \
--uid "$USER_UID" \
--gid "$USER_GID" \
--no-create-home \
"$USER_NAME"
USER ${USER_NAME}
#@todo: only bring what we need
COPY --chown=${USER_NAME}:${USER_GROUP} --from=builder /build/server "${BASEDIR}/server"
ENV PORT="3001"
ENV CONFIG_PATH="${BASEDIR}/config.json"
ENV DATABASE="${BASEDIR}/database.db"
WORKDIR "${BASEDIR}/server"
ENTRYPOINT [ "npm", "run" ]
CMD [ "start" ]

Binary file not shown.

Binary file not shown.

View File

@ -4,8 +4,8 @@ export enum StickerType {
}
export enum StickerFormatType {
GIF = 0, // gif is a custom format type and not in discord spec
PNG = 1,
APNG = 2,
LOTTIE = 3,
GIF = 4,
}

View File

@ -53,7 +53,7 @@ export class ApplicationCommand extends BaseClass {
@Column({ nullable: true, type: "simple-json" })
description_localizations?: Record<string, string>;
@Column({ type: "simple-json", default: [] })
@Column({ type: "simple-json", default: "[]" })
options: ApplicationCommandOption[];
@Column({ nullable: true, type: String })

View File

@ -0,0 +1,11 @@
import { MigrationInterface, QueryRunner } from "typeorm";
export class FixGifStickersFormatType1762611552514 implements MigrationInterface {
public async up(queryRunner: QueryRunner): Promise<void> {
await queryRunner.query(`UPDATE "stickers" SET "format_type" = 4 WHERE "format_type" = 0;`);
}
public async down(queryRunner: QueryRunner): Promise<void> {
await queryRunner.query(`UPDATE "stickers" SET "format_type" = 0 WHERE "format_type" = 4;`);
}
}