49 lines
1.5 KiB
TypeScript
49 lines
1.5 KiB
TypeScript
|
import type { SegmentResponse } from '@futureporn/types'
|
||
|
import { configs } from '../../../services/capture/src/config.ts'
|
||
|
|
||
|
|
||
|
/**
|
||
|
* updateSegmentInDatabase
|
||
|
*
|
||
|
* updates the segment in the database with the new filesize
|
||
|
*
|
||
|
* resolves with the updated segment and the is_recording_aborted column of the related vod
|
||
|
*/
|
||
|
export default async function updateSegmentInDatabase({
|
||
|
segment_id,
|
||
|
fileSize,
|
||
|
}: {
|
||
|
segment_id: string,
|
||
|
fileSize: number,
|
||
|
}): Promise<SegmentResponse> {
|
||
|
|
||
|
const payload: any = {
|
||
|
bytes: fileSize
|
||
|
}
|
||
|
|
||
|
const fetchUrl =`${configs.postgrestUrl}/segments?id=eq.${segment_id}&select=vod:vods(is_recording_aborted)`
|
||
|
console.info(`updateSegmentInDatabase > fetchUrl=${fetchUrl}`)
|
||
|
const res = await fetch(fetchUrl, {
|
||
|
method: 'PATCH',
|
||
|
headers: {
|
||
|
'Content-Type': 'application/json',
|
||
|
'Accept': 'application/json',
|
||
|
'Prefer': 'return=representation',
|
||
|
'Authorization': `Bearer ${configs.automationUserJwt}`
|
||
|
},
|
||
|
body: JSON.stringify(payload)
|
||
|
})
|
||
|
if (!res.ok) {
|
||
|
const body = await res.text()
|
||
|
const msg = `failed to updateSegmentInDatabase. status=${res.status}, statusText=${res.statusText}, body=${body}`
|
||
|
console.error(msg)
|
||
|
throw new Error(msg);
|
||
|
}
|
||
|
// console.info(`response was OK~`)
|
||
|
const body = await res.json() as SegmentResponse[];
|
||
|
if (!body[0]) throw new Error(`failed to get a segment that matched segment_id=${segment_id}`);
|
||
|
const bod = body[0]
|
||
|
// console.info('the following was the response from PATCH-ing /segments')
|
||
|
// console.info(JSON.stringify(bod))
|
||
|
return bod
|
||
|
}
|