Skip to main content

Plugin Architecture

Amplication's Data Service Generator (DSG) service is responsible for the code generation process. This process is divided into several functions, each playing a different part in the process for both Node.js and .NET services.

To enable intervention in the code generation process, we wrap these functions in a function named pluginWrapper.

The pluginWrapper function is invoked with the following arguments:

  • func - the DSG function we want to wrap.
  • event - the name of event we want to capture, and change something in the triggered process.
  • args - the original parameters of the DSG function. These are likely to be used as the parameters of the event, for the plugin developer to have access to these params and manipulate the returned value of the function.

Event Lifecycle

Each plugin event supports two execution points:

  • before: Executes before the main event processing
  • after: Executes after the main event processing

These lifecycle hooks allow precise control over the code generation process.

For more information about before and after event see Before and After Lifecycle Functions

When the pluginWrapper function is invoked, it checks whether the event argument that was passed has a before or after property. If so, it invokes other functions that are responsible for calculating the final behavior when this event is emitted, or in other words, the outcome of the function that this event is responsible to execute.

If no part of the event lifecycle was provided or if none of its params were changed, the default behavior will be executed.

Node.js vs .NET

While the overall architecture remains similar for both Node.js and .NET services, there are distinct events and parameters for each. The Node.js events are defined in the EventNames enum, while the .NET events are defined in the DotnetEventNames enum.