mirror of
https://github.com/iv-org/invidious.git
synced 2025-01-19 19:21:32 -05:00
reduce indentation and improve jsdoc descriptions
This commit is contained in:
parent
bd4a4ab17b
commit
0d586dde2a
@ -32,138 +32,19 @@ class invidious_embed {
|
|||||||
*/
|
*/
|
||||||
static api_promise = false;
|
static api_promise = false;
|
||||||
static invidious_instance = '';
|
static invidious_instance = '';
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* @type {[string]}
|
* @type {[string]}
|
||||||
*/
|
*/
|
||||||
static api_instance_list = [];
|
static api_instance_list = [];
|
||||||
|
|
||||||
|
/**
|
||||||
|
* @type {Object<string,boolean>}
|
||||||
|
*/
|
||||||
static instance_status_list = {};
|
static instance_status_list = {};
|
||||||
static videodata_cahce = {};
|
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Add event execute function for player
|
* @typedef {{
|
||||||
* @param {string} eventname
|
|
||||||
* @param {Function} event_execute_function
|
|
||||||
*/
|
|
||||||
addEventListener(eventname, event_execute_function) {
|
|
||||||
if (typeof event_execute_function === 'function') {
|
|
||||||
if (eventname in invidious_embed.eventname_table) {
|
|
||||||
this.eventobject[invidious_embed.eventname_table[eventname]].push(event_execute_function);
|
|
||||||
} else if (invidious_embed.available_event_name.includes(eventname)) {
|
|
||||||
this.eventobject[eventname].push(event_execute_function);
|
|
||||||
} else {
|
|
||||||
console.warn('addEventListener cannot find such eventname : ' + eventname);
|
|
||||||
}
|
|
||||||
} else {
|
|
||||||
console.warn("addEventListner secound args must be function");
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
/**
|
|
||||||
* remove spacific event execute function
|
|
||||||
* @param {string} eventname
|
|
||||||
* @param {Function} delete_event_function
|
|
||||||
*/
|
|
||||||
removeEventListener(eventname, delete_event_function) {
|
|
||||||
if (typeof delete_event_function === 'function') {
|
|
||||||
let internal_eventname;
|
|
||||||
if (eventname in invidious_embed.eventname_table) {
|
|
||||||
internal_eventname = invidious_embed.eventname_table[eventname];
|
|
||||||
} else if (invidious_embed.available_event_name.includes(eventname)) {
|
|
||||||
internal_eventname = eventname;
|
|
||||||
} else {
|
|
||||||
console.warn('removeEventListner cannot find such eventname : ' + eventname);
|
|
||||||
return;
|
|
||||||
}
|
|
||||||
|
|
||||||
this.eventobject[internal_eventname] = this.eventobject[internal_eventname].filter(listed_function => {
|
|
||||||
const allowFunctionDetected = listed_function.toString()[0] === '(';
|
|
||||||
if (allowFunctionDetected) {
|
|
||||||
listed_function.toString() !== delete_event_function.toString();
|
|
||||||
} else {
|
|
||||||
listed_function !== delete_event_function;
|
|
||||||
}
|
|
||||||
});
|
|
||||||
} else {
|
|
||||||
console.warn("removeEventListener secound args must be function");
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
/**
|
|
||||||
* return whether instance_origin origin can use or not
|
|
||||||
* @param {string} instance_origin
|
|
||||||
* @returns {Promise<boolean>}
|
|
||||||
*/
|
|
||||||
async instance_access_check(instance_origin) {
|
|
||||||
let return_status;
|
|
||||||
const status_cahce_exist = instance_origin in invidious_embed.instance_status_list;
|
|
||||||
if (!status_cahce_exist) {
|
|
||||||
try {
|
|
||||||
const instance_stats = await fetch(instance_origin + '/api/v1/stats');
|
|
||||||
if (instance_stats.ok) {
|
|
||||||
const instance_stats_json = await instance_stats.json();
|
|
||||||
return_status = (instance_stats_json.software.name === 'invidious');
|
|
||||||
} else {
|
|
||||||
return_status = false;
|
|
||||||
}
|
|
||||||
} catch {
|
|
||||||
return_status = false;
|
|
||||||
}
|
|
||||||
invidious_embed.instance_status_list[instance_origin] = return_status;
|
|
||||||
return return_status;
|
|
||||||
} else {
|
|
||||||
return invidious_embed.instance_status_list[instance_origin];
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
/**
|
|
||||||
* Need to use await
|
|
||||||
*
|
|
||||||
* Add invidious_embed.api_instance_list
|
|
||||||
*
|
|
||||||
* fetch from api.invidious.io
|
|
||||||
*/
|
|
||||||
async get_instance_list() {
|
|
||||||
invidious_embed.api_instance_list = [];
|
|
||||||
const instance_list_api = await (await fetch('https://api.invidious.io/instances.json?pretty=1&sort_by=type,users')).json();
|
|
||||||
instance_list_api.forEach(instance_data => {
|
|
||||||
const http_check = instance_data[1]['type'] === 'https';
|
|
||||||
let status_check_api_data;
|
|
||||||
if (instance_data[1]['monitor'] !== null) {
|
|
||||||
status_check_api_data = instance_data[1]['monitor']['statusClass'] === 'success';
|
|
||||||
}
|
|
||||||
const api_available = instance_data[1]['api'] && instance_data[1]['cors'];
|
|
||||||
if (http_check && status_check_api_data && api_available) {
|
|
||||||
invidious_embed.api_instance_list.push(instance_data[1]['uri']);
|
|
||||||
}
|
|
||||||
});
|
|
||||||
}
|
|
||||||
|
|
||||||
/**
|
|
||||||
* Need to use await
|
|
||||||
*
|
|
||||||
* Auto select invidious instance and set invidious_embed.invidious_instance
|
|
||||||
*/
|
|
||||||
async auto_instance_select() {
|
|
||||||
if (await this.instance_access_check(invidious_embed.invidious_instance)) {
|
|
||||||
return;
|
|
||||||
} else {
|
|
||||||
if (invidious_embed.api_instance_list.length === 0) {
|
|
||||||
await this.get_instance_list();
|
|
||||||
}
|
|
||||||
for (let x = 0; x < invidious_embed.api_instance_list.length; x++) {
|
|
||||||
if (await this.instance_access_check(invidious_embed.api_instance_list[x])) {
|
|
||||||
invidious_embed.invidious_instance = invidious_embed.api_instance_list[x];
|
|
||||||
break;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
/**
|
|
||||||
* Need to use await
|
|
||||||
* Return videoData using invidious videos api
|
|
||||||
* @param {string} videoid
|
|
||||||
* @returns {Promise<{
|
|
||||||
* title:string,
|
* title:string,
|
||||||
* videoId:string,
|
* videoId:string,
|
||||||
* videoThumbnails:[{
|
* videoThumbnails:[{
|
||||||
@ -263,7 +144,138 @@ class invidious_embed {
|
|||||||
* viewCountText:string,
|
* viewCountText:string,
|
||||||
* viewCount:number
|
* viewCount:number
|
||||||
* }]
|
* }]
|
||||||
* }>}
|
* }} videoDataApi
|
||||||
|
*/
|
||||||
|
|
||||||
|
/**
|
||||||
|
* @type {Object<string,videoDataApi>}
|
||||||
|
*/
|
||||||
|
static videodata_cahce = {};
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Add event execute function for player
|
||||||
|
* @param {string} eventname
|
||||||
|
* @param {Function} event_execute_function
|
||||||
|
*/
|
||||||
|
addEventListener(eventname, event_execute_function) {
|
||||||
|
if (typeof event_execute_function === 'function') {
|
||||||
|
if (eventname in invidious_embed.eventname_table) {
|
||||||
|
this.eventobject[invidious_embed.eventname_table[eventname]].push(event_execute_function);
|
||||||
|
} else if (invidious_embed.available_event_name.includes(eventname)) {
|
||||||
|
this.eventobject[eventname].push(event_execute_function);
|
||||||
|
} else {
|
||||||
|
console.warn('addEventListener cannot find such eventname : ' + eventname);
|
||||||
|
}
|
||||||
|
} else {
|
||||||
|
console.warn("addEventListner secound args must be function");
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* remove spacific event execute function
|
||||||
|
* @param {string} eventname
|
||||||
|
* @param {Function} delete_event_function
|
||||||
|
*/
|
||||||
|
removeEventListener(eventname, delete_event_function) {
|
||||||
|
if (typeof delete_event_function === 'function') {
|
||||||
|
let internal_eventname;
|
||||||
|
if (eventname in invidious_embed.eventname_table) {
|
||||||
|
internal_eventname = invidious_embed.eventname_table[eventname];
|
||||||
|
} else if (invidious_embed.available_event_name.includes(eventname)) {
|
||||||
|
internal_eventname = eventname;
|
||||||
|
} else {
|
||||||
|
console.warn('removeEventListner cannot find such eventname : ' + eventname);
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
|
||||||
|
this.eventobject[internal_eventname] = this.eventobject[internal_eventname].filter(listed_function => {
|
||||||
|
const allowFunctionDetected = listed_function.toString()[0] === '(';
|
||||||
|
if (allowFunctionDetected) {
|
||||||
|
listed_function.toString() !== delete_event_function.toString();
|
||||||
|
} else {
|
||||||
|
listed_function !== delete_event_function;
|
||||||
|
}
|
||||||
|
});
|
||||||
|
} else {
|
||||||
|
console.warn("removeEventListener secound args must be function");
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* return whether instance_origin origin can use or not
|
||||||
|
* @param {string} instance_origin
|
||||||
|
* @returns {Promise<boolean>}
|
||||||
|
*/
|
||||||
|
async instance_access_check(instance_origin) {
|
||||||
|
let return_status;
|
||||||
|
const status_cahce_exist = instance_origin in invidious_embed.instance_status_list;
|
||||||
|
if (status_cahce_exist) {
|
||||||
|
return invidious_embed.instance_status_list[instance_origin];
|
||||||
|
}
|
||||||
|
|
||||||
|
try {
|
||||||
|
const instance_stats = await fetch(instance_origin + '/api/v1/stats');
|
||||||
|
if (instance_stats.ok) {
|
||||||
|
const instance_stats_json = await instance_stats.json();
|
||||||
|
return_status = (instance_stats_json.software.name === 'invidious');
|
||||||
|
} else {
|
||||||
|
return_status = false;
|
||||||
|
}
|
||||||
|
} catch {
|
||||||
|
return_status = false;
|
||||||
|
}
|
||||||
|
invidious_embed.instance_status_list[instance_origin] = return_status;
|
||||||
|
return return_status;
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Need to use await
|
||||||
|
*
|
||||||
|
* Add invidious_embed.api_instance_list
|
||||||
|
*
|
||||||
|
* fetch from api.invidious.io
|
||||||
|
*/
|
||||||
|
async get_instance_list() {
|
||||||
|
invidious_embed.api_instance_list = [];
|
||||||
|
const instance_list_api = await (await fetch('https://api.invidious.io/instances.json?pretty=1&sort_by=type,users')).json();
|
||||||
|
instance_list_api.forEach(instance_data => {
|
||||||
|
const http_check = instance_data[1]['type'] === 'https';
|
||||||
|
let status_check_api_data;
|
||||||
|
if (instance_data[1]['monitor'] !== null) {
|
||||||
|
status_check_api_data = instance_data[1]['monitor']['statusClass'] === 'success';
|
||||||
|
}
|
||||||
|
const api_available = instance_data[1]['api'] && instance_data[1]['cors'];
|
||||||
|
if (http_check && status_check_api_data && api_available) {
|
||||||
|
invidious_embed.api_instance_list.push(instance_data[1]['uri']);
|
||||||
|
}
|
||||||
|
});
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Need to use await
|
||||||
|
*
|
||||||
|
* Auto select invidious instance and set invidious_embed.invidious_instance
|
||||||
|
*/
|
||||||
|
async auto_instance_select() {
|
||||||
|
if (await this.instance_access_check(invidious_embed.invidious_instance)) {
|
||||||
|
return;
|
||||||
|
} else {
|
||||||
|
if (invidious_embed.api_instance_list.length === 0) {
|
||||||
|
await this.get_instance_list();
|
||||||
|
}
|
||||||
|
for (let x = 0; x < invidious_embed.api_instance_list.length; x++) {
|
||||||
|
if (await this.instance_access_check(invidious_embed.api_instance_list[x])) {
|
||||||
|
invidious_embed.invidious_instance = invidious_embed.api_instance_list[x];
|
||||||
|
break;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Return videoData using invidious videos api
|
||||||
|
* @param {string} videoid
|
||||||
|
* @returns {Promise<videoDataApi>}
|
||||||
*/
|
*/
|
||||||
async videodata_api(videoid) {
|
async videodata_api(videoid) {
|
||||||
const not_in_videodata_cahce = !(videoid in invidious_embed.videodata_cahce);
|
const not_in_videodata_cahce = !(videoid in invidious_embed.videodata_cahce);
|
||||||
@ -279,7 +291,6 @@ class invidious_embed {
|
|||||||
}
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Need to use await
|
|
||||||
* check whether videoid exist or not
|
* check whether videoid exist or not
|
||||||
* @param {string} videoid
|
* @param {string} videoid
|
||||||
* @returns {promise<boolean>}
|
* @returns {promise<boolean>}
|
||||||
@ -289,7 +300,6 @@ class invidious_embed {
|
|||||||
}
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Need to use await
|
|
||||||
* return array of videoid in playlistid
|
* return array of videoid in playlistid
|
||||||
* @param {string} playlistid
|
* @param {string} playlistid
|
||||||
* @returns {Promise<[string]>}
|
* @returns {Promise<[string]>}
|
||||||
@ -312,6 +322,8 @@ class invidious_embed {
|
|||||||
* @param {{
|
* @param {{
|
||||||
* videoId:string,
|
* videoId:string,
|
||||||
* host:string,
|
* host:string,
|
||||||
|
* width:number,
|
||||||
|
* height:number,
|
||||||
* playerVars:{
|
* playerVars:{
|
||||||
* start:number|string,
|
* start:number|string,
|
||||||
* end:number|string,
|
* end:number|string,
|
||||||
@ -331,8 +343,30 @@ class invidious_embed {
|
|||||||
this.error_code = 0;
|
this.error_code = 0;
|
||||||
this.volume = 100;
|
this.volume = 100;
|
||||||
this.loop = false;
|
this.loop = false;
|
||||||
|
|
||||||
|
/**
|
||||||
|
* @type {[string]}
|
||||||
|
*/
|
||||||
this.playlistVideoIds = [];
|
this.playlistVideoIds = [];
|
||||||
|
|
||||||
|
/**
|
||||||
|
* @type {{
|
||||||
|
* ready:Function,
|
||||||
|
* ended:Function,
|
||||||
|
* error:Function,
|
||||||
|
* ratechange:Function,
|
||||||
|
* volumechange:Function,
|
||||||
|
* waiting:Function,
|
||||||
|
* timeupdate:Function,
|
||||||
|
* loadedmetadata:Function,
|
||||||
|
* play:Function,
|
||||||
|
* seeking:Function,
|
||||||
|
* seeked:Function,
|
||||||
|
* playerresize:Function,
|
||||||
|
* pause:Function,
|
||||||
|
* statechange:Function
|
||||||
|
* }}
|
||||||
|
*/
|
||||||
this.eventobject = {
|
this.eventobject = {
|
||||||
ready: [],
|
ready: [],
|
||||||
ended: [],
|
ended: [],
|
||||||
@ -357,7 +391,7 @@ class invidious_embed {
|
|||||||
} else if (typeof element === 'string') {
|
} else if (typeof element === 'string') {
|
||||||
replace_elemnt = document.getElementById(element);
|
replace_elemnt = document.getElementById(element);
|
||||||
|
|
||||||
if(replace_elemnt === null){
|
if (replace_elemnt === null) {
|
||||||
throw 'Can not find spacific element'
|
throw 'Can not find spacific element'
|
||||||
}
|
}
|
||||||
} else {
|
} else {
|
||||||
@ -479,11 +513,15 @@ class invidious_embed {
|
|||||||
return this;
|
return this;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* send message to iframe player
|
||||||
|
* @param {Object} data
|
||||||
|
*/
|
||||||
postMessage(data) {
|
postMessage(data) {
|
||||||
const additionalInfo = {
|
const additionalInfo = {
|
||||||
'origin': location.origin,
|
'origin': location.origin,
|
||||||
'widgetid': this.widgetid.toString(),
|
'widgetid': this.widgetid.toString(),
|
||||||
'target': 'invidious_control'
|
'target': 'invidious_control'
|
||||||
};
|
};
|
||||||
data = Object.assign(additionalInfo, data);
|
data = Object.assign(additionalInfo, data);
|
||||||
this.player_iframe.contentWindow.postMessage(data, this.target_origin);
|
this.player_iframe.contentWindow.postMessage(data, this.target_origin);
|
||||||
@ -495,10 +533,10 @@ class invidious_embed {
|
|||||||
*/
|
*/
|
||||||
event_executor(eventname) {
|
event_executor(eventname) {
|
||||||
const execute_functions = this.eventobject[eventname];
|
const execute_functions = this.eventobject[eventname];
|
||||||
let return_data = {
|
let return_data = {
|
||||||
type: eventname,
|
type: eventname,
|
||||||
data: null,
|
data: null,
|
||||||
target: this
|
target: this
|
||||||
};
|
};
|
||||||
switch (eventname) {
|
switch (eventname) {
|
||||||
case 'statechange':
|
case 'statechange':
|
||||||
@ -517,7 +555,7 @@ class invidious_embed {
|
|||||||
}
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
*
|
* recieve message from iframe player
|
||||||
* @param {{
|
* @param {{
|
||||||
* data:{
|
* data:{
|
||||||
* from:string,
|
* from:string,
|
||||||
@ -588,9 +626,9 @@ class invidious_embed {
|
|||||||
*/
|
*/
|
||||||
promise_send_event(event_name) {
|
promise_send_event(event_name) {
|
||||||
if (invidious_embed.api_promise) {
|
if (invidious_embed.api_promise) {
|
||||||
const promise_object = new Promise((resolve, reject) => this.message_wait[event_name].push(resolve) );
|
const promise_object = new Promise((resolve, reject) => this.message_wait[event_name].push(resolve));
|
||||||
this.postMessage({
|
this.postMessage({
|
||||||
eventname: event_name
|
eventname: event_name
|
||||||
});
|
});
|
||||||
return promise_object;
|
return promise_object;
|
||||||
} else {
|
} else {
|
||||||
@ -812,7 +850,7 @@ class invidious_embed {
|
|||||||
}
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
*
|
* Internal function, so use such as loadVideoById() instead of this function.
|
||||||
* @param {string|{
|
* @param {string|{
|
||||||
* videoId:string|undefined,
|
* videoId:string|undefined,
|
||||||
* mediaContentUrl:string|undefined,
|
* mediaContentUrl:string|undefined,
|
||||||
@ -1012,7 +1050,7 @@ class invidious_embed {
|
|||||||
}
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
*
|
* Internal function, so use such as loadPlaylist() instead of this function.
|
||||||
* @param {string|[string]|{index:number|undefined,list:string,listType:string|undefined}} playlistData
|
* @param {string|[string]|{index:number|undefined,list:string,listType:string|undefined}} playlistData
|
||||||
* @param {boolean} autoplay
|
* @param {boolean} autoplay
|
||||||
* @param {number} index
|
* @param {number} index
|
||||||
@ -1317,13 +1355,13 @@ class invidious_embed {
|
|||||||
*/
|
*/
|
||||||
async getVideoData() {
|
async getVideoData() {
|
||||||
const videoData = await this.videodata_api(this.videoId);
|
const videoData = await this.videodata_api(this.videoId);
|
||||||
return {
|
return {
|
||||||
video_id: this.videoId,
|
video_id: this.videoId,
|
||||||
title: await this.promise_send_event('gettitle'),
|
title: await this.promise_send_event('gettitle'),
|
||||||
list: await this.promise_send_event('getplaylistid'),
|
list: await this.promise_send_event('getplaylistid'),
|
||||||
isListed: videoData.isListed,
|
isListed: videoData.isListed,
|
||||||
isLive: videoData.liveNow,
|
isLive: videoData.liveNow,
|
||||||
isPremiere: videoData.premium
|
isPremiere: videoData.premium
|
||||||
};
|
};
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -1386,7 +1424,7 @@ class invidious_embed {
|
|||||||
/**
|
/**
|
||||||
* After load iFrame api,function will execute
|
* After load iFrame api,function will execute
|
||||||
*
|
*
|
||||||
* But this function always execute imidiretry because iframe api ready mean load complete this js file
|
* But this function always execute immediately because iframe api ready mean load complete this js file
|
||||||
* @param {Function} func
|
* @param {Function} func
|
||||||
*/
|
*/
|
||||||
function invidious_ready(func) {
|
function invidious_ready(func) {
|
||||||
|
Loading…
Reference in New Issue
Block a user