There are some wonderful free or open-source tools you can use to improve the security of your serverless projects. We will explore these tools in five areas.
1. Linters
Linters help improve your code by finding common coding flaws. You would typically run them when you create a pull request, create a build, or in your CI/CD.
- ESLint (Node): eslint.org
- Pylint (Python): pylint.org
- golanglint (golang): github.com/golang/lint
2. Dependency checkers
Your project might use dependencies, libraries, or packages. Some of these packages might be out-of-date, deprecated, or have known vulnerabilities. A dependency checker can help you find packages that need updating and create pull requests to update them automatically.
- npm audit (Node): docs.npmjs.com/auditing-package-dependencie..
- Snyk (Node, .Net, Java, Python, and more): snyk.io
- Dependabot (Node, Python, Java, .Net, and more): dependabot.com
- GitHub Dependabot (Node, Python, Java, .Net, and more): help.github.com/en/github/administering-a-r..
3. AWS IAM Roles
If you are using Amazon Web Services, your projects has IAM roles for your serverless functions. The Serverless Framework automatically creates one IAM role for all the functions in your configuration file. Each function should have its own IAM role to enable the Principle of Least Privilege.
- serverless-iam-roles-per-function Serverless plugin: github.com/functionalone/serverless-iam-rol..
- serverless-plugin-custom-roles Serverless plugin: github.com/AntonBazhal/serverless-plugin-cu..
- Collection of AWS IAM policies for the Serverless Framework: github.com/miguel-a-calles-mba/serverless-p..
4. Error Monitoring and Alerting
Your functions may throw an error, but you may not know about it unless you manually monitor the logs or you setup an alerting system.
- Dashbird: dashbird.io
- Sentry: docs.sentry.io/platforms/node/guides/aws-la.. and github.com/arabold/serverless-sentry-plugin
5. Termination Protection
When you deploy a new AWS CloudFormation stack to production, you might want to enable termination protection to avoid accidentally deleting your stack.
- serverless-stack-termination-protection Serverless plugin: github.com/miguel-a-calles-mba/serverless-s..
Conclusion
You can improve the security of your serverless project by taking advantage of free or open source solutions that are already out there.
Before you go
About the author
Originally published on Secjuice.com
Photo by Patrick Hendry on Unsplash