mirror of
https://github.com/doms9/iptv.git
synced 2026-06-15 12:46:27 +02:00
Compare commits
35 commits
dce07ca352
...
011230fc0f
| Author | SHA1 | Date | |
|---|---|---|---|
|
|
011230fc0f | ||
|
|
0ea79adf8e | ||
|
|
c877f6365f | ||
|
|
d79c0b9d79 | ||
|
|
55bef4b3ab | ||
|
|
b98fd50b82 | ||
|
|
3b48bb0d93 | ||
|
|
412de8de19 | ||
|
|
e19921233f | ||
|
|
a90655de47 | ||
|
|
b7fd1d6893 | ||
|
|
42d85811e5 | ||
|
|
486994d1ab | ||
|
|
fcd4240269 | ||
|
|
32e592c1af | ||
|
|
a320eadfc4 | ||
|
|
679ab4dd53 | ||
|
|
f2810b3880 | ||
|
|
9e740ff533 | ||
|
|
8429e7f4b9 | ||
|
|
2755c39852 | ||
|
|
8983a1fbf7 | ||
|
|
6cfc15c57a | ||
|
|
00000d9ad8 | ||
|
|
1291aa98b4 | ||
|
|
73489178a2 | ||
|
|
9ab113c4d7 | ||
|
|
22dc68dd97 | ||
|
|
4b9df500d8 | ||
|
|
61e0562c1c | ||
|
|
db861084ca | ||
|
|
c4aab8d5b9 | ||
|
|
881c367b29 | ||
|
|
7e8aaba0a5 | ||
|
|
e29cc712f9 |
6 changed files with 120416 additions and 126522 deletions
1898
M3U8/TV.m3u8
1898
M3U8/TV.m3u8
File diff suppressed because it is too large
Load diff
243052
M3U8/TV.xml
243052
M3U8/TV.xml
File diff suppressed because one or more lines are too long
1898
M3U8/events.m3u8
1898
M3U8/events.m3u8
File diff suppressed because it is too large
Load diff
|
|
@ -6,6 +6,7 @@ from pathlib import Path
|
||||||
from playwright.async_api import async_playwright
|
from playwright.async_api import async_playwright
|
||||||
from scrapers import (
|
from scrapers import (
|
||||||
cdnlivetv,
|
cdnlivetv,
|
||||||
|
dami,
|
||||||
embedhd,
|
embedhd,
|
||||||
fawa,
|
fawa,
|
||||||
fsports,
|
fsports,
|
||||||
|
|
@ -65,6 +66,7 @@ async def main() -> None:
|
||||||
]
|
]
|
||||||
|
|
||||||
httpx_tasks = [
|
httpx_tasks = [
|
||||||
|
# asyncio.create_task(dami.scrape()),
|
||||||
asyncio.create_task(fawa.scrape()),
|
asyncio.create_task(fawa.scrape()),
|
||||||
asyncio.create_task(istreameast.scrape()),
|
asyncio.create_task(istreameast.scrape()),
|
||||||
asyncio.create_task(mainportal.scrape()),
|
asyncio.create_task(mainportal.scrape()),
|
||||||
|
|
@ -93,6 +95,7 @@ async def main() -> None:
|
||||||
|
|
||||||
additions = (
|
additions = (
|
||||||
cdnlivetv.urls
|
cdnlivetv.urls
|
||||||
|
| dami.urls
|
||||||
| embedhd.urls
|
| embedhd.urls
|
||||||
| fawa.urls
|
| fawa.urls
|
||||||
| fsports.urls
|
| fsports.urls
|
||||||
|
|
|
||||||
80
M3U8/scrapers/dami.py
Normal file
80
M3U8/scrapers/dami.py
Normal file
|
|
@ -0,0 +1,80 @@
|
||||||
|
from .utils import Cache, Time, get_logger, leagues, network
|
||||||
|
|
||||||
|
log = get_logger(__name__)
|
||||||
|
|
||||||
|
urls: dict[str, dict[str, str | float]] = {}
|
||||||
|
|
||||||
|
TAG = "DAMI"
|
||||||
|
|
||||||
|
CACHE_FILE = Cache(TAG, exp=28_800)
|
||||||
|
|
||||||
|
API_URL = "https://api.ppv.to/api/streams"
|
||||||
|
# "https://api.ppv.cx/api/streams"
|
||||||
|
# "https://api.ppv.sh/api/streams"
|
||||||
|
|
||||||
|
|
||||||
|
async def get_events() -> dict[str, dict[str, str | float]]:
|
||||||
|
now = Time.clean(Time.now())
|
||||||
|
|
||||||
|
events = {}
|
||||||
|
|
||||||
|
if not (r := await network.request(API_URL, log=log)):
|
||||||
|
return events
|
||||||
|
|
||||||
|
api_data: dict[str, dict] = r.json()
|
||||||
|
|
||||||
|
for stream_group in api_data.get("streams", []):
|
||||||
|
sport = stream_group["category"]
|
||||||
|
|
||||||
|
if sport == "24/7 Streams":
|
||||||
|
continue
|
||||||
|
|
||||||
|
for event in stream_group.get("streams", []):
|
||||||
|
name = event.get("name")
|
||||||
|
|
||||||
|
start_ts = event.get("starts_at")
|
||||||
|
|
||||||
|
logo = event.get("poster")
|
||||||
|
|
||||||
|
uri_name = event.get("uri_name")
|
||||||
|
|
||||||
|
if not (name and start_ts and uri_name):
|
||||||
|
continue
|
||||||
|
|
||||||
|
event_dt = Time.from_ts(start_ts)
|
||||||
|
|
||||||
|
if event_dt.date() != now.date():
|
||||||
|
continue
|
||||||
|
|
||||||
|
key = f"[{sport}] {name} ({TAG})"
|
||||||
|
|
||||||
|
tvg_id, pic = leagues.get_tvg_info(sport, name)
|
||||||
|
|
||||||
|
events[key] = {
|
||||||
|
"url": f"https://dami-tv.pro/live-hls/channel/{uri_name}/playlist.m3u8",
|
||||||
|
"logo": logo or pic,
|
||||||
|
"base": f"https://dami-tv.pro/player/auto/?match={uri_name}",
|
||||||
|
"timestamp": now.timestamp(),
|
||||||
|
"id": tvg_id or "Live.Event.us",
|
||||||
|
}
|
||||||
|
|
||||||
|
return events
|
||||||
|
|
||||||
|
|
||||||
|
async def scrape() -> None:
|
||||||
|
if cached_urls := CACHE_FILE.load():
|
||||||
|
urls.update(cached_urls)
|
||||||
|
|
||||||
|
log.info(f"Loaded {len(urls)} event(s) from cache")
|
||||||
|
|
||||||
|
return
|
||||||
|
|
||||||
|
log.info(f'Scraping from "{API_URL}"')
|
||||||
|
|
||||||
|
events = await get_events()
|
||||||
|
|
||||||
|
urls.update(events)
|
||||||
|
|
||||||
|
log.info(f"Collected and cached {len(urls)} event(s)")
|
||||||
|
|
||||||
|
CACHE_FILE.write(urls)
|
||||||
|
|
@ -1,10 +1,7 @@
|
||||||
## Base Log @ 2026-05-13 16:40 UTC
|
## Base Log @ 2026-05-14 16:25 UTC
|
||||||
|
|
||||||
### ✅ Working Streams: 159<br>❌ Dead Streams: 1
|
### ✅ Working Streams: 160<br>❌ Dead Streams: 0
|
||||||
|
|
||||||
| Channel | Error (Code) | Link |
|
|
||||||
| ------- | ------------ | ---- |
|
|
||||||
| FDSN Midwest | HTTP Error (403) | `http://realsport.scalecdn.co:8080/live/supersonicstreams/cUewZolveU8Jh18jk34BDJ/3784.ts` |
|
|
||||||
---
|
---
|
||||||
#### Base Channels URL
|
#### Base Channels URL
|
||||||
```
|
```
|
||||||
|
|
|
||||||
Loading…
Add table
Add a link
Reference in a new issue