|
|
|
|
@ -4,7 +4,7 @@ import type { DataProcessorData } from '../../types/dataProcessor'
|
|
|
|
|
import { Stream, Playlist, Channel, Issue } from '../../models'
|
|
|
|
|
import type { DataLoaderData } from '../../types/dataLoader'
|
|
|
|
|
import { DATA_DIR, STREAMS_DIR } from '../../constants'
|
|
|
|
|
import validUrl from 'valid-url'
|
|
|
|
|
import { isURI } from '../../utils'
|
|
|
|
|
|
|
|
|
|
let processedIssues = new Collection()
|
|
|
|
|
|
|
|
|
|
@ -158,7 +158,7 @@ async function addStreams({
|
|
|
|
|
if (data.missing('streamId') || data.missing('streamUrl')) return
|
|
|
|
|
if (streams.includes((_stream: Stream) => _stream.url === data.getString('streamUrl'))) return
|
|
|
|
|
const streamUrl = data.getString('streamUrl') || ''
|
|
|
|
|
if (!isUri(streamUrl)) return
|
|
|
|
|
if (!isURI(streamUrl)) return
|
|
|
|
|
|
|
|
|
|
const streamId = data.getString('streamId') || ''
|
|
|
|
|
const [channelId, feedId] = streamId.split('@')
|
|
|
|
|
@ -192,7 +192,3 @@ async function addStreams({
|
|
|
|
|
processedIssues.add(issue.number)
|
|
|
|
|
})
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
function isUri(string: string) {
|
|
|
|
|
return validUrl.isUri(encodeURI(string))
|
|
|
|
|
}
|
|
|
|
|
|