Abstract service that receives commands via the AWS Lambda protocol to operations automatically generated for commands defined in ICommandable components. Each command is exposed as an invoke method that receives a command’s name and parameters.
Extends: LambdaController
Description
The CommandableLambdaController allows you to create abstract services that receive commands via the AWS Lambda protocol to operations automatically generated for commands defined in ICommandable components. Each command is exposed as an invoke method that receives a command’s name and parameters.
Important points
- This service is intended to work inside a LambdaFunction container that exploses registered actions externally.
Configuration parameters
- dependencies:
- controller: override for Controller dependency
References
- *:logger:*:*:1.0: (optional) ILogger components to pass log messages.
- *:counters:*:*:1.0: (optional) ICounters components to pass collected measurements.
Constructors
Creates a new instance of the service.
CommandableLambdaController(String? name) : super(name)
- name: string - service name.
Instance methods
register
Registers all actions in AWS Lambda function.
void register()
Examples
class MyCommandableLambdaController extends CommandableLambdaController {
MyCommandableLambdaController(): super() {
_dependencyResolver.put(
"service",
new Descriptor("mygroup","service","*","*","1.0")
);
}
}
let controller = new MyCommandableLambdaController();
controller.setReferences(References.fromTuples(
Descriptor("mygroup","service","default","default","1.0"), controller
));
await controller.open(Context.fromTraceId("123"));
console.log("The AWS Lambda controller is running");