Merge pull request #34330 from iptv-org/patch-2026.03.3

Patch 2026.03.3
This commit is contained in:
archrootsda 2026-03-13 00:32:13 +01:00 committed by GitHub
commit 47b4778d02
No known key found for this signature in database
GPG Key ID: B5690EEEBB952194
11 changed files with 125 additions and 9 deletions

View File

@ -3,6 +3,7 @@ import { Storage } from '@freearhey/storage-js'
import { PlaylistParser } from '../../core'
import { data, loadData } from '../../api'
import { ROOT_DIR } from '../../constants'
import { isURI } from '../../utils.js'
import { Stream } from '../../models'
import * as sdk from '@iptv-org/sdk'
import { program } from 'commander'
@ -63,6 +64,14 @@ async function main() {
buffer.set(stream.url, true)
}
if (!isURI(stream.url)) {
log.add({
type: 'error',
line: stream.getLine(),
message: `"${stream.url}" is not a valid URL`
})
}
if (stream.channel) {
const blocklistRecords = new Collection(
data.blocklistRecordsGroupedByChannel.get(stream.channel)

View File

@ -2,8 +2,8 @@ import normalizeUrl from 'normalize-url'
export function isURI(string: string): boolean {
try {
new URL(string)
return true
const url = new URL(string)
return /^(http:|https:|mmsh:|rtsp:|rtmp:)/.test(url.protocol)
} catch {
return false
}

View File

@ -77,7 +77,7 @@ https://ccstreaming.packet.mx/WebRTCAppEE/streams/45.1_kd5oiNTTWO0gEOFc431277834
#EXTINF:-1 tvg-id="CanalParlamentodelCongresodeJalisco.mx@SD",Canal Parlamento del Congreso de Jalisco (720p) [Not 24/7]
https://60417ddeaf0d9.streamlock.net/srtc/smil:srtc.smil/playlist.m3u8
#EXTINF:-1 tvg-id="Capital21.mx@SD",Capital 21 (1080p) [Not 24/7]
hhttps://video.cdmx.gob.mx/redes/stream.m3u8
https://video.cdmx.gob.mx/redes/stream.m3u8
#EXTINF:-1 tvg-id="ConectaTV.mx@SD",Conecta TV (720p)
https://stream8.mexiserver.com:19360/conectatvx/conectatvx.m3u8
#EXTINF:-1 tvg-id="CreaLaTV.mx@SD",CreaLaTV (1080p)

View File

@ -84,7 +84,7 @@ https://live.mediatech.vn/live/285aaa79b4b265a457d81bb72bc32e2c114/chunklist.m3u
#EXTINF:-1 tvg-id="SCTV1.vn@SD",SCTV1 (720p)
https://liveh12.vtvprime.vn/hls/SCTV1/index.m3u8
#EXTINF:-1 tvg-id="SCTV2.vn@SD",SCTV2 (720p)
ttps://liveh12.vtvprime.vn/hls/SCTV2/index.m3u8
https://liveh12.vtvprime.vn/hls/SCTV2/index.m3u8
#EXTINF:-1 tvg-id="SCTV4.vn@SD",SCTV4 (720p)
https://liveh12.vtvprime.vn/hls/SCTV4/index.m3u8
#EXTINF:-1 tvg-id="SCTV6.vn@SD",SCTV6 (1080p) [Geo-blocked]

View File

@ -0,0 +1 @@
#EXTM3U

View File

@ -588,5 +588,13 @@
"country": "CA",
"categories": [],
"is_nsfw": false
},
{
"id": "Channel7.bz",
"name": "Channel 7",
"network": null,
"country": "BZ",
"categories": [],
"is_nsfw": false
}
]

View File

@ -2393,5 +2393,84 @@ module.exports = [
timeline_url: 'https://api.github.com/repos/iptv-org/iptv/issues/25157/timeline',
performed_via_github_app: null,
state_reason: null
},
{
url: 'https://api.github.com/repos/iptv-org/iptv/issues/15175',
repository_url: 'https://api.github.com/repos/iptv-org/iptv',
labels_url: 'https://api.github.com/repos/iptv-org/iptv/issues/15175/labels{/name}',
comments_url: 'https://api.github.com/repos/iptv-org/iptv/issues/15175/comments',
events_url: 'https://api.github.com/repos/iptv-org/iptv/issues/15175/events',
html_url: 'https://github.com/iptv-org/iptv/issues/15175',
id: 1884859888,
node_id: 'I_kwDOCWUK8M5wWK2C',
number: 15175,
title: 'Add: TFX',
user: {
login: 'freearhey',
id: 7253922,
node_id: 'MDQ6VXNlcjcyNTM5MjI=',
avatar_url: 'https://avatars.githubusercontent.com/u/7253922?v=4',
gravatar_id: '',
url: 'https://api.github.com/users/freearhey',
html_url: 'https://github.com/freearhey',
followers_url: 'https://api.github.com/users/freearhey/followers',
following_url: 'https://api.github.com/users/freearhey/following{/other_user}',
gists_url: 'https://api.github.com/users/freearhey/gists{/gist_id}',
starred_url: 'https://api.github.com/users/freearhey/starred{/owner}{/repo}',
subscriptions_url: 'https://api.github.com/users/freearhey/subscriptions',
organizations_url: 'https://api.github.com/users/freearhey/orgs',
repos_url: 'https://api.github.com/users/freearhey/repos',
events_url: 'https://api.github.com/users/freearhey/events{/privacy}',
received_events_url: 'https://api.github.com/users/freearhey/received_events',
type: 'User',
site_admin: false
},
labels: [
{
id: 5923498886,
node_id: 'LA_kwDOCWUK8M8AAAABYRFrhg',
url: 'https://api.github.com/repos/iptv-org/iptv/labels/approved',
name: 'approved',
color: '85ddde',
default: false,
description: ''
},
{
id: 5923508587,
node_id: 'LA_kwDOCWUK8M8AAAABYRGRaw',
url: 'https://api.github.com/repos/iptv-org/iptv/labels/streams:add',
name: 'streams:add',
color: '017ff9',
default: false,
description: 'Request to add a new link to a playlist'
}
],
state: 'open',
locked: false,
assignee: null,
assignees: [],
milestone: null,
comments: 1,
created_at: '2023-09-06T22:54:25Z',
updated_at: '2023-09-07T00:57:11Z',
closed_at: null,
author_association: 'COLLABORATOR',
active_lock_reason: null,
body: '### Stream ID\n\nChannel7.bz@SD\n\n### Stream URL\n\nnew: https://streamer2.nexgen.bz/07-CHANNEL7/index.m3u8\n\n### Label\n\nNone\n\n### HTTP User Agent\n\n_No response_\n\n### HTTP Referrer\n\n_No response_\n\n### Notes (optional)\n\n_No response_\n\n### Contributing Guide\n\n- [X] I have read [Contributing Guide](https://github.com/iptv-org/iptv/blob/master/CONTRIBUTING.md)',
reactions: {
url: 'https://api.github.com/repos/iptv-org/iptv/issues/15175/reactions',
total_count: 0,
'+1': 0,
'-1': 0,
laugh: 0,
hooray: 0,
confused: 0,
heart: 0,
rocket: 0,
eyes: 0
},
timeline_url: 'https://api.github.com/repos/iptv-org/iptv/issues/15175/timeline',
performed_via_github_app: null,
state_reason: null
}
]

View File

@ -0,0 +1 @@
#EXTM3U

View File

@ -0,0 +1,3 @@
#EXTM3U
#EXTINF:-1 tvg-id="Channel7.bz@SD",Channel 7
new: https://streamer2.nexgen.bz/07-CHANNEL7/index.m3u8

View File

@ -38,6 +38,20 @@ describe('playlist:validate', () => {
}
})
it('show a error if stream has an invalid url', () => {
const cmd = `${ENV_VAR} npm run playlist:validate -- invalid_url.m3u`
try {
execSync(cmd, { encoding: 'utf8' })
} catch (error) {
if (process.env.DEBUG === 'true') console.log(cmd, error)
expect((error as ExecError).stdout).toContain('invalid_url.m3u')
expect((error as ExecError).stdout).toContain(
'2 error "new: https://streamer2.nexgen.bz/07-CHANNEL7/index.m3u8" is not a valid URL'
)
expect((error as ExecError).stdout).toContain('1 problems (1 errors, 0 warnings)')
}
})
it('skip the file if it does not exist', () => {
const cmd = `${ENV_VAR} npm run playlist:validate -- missing.m3u`
execSync(cmd, { encoding: 'utf8' })

View File

@ -19,11 +19,12 @@ describe('report:create', () => {
2 14177 'streams:add' 'TUTV.us' 'https://livestream.telvue.com/templeuni1/f7b44cfafd5c52223d5498196c8a2e7b.sdp/playlist.m3u8' 'duplicate_link'
3 14178 'streams:add' 'TV3.my' 'https://live-streams-ssai-01.tonton.com.my/live/2dd2b7cd-1b34-4871-b669-57b5c9beca23/live.isml/.m...' 'channel_blocked'
4 14179 'streams:add' 'ManoramaNews.in' '(https://mitelefe.com/Api/Videos/GetSourceUrl/694564/0/HLS / https://ssl.cloud.telefe.com/Api/Vid...' 'invalid_stream_url'
5 16120 'streams:remove' undefined 'http://190.61.102.67:2000/play/a038/index.m3u8' 'nonexistent_link'
6 19956 'channel search' 'CNBCe.tr' undefined 'invalid_channel_id'
7 19957 'channel search' '13thStreet.au' undefined 'channel_closed'
8 20956 'channel search' 'IONTV.us' undefined 'fulfilled'
9 25157 'streams:add' 'OnTimeSports.eg@SD' 'OnTime Sports SD.mu38' 'invalid_stream_url'
5 15175 'streams:add' 'Channel7.bz@SD' 'new: https://streamer2.nexgen.bz/07-CHANNEL7/index.m3u8' 'invalid_stream_url'
6 16120 'streams:remove' undefined 'http://190.61.102.67:2000/play/a038/index.m3u8' 'nonexistent_link'
7 19956 'channel search' 'CNBCe.tr' undefined 'invalid_channel_id'
8 19957 'channel search' '13thStreet.au' undefined 'channel_closed'
9 20956 'channel search' 'IONTV.us' undefined 'fulfilled'
10 25157 'streams:add' 'OnTimeSports.eg@SD' 'OnTime Sports SD.mu38' 'invalid_stream_url'
`)
).toBe(true)
})