Implement Domain Namespaces
External Entities
The external entity script is comprised of 3 parts: constructor, loader, and validator.
Constructor
//**
* constructor method of external entity reference
*/
public create(): void {
   const log = this.util.log;
   log.debug('Constructor.execute()');
   // Initialize the value of the associated properties to the input value store in the construc-tor parameter and to a predefined value
   this.instance.associatedProperty1 = this.input.constructorProperty1;
   this.instance.associatedProperty1 = value1;
}
Loader
The loader is used to load the external instance. This is normally done by calling a REST integration service of the integration namespace.
/**
* load method of external entity reference - loads external entity from external system
*/
public async load(): Promise<void> {
   const log = this.util.log;
   log.debug('Load.execute()');
   
  // Initialize the input of the REST integration service
   const input = this.factory.entity.cust. ServiceIdentifier_Input();
  // Initialize the input properties to their values
   input.property1 = “value1”; // or this.instance.(…)
  // Call the REST service and pass as input the the input entity created above
   const serviceOutput = await this.services.intnsacrnm.ServiceIdentifier (input);
   // Check if the output of the service is not void
   if(serviceOutput) {
     
     // Initialize the output of the loader of the external entity
     this.output = this.factory.nsacrnm.ExternalEntityIdentifier_Output()
     // Set the values of the output properties of the output
     this.output.property1 = serviceOutput.property1;
     this.output.property2 = serviceOutput.property2; 
   }
}
          Validator
The Validator gives information regarding the existence of a specific instance of an
                external entity. It usually returns true if the external instance exists and false
                if it does not exist. The Validator can also be used for updating the local insatnce
                of an External Entity if the update flag is set to true.
In a validator it is recommended to try to load the instance. If the instance is returned successfully, then return true. A validator must always return a Boolean.
/**
* validate method of external entity reference - checks if external entity still exists in exter-nal system
* @param update indicates whether local properties should be updated after validating entity on external system
* @returns boolean indicating whether external entity still exists in external system
*/
public async validate(update: boolean): Promise<boolean> {
    const log = this.util.log;
    log.debug('Validate.execute()');
    // trigger load function of external entity in order to validate whether the entity still exists
    const existance = await this.instance.load();
    // If it exists return true. Otherwise, return false.
    if(existance) {
      return true;
    } else {
      return false;
    }
}
    Factory Commands
The main purpose of a factory command is to set values to the properties of the entity and then persist those changes to the database, thus, creating a new instance.
// Exemplary implementation:
// Assign the created entity to this.instance. This will also ensure type safety
// And the factory command will return the correct instanceId automatically
// Get input to the factory command
const {inputProperty1, inputProperty2} = this.input;
// Set the instance properties to their corresponding input values
this.instance.property1 = inputProperty1;
this.instance.property2 = inputProperty2;
// Set the instance property to an initial value
this.instance.property3 = value3;
// Save changes to the database
await this.instance.persist();
Instance commands
// If a condition is satisfied, throw a business error
if( condition ){
  throw this.factory.error.nsacrnm.MyBusinessError(); 
} else { // if condition not satisfied update the value of property1 to the value newValue
  this.instance.property1 = newValue;
}
// Save changes to the database
await this.instance.persist();
// If a condition is satisfied, throw a business error
this.instance.delete();
                Events
// Initialize the event type
const event = this.factory.event.OrderAccepted();
// Initialize the value of the payload properties
event.payload.property1 = value1;
// Publish the event
await event.publish();
Agents
/// Get the payload of the event that triggered the agent
const { payloadproperty1, payloadproperty2 } =  this.input;
// Initialize the input and call the service GetOrderByNo
const input = this.factory.entity.order.ServiceIdentifier_Input();
// Initialize the property of the input entity
input.property1 = payloadproperty1;
// Call service and pass as input the input entity created above
await this.services.order.ServiceIdentifier(input);
  Domain Services
// Get the input properties
const {property1, pproperty2, id} =  this.input;
// Get an instance by ID
const insatnce1 = await this.repo.nsacrnm.EntityIdentifier.findById(id);
// Check if instance exists
if(insatnce1){
   // Initialize the output 
   this.output = this.factory.entity.order.ServiceIdentifier_Output();
   // Initialize the values of the output properties
   this.output.property1 = value1;
   this.output.property2 = value2;
}