diff --git a/CHANGELOG.md b/CHANGELOG.md index cbe472b..9f2774a 100644 --- a/CHANGELOG.md +++ b/CHANGELOG.md @@ -6,15 +6,6 @@ and this project adheres to [Semantic Versioning](https://semver.org/spec/v2.0.0 ## [Unreleased] -## [2.5.0] - 2024-01-16 - -### Added -- Added `/loop-queue` - -## [2.4.4] - 2023-12-21 - -- Optimized Docker container to run JS code directly with node instead of yarn, npm and tsx. Reduces memory usage. - ## [2.4.3] - 2023-09-10 ### Fixed @@ -280,9 +271,7 @@ and this project adheres to [Semantic Versioning](https://semver.org/spec/v2.0.0 ### Added - Initial release -[unreleased]: https://github.com/codetheweb/muse/compare/v2.5.0...HEAD -[2.5.0]: https://github.com/codetheweb/muse/compare/v2.4.4...v2.5.0 -[2.4.4]: https://github.com/codetheweb/muse/compare/v2.4.3...v2.4.4 +[unreleased]: https://github.com/codetheweb/muse/compare/v2.4.3...HEAD [2.4.3]: https://github.com/codetheweb/muse/compare/v2.4.2...v2.4.3 [2.4.2]: https://github.com/codetheweb/muse/compare/v2.4.1...v2.4.2 [2.4.1]: https://github.com/codetheweb/muse/compare/v2.4.0...v2.4.1 diff --git a/Dockerfile b/Dockerfile index a3d20ac..6ec862d 100644 --- a/Dockerfile +++ b/Dockerfile @@ -14,29 +14,18 @@ COPY package.json . COPY yarn.lock . RUN yarn install --prod -RUN cp -R node_modules /usr/app/prod_node_modules - -RUN yarn install - -FROM dependencies AS builder - -COPY . . - -# Run tsc build -RUN yarn prisma generate -RUN yarn build # Only keep what's necessary to run FROM base AS runner WORKDIR /usr/app -COPY --from=builder /usr/app/dist ./dist -COPY --from=dependencies /usr/app/prod_node_modules node_modules -COPY --from=builder /usr/app/node_modules/.prisma/client ./node_modules/.prisma/client +COPY --from=dependencies /usr/app/node_modules node_modules COPY . . +RUN yarn prisma generate + ARG COMMIT_HASH=unknown ARG BUILD_DATE=unknown @@ -45,4 +34,4 @@ ENV NODE_ENV production ENV COMMIT_HASH $COMMIT_HASH ENV BUILD_DATE $BUILD_DATE -CMD ["tini", "--", "node", "--enable-source-maps", "dist/scripts/migrate-and-start.js"] +CMD ["tini", "--", "yarn", "start"] diff --git a/README.md b/README.md index 394af6a..d474a53 100644 --- a/README.md +++ b/README.md @@ -31,9 +31,6 @@ Muse is written in TypeScript. You can either run Muse with Docker (recommended) - `SPOTIFY_CLIENT_ID` and `SPOTIFY_CLIENT_SECRET` can be acquired [here](https://developer.spotify.com/dashboard/applications) with 'Create a Client ID'. - `YOUTUBE_API_KEY` can be acquired by [creating a new project](https://console.developers.google.com) in Google's Developer Console, enabling the YouTube API, and creating an API key under credentials. -> [!WARNING] -> Even if you don't plan on using Spotify, you must still provide the client ID and secret; otherwise Muse will not function. - Muse will log a URL when run. Open this URL in a browser to invite Muse to your server. Muse will DM the server owner after it's added with setup instructions. A 64-bit OS is required to run Muse. diff --git a/package.json b/package.json index 1c91e71..62f38e7 100644 --- a/package.json +++ b/package.json @@ -1,6 +1,6 @@ { "name": "muse", - "version": "2.5.0", + "version": "2.4.3", "description": "🎧 a self-hosted Discord music bot that doesn't suck ", "repository": "git@github.com:codetheweb/muse.git", "author": "Max Isom ", @@ -26,8 +26,7 @@ "migrations:run": "npm run prisma:with-env migrate deploy", "prisma:with-env": "npm run env:set-database-url prisma", "env:set-database-url": "tsx src/scripts/run-with-database-url.ts", - "release": "release-it", - "build": "tsc" + "release": "release-it" }, "devDependencies": { "@release-it/keep-a-changelog": "^2.3.0", diff --git a/src/commands/config.ts b/src/commands/config.ts index ae3bc45..158f4f4 100644 --- a/src/commands/config.ts +++ b/src/commands/config.ts @@ -3,7 +3,7 @@ import {ChatInputCommandInteraction, EmbedBuilder, PermissionFlagsBits} from 'di import {injectable} from 'inversify'; import {prisma} from '../utils/db.js'; import Command from './index.js'; -import {getGuildSettings} from '../utils/get-guild-settings.js'; +import {getGuildSettings} from '../utils/get-guild-settings'; @injectable() export default class implements Command { diff --git a/src/commands/loop-queue.ts b/src/commands/loop-queue.ts deleted file mode 100644 index 47b9adf..0000000 --- a/src/commands/loop-queue.ts +++ /dev/null @@ -1,42 +0,0 @@ -import {ChatInputCommandInteraction} from 'discord.js'; -import {TYPES} from '../types.js'; -import {inject, injectable} from 'inversify'; -import PlayerManager from '../managers/player.js'; -import Command from '.'; -import {SlashCommandBuilder} from '@discordjs/builders'; -import {STATUS} from '../services/player.js'; - -@injectable() -export default class implements Command { - public readonly slashCommand = new SlashCommandBuilder() - .setName('loop-queue') - .setDescription('toggle looping the entire queue'); - - public requiresVC = true; - - private readonly playerManager: PlayerManager; - - constructor(@inject(TYPES.Managers.Player) playerManager: PlayerManager) { - this.playerManager = playerManager; - } - - public async execute(interaction: ChatInputCommandInteraction): Promise { - const player = this.playerManager.get(interaction.guild!.id); - - if (player.status === STATUS.IDLE) { - throw new Error('no songs to loop!'); - } - - if (player.queueSize() < 2) { - throw new Error('not enough songs to loop a queue!'); - } - - if (player.loopCurrentSong) { - player.loopCurrentSong = false; - } - - player.loopCurrentQueue = !player.loopCurrentQueue; - - await interaction.reply((player.loopCurrentQueue ? 'looped queue :)' : 'stopped looping queue :(')); - } -} diff --git a/src/commands/loop.ts b/src/commands/loop.ts index f654237..3b609a5 100644 --- a/src/commands/loop.ts +++ b/src/commands/loop.ts @@ -4,7 +4,7 @@ import {inject, injectable} from 'inversify'; import PlayerManager from '../managers/player.js'; import Command from '.'; import {SlashCommandBuilder} from '@discordjs/builders'; -import {STATUS} from '../services/player.js'; +import {STATUS} from '../services/player'; @injectable() export default class implements Command { @@ -27,10 +27,6 @@ export default class implements Command { throw new Error('no song to loop!'); } - if (player.loopCurrentQueue) { - player.loopCurrentQueue = false; - } - player.loopCurrentSong = !player.loopCurrentSong; await interaction.reply((player.loopCurrentSong ? 'looped :)' : 'stopped looping :(')); diff --git a/src/events/voice-state-update.ts b/src/events/voice-state-update.ts index 15784db..e941a70 100644 --- a/src/events/voice-state-update.ts +++ b/src/events/voice-state-update.ts @@ -3,7 +3,7 @@ import container from '../inversify.config.js'; import {TYPES} from '../types.js'; import PlayerManager from '../managers/player.js'; import {getSizeWithoutBots} from '../utils/channels.js'; -import {getGuildSettings} from '../utils/get-guild-settings.js'; +import {getGuildSettings} from '../utils/get-guild-settings'; export default async (oldState: VoiceState, _: VoiceState): Promise => { const playerManager = container.get(TYPES.Managers.Player); diff --git a/src/inversify.config.ts b/src/inversify.config.ts index d0694cf..1a3b85c 100644 --- a/src/inversify.config.ts +++ b/src/inversify.config.ts @@ -21,8 +21,7 @@ import Config from './commands/config.js'; import Disconnect from './commands/disconnect.js'; import Favorites from './commands/favorites.js'; import ForwardSeek from './commands/fseek.js'; -import LoopQueue from './commands/loop-queue.js'; -import Loop from './commands/loop.js'; +import Loop from './commands/loop'; import Move from './commands/move.js'; import Next from './commands/next.js'; import NowPlaying from './commands/now-playing.js'; @@ -69,7 +68,6 @@ container.bind(TYPES.Services.SpotifyAPI).to(SpotifyAPI).inSingleton Disconnect, Favorites, ForwardSeek, - LoopQueue, Loop, Move, Next, diff --git a/src/scripts/migrate-and-start.ts b/src/scripts/migrate-and-start.ts index 41197e4..d971745 100644 --- a/src/scripts/migrate-and-start.ts +++ b/src/scripts/migrate-and-start.ts @@ -9,13 +9,11 @@ import Prisma from '@prisma/client'; import ora from 'ora'; import {startBot} from '../index.js'; import logBanner from '../utils/log-banner.js'; -import createDatabaseUrl, {createDatabasePath} from '../utils/create-database-url.js'; +import {createDatabasePath} from '../utils/create-database-url.js'; import {DATA_DIR} from '../services/config.js'; const client = new Prisma.PrismaClient(); -process.env.DATABASE_URL = process.env.DATABASE_URL ?? createDatabaseUrl(DATA_DIR); - const migrateFromSequelizeToPrisma = async () => { await execa('prisma', ['migrate', 'resolve', '--applied', '20220101155430_migrate_from_sequelize'], {preferLocal: true}); }; diff --git a/src/services/add-query-to-queue.ts b/src/services/add-query-to-queue.ts index 24f7228..744f3c0 100644 --- a/src/services/add-query-to-queue.ts +++ b/src/services/add-query-to-queue.ts @@ -9,7 +9,7 @@ import {SongMetadata, STATUS} from './player.js'; import PlayerManager from '../managers/player.js'; import {buildPlayingMessageEmbed} from '../utils/build-embed.js'; import {getMemberVoiceChannel, getMostPopularVoiceChannel} from '../utils/channels.js'; -import {getGuildSettings} from '../utils/get-guild-settings.js'; +import {getGuildSettings} from '../utils/get-guild-settings'; @injectable() export default class AddQueryToQueue { diff --git a/src/services/get-songs.ts b/src/services/get-songs.ts index b957734..1c68e7e 100644 --- a/src/services/get-songs.ts +++ b/src/services/get-songs.ts @@ -1,6 +1,6 @@ import {inject, injectable} from 'inversify'; import * as spotifyURI from 'spotify-uri'; -import {SongMetadata, QueuedPlaylist, MediaSource} from './player.js'; +import {SongMetadata, QueuedPlaylist, MediaSource} from './player'; import {TYPES} from '../types.js'; import ffmpeg from 'fluent-ffmpeg'; import YoutubeAPI from './youtube-api.js'; diff --git a/src/services/player.ts b/src/services/player.ts index c17a536..c888896 100644 --- a/src/services/player.ts +++ b/src/services/player.ts @@ -18,7 +18,7 @@ import { } from '@discordjs/voice'; import FileCacheProvider from './file-cache.js'; import debug from '../utils/debug.js'; -import {getGuildSettings} from '../utils/get-guild-settings.js'; +import {getGuildSettings} from '../utils/get-guild-settings'; export enum MediaSource { Youtube, @@ -63,7 +63,6 @@ export default class { public status = STATUS.PAUSED; public guildId: string; public loopCurrentSong = false; - public loopCurrentQueue = false; private queue: QueuedSong[] = []; private queuePosition = 0; @@ -546,17 +545,6 @@ export default class { return; } - // Automatically re-add current song to queue - if (this.loopCurrentQueue && newState.status === AudioPlayerStatus.Idle && this.status === STATUS.PLAYING) { - const currentSong = this.getCurrent(); - - if (currentSong) { - this.add(currentSong); - } else { - throw new Error('No song currently playing.'); - } - } - if (newState.status === AudioPlayerStatus.Idle && this.status === STATUS.PLAYING) { await this.forward(1); } diff --git a/src/utils/build-embed.ts b/src/utils/build-embed.ts index d851e3f..e4159b6 100644 --- a/src/utils/build-embed.ts +++ b/src/utils/build-embed.ts @@ -46,7 +46,7 @@ const getPlayerUI = (player: Player) => { const button = player.status === STATUS.PLAYING ? 'âšī¸' : 'â–ļī¸'; const progressBar = getProgressBar(15, position / song.length); const elapsedTime = song.isLive ? 'live' : `${prettyTime(position)}/${prettyTime(song.length)}`; - const loop = player.loopCurrentSong ? '🔂' : player.loopCurrentQueue ? '🔁' : ''; + const loop = player.loopCurrentSong ? '🔁' : ''; return `${button} ${progressBar} \`[${elapsedTime}]\` 🔉 ${loop}`; }; diff --git a/src/utils/get-guild-settings.ts b/src/utils/get-guild-settings.ts index 3d9e965..f001aab 100644 --- a/src/utils/get-guild-settings.ts +++ b/src/utils/get-guild-settings.ts @@ -1,6 +1,6 @@ import {Setting} from '@prisma/client'; -import {prisma} from './db.js'; -import {createGuildSettings} from '../events/guild-create.js'; +import {prisma} from './db'; +import {createGuildSettings} from '../events/guild-create'; export async function getGuildSettings(guildId: string): Promise { const config = await prisma.setting.findUnique({where: {guildId}}); diff --git a/tsconfig.json b/tsconfig.json index 5685334..c02ad2f 100644 --- a/tsconfig.json +++ b/tsconfig.json @@ -9,7 +9,7 @@ "esModuleInterop": true, "sourceMap": true, "resolveJsonModule": true, - "outDir": "dist" + "noEmit": true }, "include": ["src"], "exclude": ["node_modules"]