From 5ea284ae873536345b2eab181162e02fd5b7ac5c Mon Sep 17 00:00:00 2001 From: Cooper Ransom Date: Tue, 26 Mar 2024 19:37:35 -0400 Subject: [PATCH] Add better scrape error messages for the extension --- public/config.js | 10 +-- src/assets/locales/en.json | 8 +++ src/pages/parts/player/ScrapeErrorPart.tsx | 77 +++++++++++++++++++--- 3 files changed, 81 insertions(+), 14 deletions(-) diff --git a/public/config.js b/public/config.js index feb65e84..b19ec99c 100644 --- a/public/config.js +++ b/public/config.js @@ -1,19 +1,19 @@ window.__CONFIG__ = { // The URL for the CORS proxy, the URL must NOT end with a slash! // If not specified, the onboarding will not allow a "default setup". The user will have to use the extension or set up a proxy themselves - VITE_CORS_PROXY_URL: "", + VITE_CORS_PROXY_URL: "https://sudo-proxy.up.railway.app", // The READ API key to access TMDB - VITE_TMDB_READ_API_KEY: "", + VITE_TMDB_READ_API_KEY: "eyJhbGciOiJIUzI1NiJ9.eyJhdWQiOiJhZTljNGE2ZDE1ZDFiODZiNzdlMWQyYmI5ZGY0MzdmYyIsInN1YiI6IjY1YjNmMWI0NTk0Yzk0MDE2MzNkZDBjNSIsInNjb3BlcyI6WyJhcGlfcmVhZCJdLCJ2ZXJzaW9uIjoxfQ.kAX7TkbKuJkNty6IsjcCLnoENFicVZn6d6DkLQsy3p8", // The DMCA email displayed in the footer, null to hide the DMCA link - VITE_DMCA_EMAIL: null, + VITE_DMCA_EMAIL: "dev@sudo-flix.lol", // Whether to disable hash-based routing, leave this as false if you don't know what this is - VITE_NORMAL_ROUTER: false, + VITE_NORMAL_ROUTER: true, // The backend URL to communicate with - VITE_BACKEND_URL: null, + VITE_BACKEND_URL: "backend.sudo-flix.lol", // A comma separated list of disallowed IDs in the case of a DMCA claim - in the format "series-" and "movie-" VITE_DISALLOWED_IDS: "", diff --git a/src/assets/locales/en.json b/src/assets/locales/en.json index eeda3629..10f324b0 100644 --- a/src/assets/locales/en.json +++ b/src/assets/locales/en.json @@ -388,6 +388,14 @@ "homeButton": "Go home", "text": "We have searched through our providers and cannot find the media you are looking for! We do not host the media and have no control over what is available. Please click 'Show details' below for more details.", "title": "We couldn't find that" + }, + "extensionFailure": { + "badge": "Not found", + "homeButton": "Go home", + "enableExtension": "Enable extension", + "disabledTitle": "Extension disabled", + "text": "You've installed the movie-web extension. To start using it, complete a few preliminary steps. Have you enabled the extension for this site?", + "title": "Extension Disabled" } }, "time": { diff --git a/src/pages/parts/player/ScrapeErrorPart.tsx b/src/pages/parts/player/ScrapeErrorPart.tsx index 127a69a6..a6a89fd9 100644 --- a/src/pages/parts/player/ScrapeErrorPart.tsx +++ b/src/pages/parts/player/ScrapeErrorPart.tsx @@ -1,7 +1,9 @@ -import { useMemo } from "react"; -import { useTranslation } from "react-i18next"; +import { useEffect, useMemo, useState } from "react"; +import { Trans, useTranslation } from "react-i18next"; import { useLocation } from "react-router-dom"; +import { isAllowedExtensionVersion } from "@/backend/extension/compatibility"; +import { extensionInfo, sendPage } from "@/backend/extension/messaging"; import { Button } from "@/components/buttons/Button"; import { Icons } from "@/components/Icon"; import { IconPill } from "@/components/layout/IconPill"; @@ -14,6 +16,14 @@ import { getProviderApiUrls } from "@/utils/proxyUrls"; import { ErrorCardInModal } from "../errors/ErrorCard"; +type ExtensionStatus = + | "unknown" + | "failed" + | "disallowed" + | "noperms" + | "outdated" + | "success"; + export interface ScrapeErrorPartProps { data: { sources: Record; @@ -21,10 +31,24 @@ export interface ScrapeErrorPartProps { }; } +async function getExtensionState(): Promise { + const info = await extensionInfo(); + if (!info) return "unknown"; // cant talk to extension + if (!info.success) return "failed"; // extension failed to respond + if (!info.allowed) return "disallowed"; // extension is not enabled on this page + if (!info.hasPermission) return "noperms"; // extension has no perms to do it's tasks + if (!isAllowedExtensionVersion(info.version)) return "outdated"; // extension is too old + return "success"; // no problems +} + export function ScrapeErrorPart(props: ScrapeErrorPartProps) { const { t } = useTranslation(); const modal = useModal("error"); const location = useLocation(); + const [extensionState, setExtensionState] = + useState("unknown"); + const [title, setTitle] = useState(t("player.scraping.notFound.title")); + const [icon, setIcon] = useState(Icons.WAND); const error = useMemo(() => { const data = props.data; @@ -42,14 +66,42 @@ export function ScrapeErrorPart(props: ScrapeErrorPartProps) { return str; }, [props, location]); + useEffect(() => { + getExtensionState().then((state) => { + setExtensionState(state); + if (state === "disallowed") { + setTitle(t("player.scraping.extensionFailure.disabledTitle")); + setIcon(Icons.LOCK); + } + }); + }, [t]); + return ( - - {t("player.scraping.notFound.badge")} - - {t("player.scraping.notFound.title")} - {t("player.scraping.notFound.text")} + {t("player.scraping.notFound.badge")} + {title} + + {extensionState === "disallowed" ? ( + + ), + }} + /> + ) : ( + + ), + }} + /> + )} +