Philosophy
When you are adopting a framework, it’s important to know not only what it does but how it is designed. These are the principles that Laconia follows:
Be a non-intrusive framework
Your application code doesn't need to depend on the Laconia directly. Developers should be able to switch to other frameworks easily when needed without changing much of their application code.
“Don’t marry the framework” - Robert C. Martin
Laconia at its heart encourages the adoption of the Ports and Adapters pattern, or sometimes known as the Hexagonal Architecture. Your application must be blissfully ignorant of the nature of its external device, and the cloud technologies should be treated as such. Laconia also takes the Framework are details approach from the Clean Architecture book by Robert C. Martin. There are no Laconia objects to be derived for your application to work.
Set serverless design principles and best practices as the default
The design principles and best practices for serverless architecture are maturing. Laconia strives to make them adopted by default.
Let's run through each of the official best practices from AWS:
- Separate the Lambda handler (entry point) from your core logic: Laconia's core and primary adapters are designed for this.
- Use AWS Lambda Environment Variables to pass operational parameters to your function: Laconia encourages this via Convention over Configuration. By convention, you should configure environment variables to retrieve secrets, hit other Lambdas, retrieve a configuration from S3, etc.
- Minimize your deployment package size to its runtime necessities: Laconia is by design modular and has 0 external dependencies. Install only the packages you need.
- Minimize the complexity of your dependencies: Simplicity sits at the core of Laconia. Laconia believes that with the paradigm of shift of small functions, there should not be a need for a complex framework.
- Take advantage of Execution Context reuse to improve the performance of your function: Laconia Context instances creation are cached by default. For example, it will not hit SSM twice to retrieve secrets if your Lambda is still alive.
There are other sources like the AWS Serverless Application Lens, books, various talks, and loads of content from AWS Serverless Heroes e.g. Production Ready Serverless. Laconia will evolve and continue to encourage these principles by default.
Design for developer experience
The author puts a lot of thought and time to make the developers experience of Laconia as delightful as possible. Laconia has an ultra-high test coverage to make sure that advertised features are working as it should be, including continuously testing in the cloud.
Laconia believes that intuitive API design is the design that's closest to the
programming language used i.e. JavaScript. One example, Laconia is using object
destructuring to retrieve dependencies. Explicitness is also favoured, which is
why Laconia
doesn't support middleware as a framework
and have it's middleware concept a simple decorator function instead. Intuitive
API design should also be accompanied by intuitive errors. Even though object
destructuring syntax is used, Laconia will throw an error when the expected
dependency is not registered. The invoker
, for example, will throw an error
when the invoked Lambda is returning an error (the low-level API will not).