diff --git a/config.json.example b/config.json.example index c5e8644459..78f48097a1 100644 --- a/config.json.example +++ b/config.json.example @@ -1,5 +1,6 @@ { "serverAddress": "https://sponsor.ajay.app", + "backupServerAddress": "REPLACETHISWITHABACKUPSERVERURL", "testingServerAddress": "https://sponsor.ajay.app/test", "serverAddressComment": "This specifies the default SponsorBlock server to connect to", "categoryList": ["sponsor", "selfpromo", "exclusive_access", "interaction", "poi_highlight", "intro", "outro", "preview", "filler", "chapter", "music_offtopic"], diff --git a/public/_locales/en/messages.json b/public/_locales/en/messages.json index 7a5dd69be1..6578111fd0 100644 --- a/public/_locales/en/messages.json +++ b/public/_locales/en/messages.json @@ -505,6 +505,12 @@ "customServerAddressDescription": { "message": "The address SponsorBlock uses to make calls to the server.\nUnless you have your own server instance, this should not be changed." }, + "customBackupServerAddress": { + "message": "SponsorBlock Bacup Server Address" + }, + "customBackupServerAddressDescription": { + "message": "The bacup address SponsorBlock uses to make calls to the server when the primariy Server is unavailable.\nUnless you have your own server instance, this should not be changed." + }, "save": { "message": "Save" }, diff --git a/public/options/options.html b/public/options/options.html index 9111294144..ffcc3b8b76 100644 --- a/public/options/options.html +++ b/public/options/options.html @@ -555,6 +555,26 @@

__MSG_exportOptions__

+
+ + +
__MSG_customBackupServerAddressDescription__
+ +
+
+ __MSG_save__ +
+ +
+ __MSG_reset__ +
+
+
+ diff --git a/src/config.ts b/src/config.ts index ba3caf8568..9f0f624e3d 100644 --- a/src/config.ts +++ b/src/config.ts @@ -41,6 +41,7 @@ interface SBConfig { invidiousInstances: string[]; supportInvidious: boolean; serverAddress: string; + backupServerAddress: string; minDuration: number; skipNoticeDuration: number; audioNotificationOnSkip: boolean; @@ -181,6 +182,7 @@ const Config: SBObject = { invidiousInstances: ["invidious.snopyta.org"], // leave as default supportInvidious: false, serverAddress: CompileConfig.serverAddress, + backupServerAddress: CompileConfig.backupServerAddress, minDuration: 0, skipNoticeDuration: 4, audioNotificationOnSkip: false, diff --git a/src/options.ts b/src/options.ts index e963a683af..f4b6ba5bdf 100644 --- a/src/options.ts +++ b/src/options.ts @@ -175,6 +175,7 @@ async function init() { textChangeSetButton.addEventListener("click", async () => { // See if anything extra must be done switch (option) { + case "backupServerAddress": case "serverAddress": { const result = validateServerAddress(textChangeInput.value); diff --git a/src/utils.ts b/src/utils.ts index 1ee5781d7c..41d8cdcbeb 100644 --- a/src/utils.ts +++ b/src/utils.ts @@ -370,7 +370,14 @@ export default class Utils { async asyncRequestToServer(type: string, address: string, data = {}): Promise { const serverAddress = Config.config.testingServer ? CompileConfig.testingServerAddress : Config.config.serverAddress; - return await (this.asyncRequestToCustomServer(type, serverAddress + address, data)); + let response = await (this.asyncRequestToCustomServer(type, serverAddress + address, data)); + + if(response.status >= 500 && response.status <= 599 && Config.config.backupServerAddress != undefined && Config.config.backupServerAddress.replace(/\/+$/, "").startsWith("http")) + { + response = await (this.asyncRequestToCustomServer(type, Config.config.backupServerAddress + address, data)); + } + + return response; } /**