Executor's Command are dedicated to contain purely business logic that should be executed. 
 It should not have any reference to underlying process engine and should not be concerned
 with any process runtime related logic such us completing work item, sending signals, etc.
 
 Information that are taken from process will be delivered as part of data instance of 
 
CommandContext. Depending on the execution context that data can vary but 
 in most of the cases following will be given:
 
  
  - businessKey - usually unique identifier of the caller
 
  - callbacks - FQCN of the 
CommandCollback that shall be used on command completion 
 
 When executed as part of the process (work item handler) additional data can be expected:
 
  - workItem - the actual work item that is being executed with all it's parameters
 
  - processInstanceId - id of the process instance that triggered this work
 
  - deploymentId - if given process instance is part of an active deployment
 
 
 Important note about implementations is that it shall always be possible to be initialized with default constructor
 as executor service is an async component so it will initialize the command on demand using reflection.
 In case there is a heavy logic on initialization it should be placed in another service implementation that 
 can be looked up from within command.