-
Notifications
You must be signed in to change notification settings - Fork 135
New issue
Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.
By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.
Already on GitHub? Sign in to your account
Updating SessionStorage data format to additionally scope data #1442
Conversation
✅ Deploy Preview for fdc3 canceled.
|
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
LGTM
I read the docs and I'm afraid I couldn't figure out what it's trying to tell me. It talks about generating a key by appending Ah... I think I have it. The identityURL is used as the key in the session storage. The key above is then used within the object saved to session storage. so you would access it something like this: const sessionData = sessionStorage.get(myApIdentityUrl);
const agentDetails = sessionStorage["FDC3-Desktop-Agent-Details-myWindowName"]; I think that it might make it clearer if you include some sample code like that.... (there is always the possibility that I am just being stupid and it's perfectly clear to everyone else!) |
HI @Roaders, thanks for reading that and for the code suggestion that would make it clearer. I did intend it the other way round: const sessionData:SessionStorageFormat = sessionStorage.get("FDC3-Desktop-Agent-Details-myWindowName");
const agentDetails: DesktopAgentDetails = sessionStorage["myApIdentityUrl"]; As multiple (same-origin) apps could have been loaded in one window. I'll drop an update to clarify. |
Much clearer (to me). SLight mistake in teh code though. You refer to const sessionData:SessionStorageFormat = sessionStorage.get("FDC3-Desktop-Agent-Details-myWindowName");
const agentDetails: DesktopAgentDetails = sessionData["myApIdentityUrl"]; |
Well spotted @Roaders - fixed. |
Approved at SWG #1458 |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
LGTM
@novavi this is implemented in fdc3-for-web-getAgent-refactor via functions in this file: https://github.com/finos/FDC3/blob/fdc3-for-web-impl-getAgent-refactor/packages/fdc3-get-agent/src/sessionStorage/DesktopAgentDetails.ts The functions are then used in a few places in the getAgent implementation in this file: https://github.com/finos/FDC3/blob/fdc3-for-web-impl-getAgent-refactor/packages/fdc3-get-agent/src/strategies/getAgent.ts It's all working well and to the updated spec, hence I think this PR to update the docs to match is ready to merge, it just needs your approval. |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
LGTM
Describe your change
Updates the description of and types governing the use SessionStorage by getAgent to scope the data by
identityUrl
andwindow.name
, thus ensuring iframes in a common window don't overwrite each others data and data for multiple different apps on teh same origin can be retained (to support navigating to a different app and then back again).Docs preview deeplink: https://deploy-preview-1442--fdc3.netlify.app/docs/next/api/ref/GetAgent#persisted-connection-data
Related Issue
resolves #1430
Contributor License Agreement
Review Checklist
DesktopAgent
,Channel
,PrivateChannel
,Listener
,Bridging
)?JSDoc comments on interfaces and types should be matched to the main documentation in /docs
Conformance test definitions should cover all required aspects of an FDC3 Desktop Agent implementation, which are usually marked with a MUST keyword, and optional features (SHOULD or MAY) where the format of those features is defined
The Web Connection protocol and Desktop Agent Communication Protocol schemas must be able to support all necessary aspects of the Desktop Agent API, while Bridging must support those aspects necessary for Desktop Agents to communicate with each other
npm run build
) run and the results checked in?Generated code will be found at
/src/api/BrowserTypes.ts
and/or/src/bridging/BridgingTypes.ts
BaseContext
schema applied viaallOf
(as it is in existing types)?title
anddescription
provided for all properties defined in the schema?npm run build
) run and the results checked in?Generated code will be found at
/src/context/ContextTypes.ts