49 lines
No EOL
1.2 KiB
TypeScript
49 lines
No EOL
1.2 KiB
TypeScript
import { NextResponse } from 'next/server'
|
|
|
|
export const runtime = 'edge';
|
|
|
|
/**
|
|
* Fetch currently playing music from ListenBrainz
|
|
*
|
|
* Returns the most recent listening data for the configured user.
|
|
* Requires LISTENBRAINZ_TOKEN environment variable to be set.
|
|
*
|
|
* @returns {Promise<NextResponse>} ListenBrainz listening data with track metadata
|
|
*
|
|
* @example
|
|
* // Response structure
|
|
* {
|
|
* payload: {
|
|
* count: 1,
|
|
* listens: [{
|
|
* playing_now: true,
|
|
* track_metadata: {
|
|
* artist_name: "Daft Punk",
|
|
* track_name: "Get Lucky",
|
|
* release_name: "Random Access Memories"
|
|
* }
|
|
* }]
|
|
* }
|
|
* }
|
|
*
|
|
* @category API
|
|
*/
|
|
export async function GET() {
|
|
try {
|
|
const response = await fetch("https://api.listenbrainz.org/1/user/p0ntus/playing-now", {
|
|
headers: {
|
|
Authorization: `Token ${process.env.LISTENBRAINZ_TOKEN}`,
|
|
},
|
|
})
|
|
|
|
if (!response.ok) {
|
|
throw new Error(`HTTP error! Status: ${response.status}`)
|
|
}
|
|
|
|
const data = await response.json()
|
|
return NextResponse.json(data)
|
|
} catch (error) {
|
|
console.error('Error fetching now playing:', error)
|
|
return NextResponse.json({ error: 'Failed to fetch now playing data' }, { status: 500 })
|
|
}
|
|
} |