mirror of
https://github.com/wukko/cobalt.git
synced 2025-01-12 20:02:19 +01:00
stream/manage: refactor internal stream handling, skip m3u8 services
- fix a typo caused by refactoring Co-authored-by: wukko <me@wukko.me>
This commit is contained in:
parent
291a3c2e53
commit
70a79fdedd
1 changed files with 34 additions and 24 deletions
|
@ -6,6 +6,8 @@ import { decryptStream, encryptStream, generateHmac } from "../sub/crypto.js";
|
||||||
import { streamLifespan } from "../config.js";
|
import { streamLifespan } from "../config.js";
|
||||||
import { strict as assert } from "assert";
|
import { strict as assert } from "assert";
|
||||||
|
|
||||||
|
const M3U_SERVICES = ['dailymotion', 'vimeo', 'rutube'];
|
||||||
|
|
||||||
const streamNoAccess = {
|
const streamNoAccess = {
|
||||||
error: "i couldn't verify if you have access to this stream. go back and try again!",
|
error: "i couldn't verify if you have access to this stream. go back and try again!",
|
||||||
status: 401
|
status: 401
|
||||||
|
@ -73,12 +75,12 @@ export function getInternalStream(id) {
|
||||||
return internalStreamCache[id];
|
return internalStreamCache[id];
|
||||||
}
|
}
|
||||||
|
|
||||||
export function createInternalStream(obj = {}) {
|
export function createInternalStream(url, obj = {}) {
|
||||||
assert(typeof obj.url === 'string');
|
assert(typeof url === 'string');
|
||||||
|
|
||||||
const streamID = nanoid();
|
const streamID = nanoid();
|
||||||
internalStreamCache[streamID] = {
|
internalStreamCache[streamID] = {
|
||||||
url: obj.url,
|
url,
|
||||||
service: obj.service,
|
service: obj.service,
|
||||||
controller: new AbortController()
|
controller: new AbortController()
|
||||||
};
|
};
|
||||||
|
@ -89,8 +91,12 @@ export function createInternalStream(obj = {}) {
|
||||||
}
|
}
|
||||||
|
|
||||||
export function destroyInternalStream(url) {
|
export function destroyInternalStream(url) {
|
||||||
const id = new URL(url).searchParams.get('t');
|
url = new URL(url);
|
||||||
assert(id);
|
if (url.hostname !== '127.0.0.1') {
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
|
||||||
|
const id = url.searchParams.get('t');
|
||||||
|
|
||||||
if (internalStreamCache[id]) {
|
if (internalStreamCache[id]) {
|
||||||
internalStreamCache[id].controller.abort();
|
internalStreamCache[id].controller.abort();
|
||||||
|
@ -98,6 +104,28 @@ export function destroyInternalStream(url) {
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
function wrapStream(streamInfo) {
|
||||||
|
/* m3u8 links are currently not supported
|
||||||
|
* for internal streams, skip them */
|
||||||
|
if (M3U_SERVICES.includes(streamInfo.service)) {
|
||||||
|
return streamInfo;
|
||||||
|
}
|
||||||
|
|
||||||
|
const url = streamInfo.urls;
|
||||||
|
|
||||||
|
if (typeof url === 'string') {
|
||||||
|
streamInfo.urls = createInternalStream(url, streamInfo);
|
||||||
|
} else if (Array.isArray(url)) {
|
||||||
|
for (const idx in streamInfo.urls) {
|
||||||
|
streamInfo.urls[idx] = createInternalStream(
|
||||||
|
streamInfo.urls[idx], streamInfo
|
||||||
|
);
|
||||||
|
}
|
||||||
|
} else throw 'invalid urls';
|
||||||
|
|
||||||
|
return streamInfo;
|
||||||
|
}
|
||||||
|
|
||||||
export function verifyStream(id, hmac, exp, secret, iv) {
|
export function verifyStream(id, hmac, exp, secret, iv) {
|
||||||
try {
|
try {
|
||||||
const ghmac = generateHmac(`${id},${exp},${iv},${secret}`, hmacSalt);
|
const ghmac = generateHmac(`${id},${exp},${iv},${secret}`, hmacSalt);
|
||||||
|
@ -113,25 +141,7 @@ export function verifyStream(id, hmac, exp, secret, iv) {
|
||||||
if (Number(exp) <= new Date().getTime())
|
if (Number(exp) <= new Date().getTime())
|
||||||
return streamNoExist;
|
return streamNoExist;
|
||||||
|
|
||||||
if (!streamInfo.originalUrls) {
|
return wrapStream(streamInfo);
|
||||||
streamInfo.originalUrls = streamInfo.urls;
|
|
||||||
}
|
|
||||||
|
|
||||||
if (typeof streamInfo.originalUrls === 'string') {
|
|
||||||
streamInfo.urls = createInternalStream({
|
|
||||||
url: streamInfo.originalUrls,
|
|
||||||
...streamInfo
|
|
||||||
});
|
|
||||||
} else if (Array.isArray(streamInfo.originalUrls)) {
|
|
||||||
for (const idx in streamInfo.originalUrls) {
|
|
||||||
streamInfo.originalUrls[idx] = createInternalStream({
|
|
||||||
url: streamInfo.originalUrls[idx],
|
|
||||||
...streamInfo
|
|
||||||
});
|
|
||||||
}
|
|
||||||
} else throw 'invalid urls';
|
|
||||||
|
|
||||||
return streamInfo;
|
|
||||||
}
|
}
|
||||||
catch {
|
catch {
|
||||||
return {
|
return {
|
||||||
|
|
Loading…
Reference in a new issue