Add metadata to ParsedGeneric submit response

This commit is contained in:
2024-05-10 05:42:43 -05:00
parent 670e8c377a
commit 597863ea70
2 changed files with 50 additions and 41 deletions

View File

@@ -23,6 +23,11 @@ import type { ParsedGeneric } from "@/components/lookup/Generic";
import { Maybe, Result } from "true-myth";
export type WarningHandler = (warning: { message: string }) => void;
export type MetaParsedGeneric = {
data: ParsedGeneric;
url: string;
completeTime: Date;
};
const useLookup = (warningHandler?: WarningHandler) => {
/**
@@ -41,14 +46,10 @@ const useLookup = (warningHandler?: WarningHandler) => {
// Used to allow repeatable lookups when weird errors happen.
const repeatableRef = useRef<string>("");
/** */
const uriType = useMemo<Maybe<TargetType>>(
function () {
if (currentType != null) return Maybe.just(currentType);
return getType(target).mapOr(
Maybe.nothing(),
(type) => Maybe.just(type)
);
return getType(target).mapOr(Maybe.nothing(), (type) => Maybe.just(type));
},
[target, currentType]
);
@@ -158,18 +159,22 @@ const useLookup = (warningHandler?: WarningHandler) => {
if (result.success === false) {
// flatten the errors to make them more readable and simple
const flatErrors = result.error.flatten(function (issue) {
const path = issue.path.map((value => value.toString())).join('.');
const path = issue.path.map((value) => value.toString()).join(".");
return `${path}: ${issue.message}`;
});
console.log(flatErrors);
// combine them all, wrap them in a new error, and return it
return Result.err(new Error([
return Result.err(
new Error(
[
"Could not parse the response from the registry.",
...flatErrors.formErrors,
...Object.values(flatErrors.fieldErrors).flat(),
].join('\n\t')));
].join("\n\t")
)
);
}
return Result.ok(result.data);
@@ -216,7 +221,9 @@ const useLookup = (warningHandler?: WarningHandler) => {
}
}
async function submitInternal(target: string): Promise<Result<ParsedGeneric, Error>> {
async function submitInternal(
target: string
): Promise<Result<{data: ParsedGeneric, url: string}, Error>> {
if (target == null || target.length == 0)
return Result.err(
new Error("A target must be given in order to execute a lookup.")
@@ -238,17 +245,15 @@ const useLookup = (warningHandler?: WarningHandler) => {
await loadBootstrap("ip4");
const url = getRegistryURL(targetType.value, target);
const result = await getAndParse<IpNetwork>(url, IpNetworkSchema);
if (result.isErr)
return Result.err(result.error);
return Result.ok(result.value);
if (result.isErr) return Result.err(result.error);
return Result.ok({data: result.value, url});
}
case "ip6": {
await loadBootstrap("ip6");
const url = getRegistryURL(targetType.value, target);
const result = await getAndParse<IpNetwork>(url, IpNetworkSchema);
if (result.isErr)
return Result.err(result.error);
return Result.ok(result.value);
if (result.isErr) return Result.err(result.error);
return Result.ok({data: result.value, url});
}
case "domain": {
await loadBootstrap("domain");
@@ -266,10 +271,9 @@ const useLookup = (warningHandler?: WarningHandler) => {
);
}
const result = await getAndParse<Domain>(url, DomainSchema);
if (result.isErr)
return Result.err(result.error);
if (result.isErr) return Result.err(result.error);
return Result.ok(result.value);
return Result.ok({data: result.value, url});
}
case "autnum": {
await loadBootstrap("autnum");
@@ -278,9 +282,8 @@ const useLookup = (warningHandler?: WarningHandler) => {
url,
AutonomousNumberSchema
);
if (result.isErr)
return Result.err(result.error);
return Result.ok(result.value);
if (result.isErr) return Result.err(result.error);
return Result.ok({data: result.value, url});
}
case "url":
case "tld":
@@ -295,7 +298,7 @@ const useLookup = (warningHandler?: WarningHandler) => {
async function submit({
target,
}: SubmitProps): Promise<Maybe<ParsedGeneric>> {
}: SubmitProps): Promise<Maybe<MetaParsedGeneric>> {
try {
// target is already set in state, but it's also provided by the form callback, so we'll use it.
const response = await submitInternal(target);
@@ -303,15 +306,19 @@ const useLookup = (warningHandler?: WarningHandler) => {
if (response.isErr) {
setError(response.error.message);
console.error(response.error);
}
else setError(null);
} else setError(null);
return response.isOk ? Maybe.just(response.value) : Maybe.nothing();
return response.isOk ? Maybe.just(
{
data: response.value.data,
url: response.value.url,
completeTime: new Date(),
}
) : Maybe.nothing();
} catch (e) {
if (!(e instanceof Error))
setError("An unknown, unprocessable error has occurred.");
else
setError(e.message);
else setError(e.message);
console.error(e);
return Maybe.nothing();
}

View File

@@ -1,7 +1,8 @@
import { type NextPage } from "next";
import Head from "next/head";
import { useState } from "react";
import Generic, { type ParsedGeneric } from "@/components/lookup/Generic";
import Generic from "@/components/lookup/Generic";
import type { MetaParsedGeneric } from "@/hooks/useLookup";
import useLookup from "@/hooks/useLookup";
import { OGP } from "react-ogp";
import LookupInput from "@/components/form/LookupInput";
@@ -12,8 +13,10 @@ import { getType } from "@/rdap";
const Index: NextPage = () => {
const { error, setTarget, setTargetType, submit } = useLookup();
const [detectedType, setDetectedType] = useState<Maybe<TargetType>>(Maybe.nothing());
const [response, setResponse] = useState<ParsedGeneric | null>();
const [detectedType, setDetectedType] = useState<Maybe<TargetType>>(
Maybe.nothing()
);
const [response, setResponse] = useState<Maybe<MetaParsedGeneric>>(Maybe.nothing());
const [isLoading, setLoading] = useState<boolean>(false);
return (
@@ -59,14 +62,11 @@ const Index: NextPage = () => {
onSubmit={async function (props) {
try {
setLoading(true);
const result = await submit(props);
if (result.isJust)
setResponse(result.value);
else
setResponse(null);
setResponse(await submit(props));
setLoading(false);
} catch (e) {
setResponse(null);
console.error(e);
setResponse(Maybe.nothing());
setLoading(false);
}
}}
@@ -78,7 +78,9 @@ const Index: NextPage = () => {
className="mb-2"
/>
) : null}
{response != null ? <Generic url={"https://google.com"} data={response} /> : null}
{response.isJust ? (
<Generic url={response.value.url} data={response.value.data} />
) : null}
</div>
</div>
</>