cancel
Showing results for 
Search instead for 
Did you mean: 
cancel
Showing results for 
Search instead for 
Did you mean: 

Community Tip - New to the community? Learn how to post a question and get help from PTC and industry experts! X

Failing to persist session data on reload or navigation from one mashup to another

bootstrap
12-Amethyst

Failing to persist session data on reload or navigation from one mashup to another

Scenario:

User sets a value that needs to be persisted for the session until the user logs out or sets a new value himself.

 

What's done so far

 

1. Created thingshape > added it to the user subsystem > property in the ThingShape is persistent

2. On the mashup there's a text box to accept value from the user > set button which calls the setter service with following code :

 Resources["CurrentSessionInfo"].SetGlobalSessionStringValue({
	name: "unitNumber" /* STRING */,
	value: unitNumber /* STRING */
});

3. There's a label widget on the mashup to show the value set by the user, which calls the Resources["CurrentSessionInfo"].GetGlobalSessionValues which returns a persistent property value unitNumber, set above by the setter service.

4. ServiceInvokeCompleted event from the setter service is bound to the Getter to return this value.

5. This works fine

 

Problem:

Once the mashup is refreshed or user navigates from current mashup to another and comes back, the session value for unitNumber set by the user disappears.

 

Not sure if I am missing any further step to persist this. Could someone please help point my mistake here

 

Thanks!

 

EDIT:

TWX version : 8.4.2

ACCEPTED SOLUTION

Accepted Solutions

Ok I think i found the issue, it is about setting textBox widget value directly with the session parameter. This should not be done, (also noted in that article I added in my previous response)

 

To make it persistent value need to run through the setter service and not via the Session parameter in the mashup.

View solution in original post

10 REPLIES 10

Hi,

 

If the getter only executes on service invoke completed of the setter, you will not be able to see the session value on a new page load.

Bind as a trigger to the getter the mashup loaded as well - or bind the session variable directly.

If you're interested, in developer tools you can also use TW.Runtime.Session.GetSessionValue("MyKey") to see what value is stored on the client side - use it only to check, but not in production code, as it's not guaranteed not to change in future. 

 

Thanks! @VladimirRosu 

 

I missed to add this info but i do i have bind on getter when page reloads so basically the getter is also executed them page is refreshed or when user navigates back to this mashup.

 

This I wasn't aware, but just wondering how does TW.Runtime.Session.GetSessionValue("MyKey")  differ from the Resource > GetGlobalSessionValues?

 

I did test with binding the session variable directly to the label widget.

 

One is executed server side, the resource approach, and the TW.Runtime is executed locally in the browser, internally, by the Mashup runtime.

I would use the javascript code in the console to check if internally the Mashup Runtime has the value you have set.

Ideally the results of both methods should be in sync.

The Session Variables themselves exist across the browser and the server at the same time.

Can you somehow attach the example mashup here?

 

Appreciate your quick response on this

 

Here's the mashup and the service bound to the widget label-49.

 

I tested with your suggestion executing TW session in dev console, it returns valid value as long as I don't refresh. After  refresh value is trashed. Even through the property in the ThingShape is persistent

 

OK, so in my 8.4.3 ThingWorx version I did the following:

-created a Thing with 2 services: Get -> String, and Set(STRING) -> nothing

-created a TestMashup, which has 2 widgets: Label and Navigation widget. This mashup uses the Get service, and the result is bound to the label. The Navigation points to the SetVarMashup

-created a SetVar mashup, which has 2 widgets: TextBox and Button.This Mashup uses the Set service, and the TextBox Input is bound to the Set service input.

I did not use any direct bindings to session.

I have set the navigation to popup, full screen and replace, and each time I had in the values I set in the TestMashup.

 

Perhaps unrelated, what I discovered though, is that calling the Set service did not affect the TW.Runtime.Session.GetSessionValue result, and I believe as a consequence, neither the label IF I bounded that to the Session variable in the UI. I think this is a bug, but I need to investigate more

Another discovery. The Server to Client session data synchronization only happens when loading the page. I guessed this was the case, but I'm able to confirm that by looking at the TW.Runtime.SessionStartup function from the mashup-runtime.js?_v=8.4.3 (Developer Tools/Sources, in the Thingworx/Runtime/js folder).

The following behavior is correct:

-if you set a session variable directly with the UI (eg: textbox Text to Session binding), this gets propagated to the server

-if you set a variable on the server (through the Resource approach), it won't get propagated on the client, because of the discovery above. Pressing F5 triggers the reload and you'll get the new session variable.

 

Thank you for checking this.

I think when I set the session variable it happens in the runtime session just that for setting the session variable I do use resource set session value service (don't remember the exact name) but I'll try your way too as soon as I am back to it.

Good. Let me know what happens ;)

So finally I could get back to this topic and retried with the option that you talked about i.e. :

 

if you set a session variable directly with the UI (eg: textbox Text to Session binding), this gets propagated to the server

 

This only works as long as I am not refreshing the mashup or if am not navigating away. Until then I can see the value with the Runtime function that you shared via developer console the moment I refresh value disappears.

 

BTW, something I noticed there is a function that only shows up when writing JS in the service with CTL + Space called Get & Set SessionValue. So far I was only using SetGlobalSessionStringValue and GetGlobalSessionValues. Do you think GlobalSession services are not the right services to use for setting such session values?

 

I somehow remember with the older version it was pretty straight forward and all the steps that I am following seems to also match with this article Understanding Session Variables in ThingWorx

 

Thanks again for your continued help on this!

Ok I think i found the issue, it is about setting textBox widget value directly with the session parameter. This should not be done, (also noted in that article I added in my previous response)

 

To make it persistent value need to run through the setter service and not via the Session parameter in the mashup.

Announcements


Top Tags