DecisionMaker can be thought of like a wallet manager plus "economic brain" of the AEA. It is responsible for the AEA's crypto-economic security and goal management, and it contains the preference and ownership representation of the AEA. The decision maker is the only component which has access to the wallet's private keys.
Interaction with skills
Skills communicate with the decision maker via
Messages. At present, the decision maker processes messages of two protocols:
SigningMessage: it is used by skills to propose a transaction to the decision-maker for signing.
A message, say
msg, is sent to the decision maker like so from any skill:
The decision maker processes messages and can accept or reject them.
Messages from the decision maker in a given skill you need to create a
Handler, in particular a
SigningHandler like so:
protocol_id = SigningMessage.protocol_id
def handle(self, message: Message):
Handle a signing message.
:param message: the signing message from the decision maker.
# code to handle the message
The framework implements a default
DecisionMakerHandler. You can also implement your own and mount it.
No further configuration is needed to use the default. To use the advanced decision maker handler, add the following configuration to the
aea-config.yaml of your AEA (on page 1):
The easiest way to add a custom decision maker handler is to run the following command to scaffold a custom
aea scaffold decision-maker-handler
You can then implement your own custom logic to process messages and interact with the
For examples how to use these concepts have a look at the
tac_ skills. These functionalities are experimental and subject to change.