References

CPS-799 - Getting issue details... STATUS

Issues/Decisions

#IssueNotesDecision
1


Proposal

The state of a given cmhandle consists of the cmhandle state itself as well as the synchronization state information related to the model instance data related to the cmhandle.  Below shows the makeup of this state follow by the allowed cmhandle state transitions.


           


NCMP CRUD / Action requests are only allowed if state.cmhandleState == READY.

CRUD / Action requests are rejected with IllegalStateException for all other cmHandleStates.

Requests to get state / public properties / cmhandle metadata are always allowed on a cmhandle regardless of the value of 'state'.

CmHandle state transitions : 



Supported NCMP API Requests  (CPS-E-05):  

------ Sync : Get the current state of a cmhandle when cmhandle is READY ----------------
    Request (sync)
           GET  {ncmp-root}/ncmp/v1/ch/<cmhandle>/state
           Accept: application/json

     Response 
           "state" : {
                "cmHandleState" : "READY",
                "dataSyncEnabled" : true,
                "dataSyncState" : {  *
                   operational {
                       "state" : "SYNCHRONIZED",
                       "lastSyncTime" : "2022-04-01 07:37:20"
                   }
                }
            }    

*  runningStoreState is not included in response if it does not exist / is not supported (yet)           
   

------ Sync :Get the current state of a cmhandle when cmhandle is LOCKED ---------------
    Request (sync)
           GET  {ncmp-root}/ncmp/v1/ch/<cmhandle>/state
           Accept: application/json

     Response 
           "state" : {
               "cmHandleState" : "LOCKED",
               "lockReason"    : {
                     "reason"  : "LOCKED_MISBEHAVING",
                     "details" : "Error recovering Modules for cmhandle"
                }
            }
               

------ Async : Get the current state of a cmhandle when cmhandle is READY ---------------- 
     Request (async)
            GET  {ncmp-root}/ncmp/v1/ch/<cmhandle>/state?topic=<topic-name>
            Accept: application/json

    Response 
            {
               "requestId" : "dffrtg56-rt56"
            }

    Event :

             "requestId" : "dffrtg56-rt56",
             "data" : {
                 "cmhandle" : "dfsdgfw454df",
                 "state" : {
                    "cmHandleState" : "READY",
                    "dataSyncEnabled" : true,
                    "dataSyncState" : {
                        operational { 
                            "state" : "SYNCHRONIZED",
                           "lastSyncTime" : "2022-04-01 07:37:20"
                       }
                    }
                }
              }
                  




  • No labels

2 Comments

  1. Review Comments : 

    1. Add reason for state transitions
    2. dataSync for each supported datastore.
    3. Missing one state transition from ADVISED → LOCKED
  2. 25.01.2022 : Post review changes approved by Toine