From 5cbc45aedbae61bcc680786802e82e6a67eb10ca Mon Sep 17 00:00:00 2001 From: Zwifi Date: Fri, 13 Dec 2024 17:07:32 +0100 Subject: [PATCH] Custom fields browser-based tests (#1189) * Prepare demo * fixup! Prepare demo * Fix browser test app * Fix browser-based test * fixup! Fix browser-based test * Apply suggestions from code review --------- Co-authored-by: Pete Edwards --- .../components/accessGrants/index.tsx | 152 ++++++++++++++++-- e2e/browser/test/e2e.playwright.ts | 14 +- 2 files changed, 153 insertions(+), 13 deletions(-) diff --git a/e2e/browser/test-app/components/accessGrants/index.tsx b/e2e/browser/test-app/components/accessGrants/index.tsx index eee31fb3e..a90d832a0 100644 --- a/e2e/browser/test-app/components/accessGrants/index.tsx +++ b/e2e/browser/test-app/components/accessGrants/index.tsx @@ -20,12 +20,19 @@ // import { getDefaultSession } from "@inrupt/solid-client-authn-browser"; -import type { AccessGrant } from "@inrupt/solid-client-access-grants"; +import type { + AccessGrant, + DatasetWithId, +} from "@inrupt/solid-client-access-grants"; import { issueAccessRequest, redirectToAccessManagementUi, getAccessGrant, cancelAccessRequest, + getCustomFields, + getResourceOwner, + getResources, + getAccessModes, } from "@inrupt/solid-client-access-grants"; import { getPodUrlAll, @@ -39,14 +46,63 @@ import { useRouter } from "next/router"; const session = getDefaultSession(); const SHARED_FILE_CONTENT = "Some content.\n"; +function AccessCredential({ + vc, + testId, +}: { + vc: DatasetWithId | undefined; + testId: "access-request" | "access-grant"; +}) { + if (vc === undefined) { + return undefined; + } + return ( +
+

+ Resource owner:{" "} + {getResourceOwner(vc)} +

+

+ Requested resources:{" "} + {getResources(vc)} +

+

+ Requested modes:{" "} + + {JSON.stringify(getAccessModes(vc))} + +

+

+ Custom fields:{" "} + + {JSON.stringify(getCustomFields(vc))} + +

+
+ ); +} + export default function AccessController({ setErrorMessage, }: { setErrorMessage: (msg: string) => void; }) { const [accessGrant, setAccessGrant] = useState(); - const [accessRequest, setAccessRequest] = useState(); + const [accessRequestUrl, setAccessRequestUrl] = useState(); + const [accessRequest, setAccessRequest] = useState(); const [sharedResourceIri, setSharedResourceIri] = useState(); + const [customInt, setCustomInt] = useState(); + const [customIntUrl, setCustomIntUrl] = useState( + "https://example.org/my-int", + ); + const [customStr, setCustomStr] = useState(); + const [customStrUrl, setCustomStrUrl] = useState( + "https://example.org/my-string", + ); + const [customBoolean, setCustomBoolean] = useState(); + const [customBooleanUrl, setCustomBooleanUrl] = useState( + "https://example.org/my-boolean", + ); const router = useRouter(); const handleCreate = async () => { @@ -103,9 +159,25 @@ export default function AccessController({ }, { fetch: session.fetch, + returnLegacyJsonld: false, + customFields: new Set([ + { + key: new URL(customIntUrl), + value: customInt!, + }, + { + key: new URL(customStrUrl), + value: customStr!, + }, + { + key: new URL(customBooleanUrl), + value: customBoolean!, + }, + ]), }, ); setAccessRequest(accessRequestReturned); + setAccessRequestUrl(accessRequestReturned.id); }; const handleRevoke = async () => { @@ -117,6 +189,7 @@ export default function AccessController({ fetch: session.fetch, }); setAccessRequest(undefined); + setAccessRequestUrl(undefined); }; const handleCallAuthedGrant = async () => { @@ -129,15 +202,20 @@ export default function AccessController({ }; const handleAccessRequest = async () => { + if (accessRequestUrl === undefined || !URL.canParse(accessRequestUrl)) { + console.error( + "Please issue an Access Request and provide its URL before being redirected.", + ); + return; + } await redirectToAccessManagementUi( - // eslint-disable-next-line @typescript-eslint/no-non-null-assertion - accessRequest!, + accessRequestUrl, `http://localhost:3000/`, { redirectCallback: (url: string) => { window.location.replace(url); }, - fallbackAccessManagementUi: `https://amc.inrupt.com/accessRequest/`, + fallbackAccessManagementUi: "https://amc.inrupt.com/accessRequest/", fetch: session.fetch, }, ); @@ -181,6 +259,59 @@ export default function AccessController({ Created resource:{" "} {sharedResourceIri}

+

+ Custom fields:{" "} +

+ setCustomIntUrl(e.currentTarget.value)} + /> + {": "} + + setCustomInt(Number.parseInt(e.currentTarget.value, 10)) + } + /> +
+ setCustomStrUrl(e.currentTarget.value)} + /> + {": "} + setCustomStr(e.currentTarget.value)} + /> +
+ setCustomBooleanUrl(e.currentTarget.value)} + /> + {": "} + setCustomBoolean((prev) => !prev)} + /> +
+
+

Access Request to Approve:{" "} { - setAccessRequest(e.currentTarget.value); + setAccessRequestUrl(e.currentTarget.value); }} + value={accessRequestUrl} />

@@ -217,15 +349,11 @@ export default function AccessController({

Issued access request:{" "} -

-          {accessRequest && JSON.stringify(accessRequest, null, 2)}
-        
+

Granted access:{" "} -

-          {accessGrant && JSON.stringify(accessGrant, null, 2)}
-        
+