1
0
Fork 0
mirror of https://github.com/sussy-code/smov.git synced 2025-01-06 17:07:41 +01:00

Add account statistic to admin page

This commit is contained in:
Cooper Ransom 2024-03-14 00:01:56 -04:00
parent c23facbd66
commit e752560301

View file

@ -1,9 +1,25 @@
import { ReactNode } from "react"; import { ReactNode, useEffect, useState } from "react";
import { Divider } from "@/components/utils/Divider"; import { Divider } from "@/components/utils/Divider";
import { Heading2 } from "@/components/utils/Text"; import { Heading2 } from "@/components/utils/Text";
import { conf } from "@/setup/config"; import { conf } from "@/setup/config";
async function getAccountNumber() {
const response = await fetch("https://backend.sudo-flix.lol/metrics");
const text = await response.text();
const regex1 =
/mw_provider_hostname_count{hostname="https:\/\/sudo-flix.lol"} (\d+)/;
const match1 = text.match(regex1);
const regex2 = /mw_user_count{namespace="movie-web"} (\d+)/;
const match2 = text.match(regex2);
if (match1 && match2) {
return match1[1] + match2[1];
}
throw new Error("ACCOUNT_NUMBER not found");
}
function ConfigValue(props: { name: string; children?: ReactNode }) { function ConfigValue(props: { name: string; children?: ReactNode }) {
return ( return (
<> <>
@ -17,17 +33,36 @@ function ConfigValue(props: { name: string; children?: ReactNode }) {
} }
export function ConfigValuesPart() { export function ConfigValuesPart() {
const [accountNumber, setAccountNumber] = useState<string | null>(null);
const [loading, setLoading] = useState(true);
const normalRouter = conf().NORMAL_ROUTER; const normalRouter = conf().NORMAL_ROUTER;
const appVersion = conf().APP_VERSION; const appVersion = conf().APP_VERSION;
const backendUrl = conf().BACKEND_URL; const backendUrl = conf().BACKEND_URL;
useEffect(() => {
getAccountNumber()
.then((number) => {
setAccountNumber(number);
setLoading(false);
})
.catch((error) => {
console.error("Error fetching account number:", error);
setLoading(false);
});
}, []);
if (loading) {
return <p>Loading...</p>;
}
return ( return (
<> <>
<Heading2 className="mb-8 mt-12">Configured values</Heading2> <Heading2 className="mb-8 mt-12">Site Constants</Heading2>
<ConfigValue name="Routing mode"> <ConfigValue name="Routing mode">
{normalRouter ? "Normal routing" : "Hash based routing"} {normalRouter ? "Normal routing" : "Hash based routing"}
</ConfigValue> </ConfigValue>
<ConfigValue name="Application version">v{appVersion}</ConfigValue> <ConfigValue name="Application version">v{appVersion}</ConfigValue>
<ConfigValue name="Backend Accounts">{accountNumber}</ConfigValue>
<ConfigValue name="Backend URL">{backendUrl}</ConfigValue> <ConfigValue name="Backend URL">{backendUrl}</ConfigValue>
</> </>
); );