CosTransactions_RecoveryCoordinator

This module implements the OMG CosTransactions::RecoveryCoordinator interface.

To get access to the record definitions for the structures use:
-include_lib("cosTransactions/include/CosTransactions.hrl").

Functions


replay_completion(RecoveryCoordinator, Timeout, Resource) -> Return

  • RecoveryCoordinator = #objref
  • Timeout = integer(), milliseconds | 'infinity'
  • Resource = #objref
  • Return = Status | {'EXCEPTION', E}
  • E = #'CosTransactions_NotPrepared'{}
  • Status = atom()

The RecoveryCoordinator object is returned by the operation CosTransactions_Coordinator:register_resource/3. The replay_completion/2 may only be used by the registered Resource and returns the current status of the transaction. The operation is used when recovering after a failure.

Possible Status replies:

  • 'StatusCommitted'
  • 'StatusCommitting'
  • 'StatusMarkedRollback'
  • 'StatusRollingBack'
  • 'StatusRolledBack'
  • 'StatusActive'
  • 'StatusPrepared'
  • 'StatusUnknown'
  • 'StatusNoTransaction'
  • 'StatusPreparing'

Warning!

replay_completion/3 is blocking and may cause dead-lock if a child calls this function at the same time as its parent invokes an operation on the child. Dead-lock will not occur if the timeout has any value except 'infinity'.

If the call is external incoming (intra-ORB) the timeout will not be activated. Hence, similar action must be taken if the Resource resides on another vendors ORB.

View Functions