6 Commits

Author SHA1 Message Date
Patryk Koreń
20a36703e6 added loop 2026-02-12 17:51:08 +01:00
Patryk Koreń
f9f0ba9b1f Manualne pobieranie yt-dlp bo yt rozjebał pobieranie we wcześniejszej wersji 2026-02-01 14:18:18 +01:00
Patryk Koreń
d60cd75786 fix history 2026-01-29 17:43:43 +01:00
Patryk Koreń
cbf39d2bae added history 2026-01-27 21:27:36 +01:00
Patryk Koreń
bb2b31bb61 ci11
Some checks failed
Build and Push Docker Image / build-image (push) Failing after 31s
2026-01-07 23:03:22 +01:00
Patryk Koreń
cdbf448291 ci testy 2026-01-07 22:19:12 +01:00
9 changed files with 160 additions and 24 deletions

View File

@@ -1,33 +1,44 @@
name: Build and Push Docker Image
on:
on:
push:
tags:
- '*' # Trigger on any Git tag
- '*' # Trigger on any git tag
jobs:
docker:
build-image:
runs-on: ubuntu-latest
container:
image: docker:rc-dind
steps:
- name: Install dedps
run: |
apk add --no-cache nodejs npm git
- name: Checkout code
uses: actions/checkout@v3
- name: Set up Docker Buildx
uses: docker/setup-buildx-action@v3
- name: Build container image
env:
IMAGE_NAME: papryk/dj-spangebob
TAG: ${{ github.ref_name }}
run: |
docker build -t "$IMAGE_NAME:$TAG" .
- name: Log in to Docker registry
uses: docker/login-action@v2
with:
registry: ${{ env.GITEA_REGISTRY }}
username: ${{ secrets.GITEA_REGISTRY_USERNAME }}
password: ${{ secrets.GITEA_REGISTRY_PASSWORD }}
env:
REGISTRY: https://gitea.papryk.com
REGISTRY_USERNAME: ${{ secrets.REGISTRY_USERNAME }}
REGISTRY_PASSWORD: ${{ secrets.REGISTRY_PASSWORD }}
run: |
echo "$REGISTRY_PASSWORD" | docker "$REGISTRY" -u "$REGISTRY_USERNAME" --password-stdin
- name: Build and push Docker image
uses: docker/build-push-action@v5
with:
context: .
push: true
tags: |
${{ env.GITEA_REGISTRY }}/${{ github.repository_owner }}/${{ github.repo }}:${{ github.ref_name }}
env:
REGISTRY: https://gitea.papryk.com
IMAGE_NAME: Papryk/dj-spangebob
TAG: ${{ github.ref_name }}
run: |
docker push "$REGISTRY/$IMAGE_NAME:$TAG"

View File

@@ -1,6 +1,9 @@
FROM node:20-alpine
FROM node:22-alpine
RUN apk add --no-cache ffmpeg yt-dlp
RUN apk add --no-cache wget ffmpeg #yt-dlp
RUN wget -P /tmp https://github.com/yt-dlp/yt-dlp/releases/download/2026.01.31/yt-dlp_musllinux
RUN mv /tmp/yt-dlp_musllinux /usr/bin/yt-dlp
RUN chmod 777 /usr/bin/yt-dlp
WORKDIR /app

36
history/29-01-2026.json Normal file
View File

@@ -0,0 +1,36 @@
[
{
"interaction": {
"type": 2,
"id": "1466473802148872486",
"applicationId": "887789346277691402",
"channelId": "470712099753164811",
"guildId": "343827205878710273",
"user": "264739894641950720",
"member": "264739894641950720",
"version": 1,
"appPermissions": "2230881414020816",
"memberPermissions": "2230883322429171",
"locale": "pl",
"guildLocale": "en-US",
"entitlements": [],
"authorizingIntegrationOwners": {
"0": "343827205878710273"
},
"context": 0,
"attachmentSizeLimit": 10485760,
"commandId": "1452614990078021710",
"commandName": "play",
"commandType": 1,
"commandGuildId": null,
"deferred": true,
"replied": true,
"ephemeral": false,
"webhook": {
"id": "887789346277691402"
},
"options": {}
},
"url": "https://soundcloud.com/musicbymoonlght/4th-of-july-rock-x-house-mix-by-moonlght-vol-2?si=93777764ee5c404db6f3fb3c6dc347d8&utm_source=clipboard&utm_medium=text&utm_campaign=social_sharing"
}
]

View File

@@ -7,6 +7,7 @@ import queue from "./queue"
import resume from "./resume"
import skip from "./skip"
import stop from "./stop"
import loop from "./loop"
export const commands: { [key: string]: Command } = {
ping,
@@ -18,5 +19,6 @@ export const commands: { [key: string]: Command } = {
stop,
pause,
skip,
loop,
}

34
src/commands/loop.ts Normal file
View File

@@ -0,0 +1,34 @@
import { CacheType, ChatInputCommandInteraction, SlashCommandBuilder } from 'discord.js';
import { toggleLoop } from '../playback';
import { formatFilePath } from '../util/downloader'
const name = "loop"
function register() {
return new SlashCommandBuilder()
.setName(name)
.setDescription('loop current song')
}
async function execute(interaction: ChatInputCommandInteraction<CacheType>) {
try {
await interaction.deferReply()
const audio = toggleLoop()
if (audio) {
await interaction.editReply(`looped ${formatFilePath(audio.url)}`);
}
else {
await interaction.editReply(`Loop turned off`);
}
} catch (error) {
console.error(error);
await interaction.reply('Coś poszło nie tak :/');
}
}
export default {
name,
register,
execute
}

10
src/global.d.ts vendored
View File

@@ -10,7 +10,13 @@ type AudioFile = {
}
type Queue = {
songList: AudioFile[],
current: AudioFile | null,
songList: AudioFile[]
current: AudioFile | null
loop: AudioFile | null
}
type HistoryObject = {
interaction: ChatInputCommandInteraction<CacheType>
url: string
}

View File

@@ -9,6 +9,7 @@ import { updatePlayer } from './playback';
import SpotifyWebApi from 'spotify-web-api-node';
export const DATA_DIR = "./data";
export const HISTORY_DIR_PATH = process.env.HISTORY_DIR_PATH ?? "./history";
// AUDIO
export const player = createAudioPlayer();

View File

@@ -3,20 +3,30 @@ import { player } from "./main";
import { CacheType, ChatInputCommandInteraction } from "discord.js";
import { getAudioFile } from "./util/downloader";
import { playSong } from "./util/helpers";
import { add_to_history } from "./util/history";
const queue: Queue = {
songList: [],
current: null
current: null,
loop: null,
}
export function toggleLoop(): AudioFile | null {
if (queue.loop) queue.loop = null
else queue.loop = queue.current
return queue.loop
}
export async function requestSong(
interaction: ChatInputCommandInteraction<CacheType>,
url: string) {
url: string,
user?: any
) {
const path = await getAudioFile(url)
queue.songList.push({ path, url })
add_to_history({ interaction, url })
updatePlayer()
}
export async function forceRequestSong(
@@ -33,7 +43,7 @@ export async function forceRequestSong(
export async function updatePlayer() {
if (player.state.status === AudioPlayerStatus.Idle) {
const nextSong = queue.songList.shift()
const nextSong = queue.loop ?? queue.songList.shift()
if (!nextSong) {
queue.current = null
return

33
src/util/history.ts Normal file
View File

@@ -0,0 +1,33 @@
import path from "node:path";
import fs from "node:fs";
import { HISTORY_DIR_PATH } from "../main";
export async function add_to_history(history: HistoryObject) {
const today = new Date();
const day = String(today.getDate()).padStart(2, '0');
const month = String(today.getMonth() + 1).padStart(2, '0');
const year = today.getFullYear();
const file_name = `${day}-${month}-${year}.json`;
const file_path = path.join(HISTORY_DIR_PATH, file_name)
if (!fs.existsSync(HISTORY_DIR_PATH)) {
fs.mkdirSync(HISTORY_DIR_PATH);
}
let data = [];
try {
const content = fs.readFileSync(file_path, 'utf8');
data = JSON.parse(content);
} catch (err) {
data = [];
}
data.push(history)
fs.writeFileSync(file_path, JSON.stringify(data, (key, value) => {
return typeof value === "bigint" ? value.toString() : value
}, 2));
}