Merge branch 'master' into users-fix2
This commit is contained in:
commit
5e90e4487f
8
.dockerignore
Normal file
8
.dockerignore
Normal file
@ -0,0 +1,8 @@
|
|||||||
|
.github/
|
||||||
|
.husky/
|
||||||
|
.idea/
|
||||||
|
.vscode/
|
||||||
|
|
||||||
|
node_modules/
|
||||||
|
dist/
|
||||||
|
files/
|
||||||
50
.github/workflows/publish-image.yml
vendored
Normal file
50
.github/workflows/publish-image.yml
vendored
Normal 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
75
Dockerfile
Normal 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.
@ -4,8 +4,8 @@ export enum StickerType {
|
|||||||
}
|
}
|
||||||
|
|
||||||
export enum StickerFormatType {
|
export enum StickerFormatType {
|
||||||
GIF = 0, // gif is a custom format type and not in discord spec
|
|
||||||
PNG = 1,
|
PNG = 1,
|
||||||
APNG = 2,
|
APNG = 2,
|
||||||
LOTTIE = 3,
|
LOTTIE = 3,
|
||||||
|
GIF = 4,
|
||||||
}
|
}
|
||||||
|
|||||||
@ -53,7 +53,7 @@ export class ApplicationCommand extends BaseClass {
|
|||||||
@Column({ nullable: true, type: "simple-json" })
|
@Column({ nullable: true, type: "simple-json" })
|
||||||
description_localizations?: Record<string, string>;
|
description_localizations?: Record<string, string>;
|
||||||
|
|
||||||
@Column({ type: "simple-json", default: [] })
|
@Column({ type: "simple-json", default: "[]" })
|
||||||
options: ApplicationCommandOption[];
|
options: ApplicationCommandOption[];
|
||||||
|
|
||||||
@Column({ nullable: true, type: String })
|
@Column({ nullable: true, type: String })
|
||||||
|
|||||||
@ -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;`);
|
||||||
|
}
|
||||||
|
}
|
||||||
Reference in New Issue
Block a user