Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/santandersecurityresearch/asvs
A simple web app that helps developers understand the ASVS requirements.
https://github.com/santandersecurityresearch/asvs
asvs django marbles owasp
Last synced: 2 months ago
JSON representation
A simple web app that helps developers understand the ASVS requirements.
- Host: GitHub
- URL: https://github.com/santandersecurityresearch/asvs
- Owner: Santandersecurityresearch
- License: mit
- Created: 2018-06-04T16:52:51.000Z (over 6 years ago)
- Default Branch: master
- Last Pushed: 2024-03-07T14:23:20.000Z (12 months ago)
- Last Synced: 2024-12-12T03:04:17.371Z (2 months ago)
- Topics: asvs, django, marbles, owasp
- Language: HTML
- Size: 3.44 MB
- Stars: 154
- Watchers: 21
- Forks: 39
- Open Issues: 8
-
Metadata Files:
- Readme: README.md
- Contributing: CONTRIBUTING.md
- License: LICENSE
- Security: SECURITY.md
Awesome Lists containing this project
README
# Welcome To The OWASP Application Security Verification Standard (ASVS) Web App - Release Name: **SCANROUTE**
The OWASP Application Security Verification Standard [ASVS](https://owasp.org/www-project-application-security-verification-standard/]) is a community-effort to
establish a framework of security requirements and controls that focus on normalising the functional and non-functional security controls required when designing, developing and testing modern web applications.You can access the ASVS via [Github](https://github.com/OWASP/ASVS/tree/master/4.0), but we wanted to make this more accessible to all as a web application (based on django). The key aim of the web application is to allow individuals or companies a quick and easy way to understand the ASVS controls, and where to find information on meeting those controls. For this second release, we've also added 2FA authentication so as to offer more security for sensitive projects.
When we built Marbles (the original release), our aim was the following:
- [x] Easy to update - the app is powered by two JSON files (asvs.json & category.json)
- [X] Lightweight - The included Dockerfile builds a 89MB Docker image (size isn't everything)
- [X] No frills - You don't want a web app that takes ages to load and has "extra" stuff in it
- [X] Community-focused - The ASVS is built by you for you, and so should this application. We welcome pull requests and ideas from you, the community.## Installing
We decided to use Docker for virtualisation so that it's easier to run in the cloud and keep update. This assumes you have Docker installed and running on your host (be it on-prem or cloud)
### Docker
Once you have cloned the repo, you can build and run the docker image with the following commands:`docker build -t asvs .`
`docker run -d -p 8000:8000 asvs`This will then map your local port 8000 to the running docker container.
**NOTE:** In this example we built the docker image using the tag (-t) *asvs*, however you can change this if you want.
***In asvs/settings.py, you will find the SECURITY_KEY. We cannot stress this enough, this should be changed before you deploy this yourself.***
### Other
If you want to run the web app on a "production" grade web server (such as Apache2) you can, django provides a WSGI file which you can find in the *asvs* folder. Individual installation guides for this are outside of the scope of this project, however because sharing is caring here is a [link](https://docs.djangoproject.com/en/2.0/howto/deployment/wsgi/) to the official django documentation.## Roadmap
This is the second release and we already have some new "features" in the planning stages. These are currently (and subject to change).
1. Sharing projects between individuals
2. Teams (maybe)
3. Integration into JIRA (via an API)## Screenshots
data:image/s3,"s3://crabby-images/a9614/a9614b58fe58f34cbb7789682338bf67621d4e0e" alt="homepage"
data:image/s3,"s3://crabby-images/7454f/7454ff77b23ba9581e80dc2c0262c944b10f2eaf" alt="levels"
data:image/s3,"s3://crabby-images/6c4f1/6c4f1fd3fcfdd858ea9060cefe8e8135a1f8abfa" alt="2fa"
data:image/s3,"s3://crabby-images/1a0a7/1a0a77b216a4cc7ed4ec32f49af190b7f51ae6c8" alt="projectmanagement"
## Code Security
It would be pretty silly if an app about application security made use of insecure code and infrastructure. As such, we are pretty strict about this and make use of both [CodeQL](https://codeql.github.com/), a brilliant semantic code analysis engine from GitHub, [Semgrep](https://semgrep.dev/), a super fast static analysis tool as well as [Snyk's](https://snyk.io/learn/docker-security-scanning/) Docker scan.
data:image/s3,"s3://crabby-images/a0f9f/a0f9f5441648357d8d3e33b1bbc5d0220af6d306" alt="docker_scan"
Once code is committed, we make use of GitHub's Actions to run futher security tests
data:image/s3,"s3://crabby-images/08d3b/08d3bbc57638119fa7ac4ac0460a018c22004f9c" alt="GitHub Actions"
data:image/s3,"s3://crabby-images/c22cb/c22cbed74227337dd55ca47ac4484816f23095b3" alt="GitHub Actions"
## Software Bill of Materials (SBOM)
We are firm supporters of the SBOM movement, as it's a key building block in software security and software supply chain risk management. A SBOM is a nested inventory, a list of ingredients that make up software components and as such, here's our recipe:
data:image/s3,"s3://crabby-images/110c1/110c11b17f2c1e39f25df0d8fc8dfa0080e4d237" alt="Dependency Tree"
data:image/s3,"s3://crabby-images/9f2a2/9f2a2c56fb77de4c53244fbe7ba4d413b933772e" alt="Software Bill of Materials"There is also a *bom.json* file in the main repo for use by automated tools.
## Who Are We?
Adam Maxwell (@catalyst256) & Daniel Cuthbert (@dcuthbert) are part of the Santander Group Cyber Security Research Team. Daniel is one of the co-authors of the ASVS, and we use it within the group and felt this app would be better suited as a community release, rather than just another internal tool. We've also had @[rubeniglesiasg](https://github.com/Santandersecurityresearch/asvs/commits?author=rubeniglesiasg) help us with slinging code, and getting it ready for version two dot oh.