Fixed session UI
This commit is contained in:
parent
370ff822d0
commit
a749abe7ed
@ -8,33 +8,44 @@
|
|||||||
import Icon from "@iconify/svelte";
|
import Icon from "@iconify/svelte";
|
||||||
import { createLitSession } from "./createLitSession";
|
import { createLitSession } from "./createLitSession";
|
||||||
import { connectProvider } from "./setupLit";
|
import { connectProvider } from "./setupLit";
|
||||||
|
import Signer from "./Signer.svelte";
|
||||||
|
|
||||||
const redirectUri = "http://localhost:3000/";
|
const redirectUri = "http://localhost:3000/";
|
||||||
|
|
||||||
let sessionSigs = null;
|
let sessionSigs = null;
|
||||||
let litNodeClient, error, currentPKP, authMethod, provider;
|
let error, currentPKP, authMethod, provider;
|
||||||
let status = "Initializing...";
|
let status = "Initializing...";
|
||||||
let pkps: IRelayPKP[] = [];
|
let pkps: IRelayPKP[] = [];
|
||||||
let view = "SIGN_IN";
|
let view = "SIGN_IN";
|
||||||
let sessionSigsObject;
|
let sessionStatuses;
|
||||||
|
let activeSession = null;
|
||||||
|
|
||||||
|
let messageToSign = { user: "Sam", loggedIn: true };
|
||||||
|
|
||||||
onMount(async () => {
|
onMount(async () => {
|
||||||
// litNodeClient = new LitNodeClient({ litNetwork: "serrano" });
|
initialize();
|
||||||
// await litNodeClient.connect();
|
|
||||||
const sessionSigsLocalStorage = localStorage.getItem("google-signature");
|
|
||||||
const currentPKPLocalStorage = localStorage.getItem("current-pkp");
|
|
||||||
if (sessionSigsLocalStorage && currentPKPLocalStorage) {
|
|
||||||
sessionSigs = JSON.parse(sessionSigsLocalStorage);
|
|
||||||
currentPKP = JSON.parse(currentPKPLocalStorage);
|
|
||||||
} else {
|
|
||||||
initialize();
|
|
||||||
}
|
|
||||||
if (sessionSigsLocalStorage) {
|
|
||||||
sessionSigsObject = JSON.parse(sessionSigsLocalStorage);
|
|
||||||
}
|
|
||||||
});
|
});
|
||||||
|
|
||||||
$: if (sessionSigs) {
|
$: if (sessionSigs) {
|
||||||
|
// Update sessionStatuses
|
||||||
|
sessionStatuses = Object.entries(sessionSigs).map(([node, data]) => {
|
||||||
|
const sessionKey = JSON.parse(data.signedMessage).sessionKey;
|
||||||
|
const expiration = new Date(JSON.parse(data.signedMessage).expiration);
|
||||||
|
const isExpired = expiration < new Date();
|
||||||
|
return {
|
||||||
|
node,
|
||||||
|
sessionKey,
|
||||||
|
expiration: expiration.toISOString(),
|
||||||
|
isExpired,
|
||||||
|
};
|
||||||
|
});
|
||||||
|
|
||||||
|
// Find an active session and store it in local storage
|
||||||
|
activeSession = sessionStatuses.find(({ isExpired }) => !isExpired);
|
||||||
|
if (activeSession) {
|
||||||
|
localStorage.setItem("google-session", JSON.stringify(activeSession));
|
||||||
|
}
|
||||||
|
|
||||||
view = "READY";
|
view = "READY";
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -133,29 +144,26 @@
|
|||||||
<h3>Your PKP Address:</h3>
|
<h3>Your PKP Address:</h3>
|
||||||
<p>{currentPKP.ethAddress}</p>
|
<p>{currentPKP.ethAddress}</p>
|
||||||
</div>
|
</div>
|
||||||
{/if}
|
Signer
|
||||||
<div class="mt-4 text-center">
|
<Signer {messageToSign} />
|
||||||
<h1>Status</h1>
|
Sessions
|
||||||
<p>{status}</p>
|
{#if activeSession}
|
||||||
</div>
|
<div>
|
||||||
<!-- <div class="mt-4 text-center">
|
<h3>Active Session:</h3>
|
||||||
Session Signature
|
<p>Node: {activeSession.node}</p>
|
||||||
{#if sessionSigsObject}
|
<p>Session Key: {activeSession.sessionKey}</p>
|
||||||
<div class="mt-4 text-center">
|
<p>Expiration: {activeSession.expiration}</p>
|
||||||
<h1>Session Signatures</h1>
|
|
||||||
{#each Object.keys(sessionSigsObject) as nodeAddress}
|
|
||||||
<div class="session-sig">
|
|
||||||
<h2>{nodeAddress}</h2>
|
|
||||||
<p>Signature: {sessionSigsObject[nodeAddress].sig}</p>
|
|
||||||
<p>Derived Via: {sessionSigsObject[nodeAddress].derivedVia}</p>
|
|
||||||
<p>Address: {sessionSigsObject[nodeAddress].address}</p>
|
|
||||||
<p>Algorithm: {sessionSigsObject[nodeAddress].algo}</p>
|
|
||||||
<h3>Signed Message</h3>
|
|
||||||
<pre>{sessionSigsObject[nodeAddress].signedMessage}</pre>
|
|
||||||
</div>
|
|
||||||
{/each}
|
|
||||||
</div>
|
</div>
|
||||||
{/if}
|
{/if}
|
||||||
</div> -->
|
{#each sessionStatuses as { node, sessionKey, expiration, isExpired }}
|
||||||
|
<p>
|
||||||
|
{isExpired ? "🔴" : "🟢"} Node: {node}, Session Key: {sessionKey},
|
||||||
|
Expiration: {expiration}
|
||||||
|
</p>
|
||||||
|
{/each}
|
||||||
|
{/if}
|
||||||
|
<div class="mt-4 text-center">
|
||||||
|
<p>{status}</p>
|
||||||
|
</div>
|
||||||
</div>
|
</div>
|
||||||
</div>
|
</div>
|
||||||
|
@ -1,9 +1,5 @@
|
|||||||
<script>
|
<script>
|
||||||
import GoogleAuth from "$lib/GoogleAuth.svelte";
|
import GoogleAuth from "$lib/GoogleAuth.svelte";
|
||||||
import Signer from "$lib/Signer.svelte";
|
|
||||||
|
|
||||||
let messageToSign = { user: "Sam", loggedIn: true };
|
|
||||||
</script>
|
</script>
|
||||||
|
|
||||||
<GoogleAuth />
|
<GoogleAuth />
|
||||||
<Signer {messageToSign} />
|
|
||||||
|
Loading…
Reference in New Issue
Block a user