feat: add ISP check

This commit is contained in:
thehrz 2024-08-20 19:52:11 +08:00
parent 7ac3ba4fd2
commit 75c1187b54
Signed by: thehrz
GPG Key ID: C84CBCE7D5F88855
4 changed files with 105 additions and 51 deletions

View File

@ -1,13 +1,10 @@
"use client" "use client"
import { CheckItemIconState, CheckItemType } from "@/types/CheckItem" import { CheckItemIconState, CheckItemType } from "@/types/CheckItem"
import { Icon } from "@iconify/react/dist/iconify.js" import { Icon } from "@iconify/react/dist/iconify.js"
import useSWRImmutable from "swr/immutable" import { useQuery } from "@tanstack/react-query"
type CheckItemProps = CheckItemType type CheckItemProps = CheckItemType
const fetcher = (url: string | URL | Request) =>
fetch(url).then((r) => r.json())
const icon = { const icon = {
ok: ( ok: (
<Icon <Icon
@ -30,8 +27,16 @@ const icon = {
), ),
} }
export default function CheckItem({ name, url, content }: CheckItemProps) { export default function CheckItem({
const { data, error, isLoading } = useSWRImmutable<any, Error>(url, fetcher) id,
name,
fetcher,
content,
}: CheckItemProps) {
const { data, error, isLoading } = useQuery({
queryKey: [id],
queryFn: fetcher,
})
return ( return (
<> <>
@ -41,11 +46,13 @@ export default function CheckItem({ name, url, content }: CheckItemProps) {
: isLoading : isLoading
? icon["loading"] ? icon["loading"]
: data != undefined : data != undefined
? icon[content(data).state] ? icon[content(data).state ?? "ok"]
: null} : null}
<div> <div>
<span className="mr-4"><b>{name}</b></span> <span className='mr-4'>
<b>{name}</b>
</span>
<span> <span>
{data != undefined {data != undefined

View File

@ -1,51 +1,94 @@
"use client" "use client"
import CheckItem from "./CheckItem" import CheckItem from "./CheckItem"
import { CheckItemType } from "@/types/CheckItem" import { CheckItemType } from "@/types/CheckItem"
import { useRef } from "react"
import { QueryClient, QueryClientProvider } from "@tanstack/react-query"
export default function Checker() {
const IPv4 = useRef("")
const IPv6 = useRef("")
const checkList: CheckItemType[] = [ const checkList: CheckItemType[] = [
{ {
id: "IPv6",
name: "公网 IPv6 地址", name: "公网 IPv6 地址",
url: "https://6.ipv6test.online/ip/myip", fetcher: () => fetch("https://test.ipv6test.online/ip/myip").then((res) => res.json()),
content: (data) => { content: (data) => {
const success = data?.version == 6 const success = data?.version == 6
if (success && data.address != null) {
IPv6.current = data.address
}
return { return {
state: success ? "ok" : "error", state: success ? "ok" : "error",
text: (success ? `${data?.address}` : "未检测到"), text: success ? `${data?.address}` : "未检测到",
} }
}, },
}, },
{ {
id: "IPv4",
name: "公网 IPv4 地址", name: "公网 IPv4 地址",
url: "https://4.ipv6test.online/ip/myip", fetcher: () => fetch("https://test.ipv6test.online/ip/myip").then((res) => res.json()),
content: (data) => { content: (data) => {
const success = data?.version == 4 const success = data?.version == 4
if (success && data.address != null) {
IPv4.current = data.address
}
return { return {
state: success ? "ok" : "error", state: success ? "ok" : "error",
text: (success ? `${data?.address}` : "未检测到"), text: success ? `${data?.address}` : "未检测到",
} }
}, },
}, },
{ {
id: "ipv4andipv6",
name: "双协议栈测试", name: "双协议栈测试",
url: "https://test.ipv6test.online/ip/myip", fetcher: () => fetch("https://test.ipv6test.online/ip/myip").then((res) => res.json()),
content: (data) => { content: (data) => {
const isIPv6 = data?.version == 6 const isIPv6 = data?.version == 6
const isIPv4 = data?.version == 4 const isIPv4 = data?.version == 4
return { return {
state: isIPv6 ? "ok" : "error", state: isIPv6 ? "ok" : "error",
text: isIPv6 ? "你的网络IPv6访问优先" : isIPv4 ? "你的网络IPv4访问优先" : "未检测到", text: isIPv6 ? "IPv6访问优先" : isIPv4 ? "IPv4访问优先" : "未检测到",
}
},
},
{
id: "ISP",
name: "ISP",
fetcher: () =>
fetch("https://test.ipv6test.online/ip/isp", {
method: "POST",
body: JSON.stringify({
address: IPv6.current,
}),
}).then((res) => res.json()),
content: (data) => {
return {
text: data.isp,
} }
}, },
}, },
] ]
export default function Checker() { const queryClient = new QueryClient();
return ( return (
<> <QueryClientProvider client={queryClient}>
{checkList.map((item, i) => { {checkList.map((item, i) => {
return <CheckItem key={i} name={item.name} url={item.url} content={item.content} /> return (
<CheckItem
key={i}
id={item.id}
name={item.name}
fetcher={item.fetcher}
content={item.content}
/>
)
})} })}
</> </QueryClientProvider>
) )
} }

View File

@ -1,7 +1,8 @@
export interface CheckItemType { export interface CheckItemType {
id: string
name: string name: string
url: string fetcher: () => Promise<any>
content: (data: any) => {state: CheckItemIconState, text: string} content: (data: any) => {state?: CheckItemIconState, text: string}
} }
export type CheckItemIconState = "ok" | "loading" | "info" | "error" export type CheckItemIconState = "ok" | "loading" | "info" | "error"

3
src/types/ISPResponse.ts Normal file
View File

@ -0,0 +1,3 @@
export default interface ISPResponse {
isp: string
}