mirror of
https://github.com/th-ch/youtube-music.git
synced 2026-01-11 10:31:47 +00:00
feat(api-server): Improved api-server volume and like/dislike state (#3592)
Co-authored-by: Copilot <175728472+Copilot@users.noreply.github.com> Co-authored-by: rewhex <gitea@cluser.local> Co-authored-by: JellyBrick <shlee1503@naver.com>
This commit is contained in:
@ -4,6 +4,12 @@ import { ipcMain } from 'electron';
|
||||
|
||||
import getSongControls from '@/providers/song-controls';
|
||||
|
||||
import {
|
||||
LikeType,
|
||||
type RepeatMode,
|
||||
type VolumeState,
|
||||
} from '@/types/datahost-get-state';
|
||||
|
||||
import {
|
||||
AddSongToQueueSchema,
|
||||
GoBackSchema,
|
||||
@ -20,7 +26,6 @@ import {
|
||||
type ResponseSongInfo,
|
||||
} from '../scheme';
|
||||
|
||||
import type { RepeatMode } from '@/types/datahost-get-state';
|
||||
import type { SongInfo } from '@/providers/song-info';
|
||||
import type { BackendContext } from '@/types/contexts';
|
||||
import type { APIServerConfig } from '../../config';
|
||||
@ -87,6 +92,24 @@ const routes = {
|
||||
},
|
||||
},
|
||||
}),
|
||||
getLikeState: createRoute({
|
||||
method: 'get',
|
||||
path: `/api/${API_VERSION}/like-state`,
|
||||
summary: 'get like state',
|
||||
description: 'Get the current like state',
|
||||
responses: {
|
||||
200: {
|
||||
description: 'Success',
|
||||
content: {
|
||||
'application/json': {
|
||||
schema: z.object({
|
||||
state: z.enum(LikeType).nullable(),
|
||||
}),
|
||||
},
|
||||
},
|
||||
},
|
||||
},
|
||||
}),
|
||||
like: createRoute({
|
||||
method: 'post',
|
||||
path: `/api/${API_VERSION}/like`,
|
||||
@ -274,6 +297,7 @@ const routes = {
|
||||
'application/json': {
|
||||
schema: z.object({
|
||||
state: z.number(),
|
||||
isMuted: z.boolean(),
|
||||
}),
|
||||
},
|
||||
},
|
||||
@ -526,12 +550,15 @@ const routes = {
|
||||
}),
|
||||
};
|
||||
|
||||
type PromiseOrValue<T> = T | Promise<T>;
|
||||
|
||||
export const register = (
|
||||
app: HonoApp,
|
||||
{ window }: BackendContext<APIServerConfig>,
|
||||
songInfoGetter: () => SongInfo | undefined,
|
||||
repeatModeGetter: () => RepeatMode | undefined,
|
||||
volumeGetter: () => number | undefined,
|
||||
songInfoGetter: () => PromiseOrValue<SongInfo | undefined>,
|
||||
repeatModeGetter: () => PromiseOrValue<RepeatMode | undefined>,
|
||||
likeTypeGetter: () => PromiseOrValue<LikeType | undefined>,
|
||||
volumeStateGetter: () => PromiseOrValue<VolumeState | undefined>,
|
||||
) => {
|
||||
const controller = getSongControls(window);
|
||||
|
||||
@ -565,6 +592,10 @@ export const register = (
|
||||
ctx.status(204);
|
||||
return ctx.body(null);
|
||||
});
|
||||
app.openapi(routes.getLikeState, async (ctx) => {
|
||||
ctx.status(200);
|
||||
return ctx.json({ state: (await likeTypeGetter()) ?? null });
|
||||
});
|
||||
app.openapi(routes.like, (ctx) => {
|
||||
controller.like();
|
||||
|
||||
@ -624,9 +655,9 @@ export const register = (
|
||||
return ctx.body(null);
|
||||
});
|
||||
|
||||
app.openapi(routes.repeatMode, (ctx) => {
|
||||
app.openapi(routes.repeatMode, async (ctx) => {
|
||||
ctx.status(200);
|
||||
return ctx.json({ mode: repeatModeGetter() ?? null });
|
||||
return ctx.json({ mode: (await repeatModeGetter()) ?? null });
|
||||
});
|
||||
app.openapi(routes.switchRepeat, (ctx) => {
|
||||
const { iteration } = ctx.req.valid('json');
|
||||
@ -642,9 +673,11 @@ export const register = (
|
||||
ctx.status(204);
|
||||
return ctx.body(null);
|
||||
});
|
||||
app.openapi(routes.getVolumeState, (ctx) => {
|
||||
app.openapi(routes.getVolumeState, async (ctx) => {
|
||||
ctx.status(200);
|
||||
return ctx.json({ state: volumeGetter() ?? 0 });
|
||||
return ctx.json(
|
||||
(await volumeStateGetter()) ?? { state: 0, isMuted: false },
|
||||
);
|
||||
});
|
||||
app.openapi(routes.setFullscreen, (ctx) => {
|
||||
const { state } = ctx.req.valid('json');
|
||||
@ -678,8 +711,8 @@ export const register = (
|
||||
return ctx.json({ state: fullscreen });
|
||||
});
|
||||
|
||||
const songInfo = (ctx: Context) => {
|
||||
const info = songInfoGetter();
|
||||
const songInfo = async (ctx: Context) => {
|
||||
const info = await songInfoGetter();
|
||||
|
||||
if (!info) {
|
||||
ctx.status(204);
|
||||
|
||||
Reference in New Issue
Block a user