cancel
Showing results for 
Search instead for 
Did you mean: 

MDK: Exception attempting to update a downloaded entity from a non-SAP OData data source

0 Kudos
552

I am extending the functionality of the SAP Asset Manager (SAM) v2005 MDK mobile application. My MDK iOS client was built using MDK Client SDK v4.3.2. I have extended SAM to interface with a non-SAP OData data source using the offline approach. I have one entity set named "Submissions" that is provided/managed by my non-SAP OData service. So far, with my extended SAM functionality I can...

  • Create a "local" Submission entity (using Action type "Action.Type.ODataService.CreateEntity")
  • Update a "local" Submission entity (using Action type "Action.Type.ODataService.UpdateEntity")
  • During synchronization, upload the "locally" created and updated Submissions entities to the non-SAP OData data source where they are processed successfully (Note: the Create Action is configured to remove the entity from the offline OData store after being uploaded)
  • During synchronization, download only the most recent version of the previously created/updated Submission entity from the non-SAP OData source to the SAM mobile app.

All the above works as expected. However, I run into an issue when I attempt to update the downloaded Submission entity using the same UpdateEntity Action that was used to successfully update the "local" Submission entities previously. At this point, the MDK Client crashes. No reason for the crash is provided. Only a stack trace is output to the console...

NativeScript caught signal 11.
Native Stack:
1   0x104b10251 sig_handler(int)
2   0x7fff522ab5fd _sigtramp
3   0xffff000112d902d7
4   0x112c9d6b0 lodata::ModifyHandler::performLocalModify(lodata::ModifyRequest*, lodata::RequestStatus*, lodata::EntityTypeInstance const*, lodata::EntitySet const*, lodata::EntityTypeInstance const*, lodata::EntitySet const*, lodata::TransactionInfo*, bool)
JS Stack unavailable. Current thread hasn't initialized a {N} runtime

Using the debugging facility of the Visual Studio Code MDK extension to inspect the Submission entity read (i.e.- queried) from the local non-SAP OData data store, I can see distinct differences between "local" Submission entities versus Submission entities "downloaded" from the non-SAP OData data source. The following two pictures show a subset of data attributes associated with the same entity. The first picture reflects when the entity was initially "local". The second picture reflects the entity after is was uploaded and processed by the non-SAP OData data source, and subsequently downloaded back to the same SAM mobile app instance.

"Local" Submission properties...

"Downloaded" Submission properties...

This is the "Create Submission Entity" Action...

This is the "Update Submission Entity" Action...

I enabled OData tracing in the MDK Client. Unfortunately, no trace information is output when the exception occurs.

Based on the "lodata" references in both the exception stack trace, as well as in the "local" entity's assigned UID value, it appears that the "UpdateEntity" Action is (possibly) expecting to only target a "local" (i.e.- a locally created) entity.

What do I need to differently when I need to update an entity that has been downloaded from an OData data source?

Or am I possibly missing required configuration information in my OData data source's EDM and/or in my Mobile Services destination for the non-SAP OData data source?

Thank you.

Accepted Solutions (1)

Accepted Solutions (1)

0 Kudos

The MDK client crash was due to the fact that our JSON representation of entities from our non-SAP OData data source did not include the "__metadata" key/value pair.

In the limited OData v2 documentation we were able to find, the "__metadata" key is described as being optional - except for Media Link Entries. Upon adding the "__metadata" key (whose value is an object that contains the keys "id" and "uri") to all our entity data representations, the MDK client crash no longer occurs when attempting to update an entity that was downloaded from our remote OData data source.

Answers (1)

Answers (1)

bill_froelich
Product and Topic Expert
Product and Topic Expert
0 Kudos

The Update Entity action does not have any special knowledge of online or offline. It can be defined against either type of service and when offline can be used to update both an existing (i.e. downloaded item) or a locally created item that has not been synchronized to the backend.

Offline odata adds the two additional properties you mentioned to help developers understand the state of the record.

@sap.isLocal true indicates the record was created locally and has not been synchronized to the backend yet.

@sap.hasPendingChanges true indicates that the record has been changed locally and not synchronized to the backend yet.

So for a newly created record both @sap.isLocal and @sap.hasPendingChanges will be true. For a downloaded record that has been updated only @sap.hasPendingChanges would be true.

For record just downloaded from your odata service, both would be false.

You should not have to do anything different in your Update action depending on if the record is locally created versus just downloaded from the backend.