ollama/web/app/api/update/route.ts

44 lines
1.2 KiB
TypeScript
Raw Normal View History

2023-07-06 00:04:06 -04:00
import { NextResponse } from 'next/server'
import semver from 'semver'
export async function GET(req: Request) {
const { searchParams } = new URL(req.url)
const os = searchParams.get('os') || 'darwin'
const version = searchParams.get('version') || '0.0.0'
2023-07-06 00:04:06 -04:00
2023-07-06 16:18:40 -04:00
if (!version) {
return new Response('not found', { status: 404 })
}
const res = await fetch('https://api.github.com/repos/jmorganca/ollama/releases', { next: { revalidate: 60 } })
const data = await res.json()
2023-07-25 17:11:50 -04:00
const latest = data?.filter((f: any) => !f.prerelease)?.[0]
if (!latest) {
return new Response('not found', { status: 404 })
}
const assets = latest.assets || []
2023-07-06 00:04:06 -04:00
if (assets.length === 0) {
return new Response('not found', { status: 404 })
}
2023-07-06 00:04:06 -04:00
// todo: get the correct asset for the current arch/os
const asset = assets.find((a: any) => a.name.toLowerCase().includes(os) && a.name.toLowerCase().includes('.zip'))
2023-07-06 00:04:06 -04:00
if (!asset) {
return new Response('not found', { status: 404 })
}
2023-07-06 16:18:40 -04:00
console.log(asset)
2023-07-06 00:04:06 -04:00
if (semver.lt(version, latest.tag_name)) {
return NextResponse.json({ version: data.tag_name, url: asset.browser_download_url })
2023-07-06 00:04:06 -04:00
}
return new Response(null, { status: 204 })
2023-07-06 00:04:06 -04:00
}