openapi! yay

This commit is contained in:
Reid 2025-08-03 20:42:31 -07:00
parent b560060b45
commit 171ed10479
Signed by: reidlab
GPG key ID: DAF5EAF6665839FD
16 changed files with 519 additions and 341 deletions

View file

@ -2,19 +2,32 @@ import { appleMusicApi } from "../../../appleMusicApi/index.js";
import express from "express";
import { validate } from "../../validate.js";
import { z } from "zod";
import { paths } from "../../openApi.js";
const router = express.Router();
const path = "/getTrackMetadata";
const schema = z.object({
query: z.object({
id: z.string()
})
});
paths[path] = {
get: {
requestParams: { query: schema.shape.query },
responses: {
200: { description: "returns from the apple music api, track metadata with `extendedAssetUrls` extension and `albums` relationship https://developer.apple.com/documentation/applemusicapi/get-a-catalog-song" },
400: { description: "bad request, invalid query parameters. sent as a zod error with details" },
default: { description: "upstream api error, or some other error" }
}
}
};
// this endpoint isn't actually used for anything by us
// it's for people who want to implement apple music downloading into their own apps (ex. discord music bot)
// it makes it a bit easier to get the metadata for a track knowing the trackId
router.get("/getTrackMetadata", async (req, res, next) => {
router.get(path, async (req, res, next) => {
try {
const { id } = (await validate(req, schema)).query;