Skip to content

Commit 70830d9

Browse files
committed
merge master
1 parent 465c41d commit 70830d9

File tree

1 file changed

+10
-3
lines changed

1 file changed

+10
-3
lines changed

packages/lit-node-client-nodejs/src/lib/lit-node-client-nodejs.ts

Lines changed: 10 additions & 3 deletions
Original file line numberDiff line numberDiff line change
@@ -2065,18 +2065,25 @@ export class LitNodeClientNodeJs
20652065
};
20662066

20672067
/**
2068-
* Get session signatures for a set of [Lit resources](https://v6-api-doc-lit-js-sdk.vercel.app/interfaces/types_src.ILitResource.html#resource).
2068+
*
2069+
* Retrieves or generates sessionSigs (think access token) for accessing Lit Network resources.
20692070
*
20702071
* How this function works on a high level:
20712072
* 1. Generate or retrieve [session keys](https://v6-api-doc-lit-js-sdk.vercel.app/interfaces/types_src.SessionKeyPair.html) (a public and private key pair)
20722073
* 2. Generate or retrieve the [`AuthSig`](https://v6-api-doc-lit-js-sdk.vercel.app/interfaces/types_src.AuthSig.html) that specifies the session [abilities](https://v6-api-doc-lit-js-sdk.vercel.app/enums/auth_helpers_src.LitAbility.html)
20732074
* 3. Sign the specific resources with the session key
20742075
*
2076+
* The process follows these steps:
2077+
* 1. Retrieves or generates a session key pair (Ed25519) for the user's device. The session key is either fetched from local storage or newly created if not found. The key does not expire.
2078+
* 2. Generates an authentication signature (`authSig`) by signing an ERC-5573 “Sign-in with Ethereum” message, which includes resource ability requests, capabilities, expiration, the user's device session public key, and a nonce. The `authSig` is retrieved from local storage, and if it has expired, the user will be prompted to re-sign.
2079+
* 3. Uses the session private key to sign the session public key along with the resource ability requests, capabilities, issuedAt, and expiration details. This creates a device-generated signature.
2080+
* 4. Constructs the session signatures (`sessionSigs`) by including the device-generated signature and the original message. The `sessionSigs` provide access to Lit Network features such as `executeJs` and `pkpSign`.
2081+
*
2082+
* See Sequence Diagram: https://www.plantuml.com/plantuml/uml/VPH1RnCn48Nl_XLFlT1Av00eGkm15QKLWY8K9K9SO-rEar4sjcLFalBl6NjJAuaMRl5utfjlPjQvJsAZx7UziQtuY5-9eWaQufQ3TOAR77cJy407Rka6zlNdHTRouUbIzSEtjiTIBUswg5v_NwMnuAVlA9KKFPN3I0x9qSSj7bqNF3iPykl9c4o9oUSJMuElv2XQ8IHAYRt3bluWM8wuVUpUJwVlFjsP8JUh5B_1DyV2AYdD6DjhLsTQTaYd3W3ad28SGWqM997fG5ZrB9DJqOaALuRwH1TMpik8tIYze-E8OrPKU5I6cMqtem2kCqOhr4vdaRAvtSjcoMkTo68scKu_Vi1EPMfrP_xVtj7sFMaHNg-6GVqk0MW0z18uKdVULTvDWtdqko28b7KktvUB2hKOBd1asU2QgDfTzrj7T4bLPdv6TR0zLwPQKkkZpIRTY4CTMbrBpg_VKuXyi49beUAHqIlirOUrL2zq9JPPdpRR5OMLVQGoGlLcjyRyQNv6MHz4W_fG42W--xWhUfNyOxiLL1USS6lRLeyAkYLNjrkVJuClm_qp5I8Lq0krUw7lwIt2DgY9oiozrjA_Yhy0
20752083
*
20762084
* Note: When generating session signatures for different PKPs or auth methods,
20772085
* be sure to call disconnectWeb3 to clear auth signatures stored in local storage
20782086
*
2079-
*
20802087
* @param { GetSessionSigsProps } params
20812088
*
20822089
* An example of how this function is used can be found in the Lit developer-guides-code repository [here](https://github.com/LIT-Protocol/developer-guides-code/tree/master/session-signatures/getSessionSigs).
@@ -2093,7 +2100,7 @@ export class LitNodeClientNodeJs
20932100
const sessionKeyUri = this.getSessionKeyUri(sessionKey.publicKey);
20942101

20952102
// First get or generate the session capability object for the specified resources.
2096-
const sessionCapabilityObject = params.sessionCapabilityObject
2103+
const sessionCapabilityObject = params.sessionCapabilityObject
20972104
? params.sessionCapabilityObject
20982105
: await this.generateSessionCapabilityObjectWithWildcards(
20992106
params.resourceAbilityRequests.map((

0 commit comments

Comments
 (0)