Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/netcentric/pickaxe-security-scanner
Pickaxe is a fast and customizable security scan library which simplifies security testing for web applications like Adobe Experience Manager or API services. It can be plugged into a maven build to execute build-in checks or custom user provided security checks. Custom security checks can be defined via YAML files or a groovy based DSL.
https://github.com/netcentric/pickaxe-security-scanner
adobe-experience-manager aem aem-automation aem-tools dispatcher groovy maven-plugin penetration-testing-tools security-audit security-automation security-scanner security-tools
Last synced: 3 months ago
JSON representation
Pickaxe is a fast and customizable security scan library which simplifies security testing for web applications like Adobe Experience Manager or API services. It can be plugged into a maven build to execute build-in checks or custom user provided security checks. Custom security checks can be defined via YAML files or a groovy based DSL.
- Host: GitHub
- URL: https://github.com/netcentric/pickaxe-security-scanner
- Owner: Netcentric
- License: epl-1.0
- Created: 2021-01-19T12:19:11.000Z (about 4 years ago)
- Default Branch: develop
- Last Pushed: 2023-12-05T22:08:25.000Z (about 1 year ago)
- Last Synced: 2024-10-12T01:08:02.695Z (4 months ago)
- Topics: adobe-experience-manager, aem, aem-automation, aem-tools, dispatcher, groovy, maven-plugin, penetration-testing-tools, security-audit, security-automation, security-scanner, security-tools
- Language: Groovy
- Homepage:
- Size: 397 KB
- Stars: 13
- Watchers: 10
- Forks: 3
- Open Issues: 9
-
Metadata Files:
- Readme: README.md
- License: LICENSE
Awesome Lists containing this project
README
[![Maven Central](https://maven-badges.herokuapp.com/maven-central/biz.netcentric.security/pickaxe/badge.svg)](https://maven-badges.herokuapp.com/maven-central/biz.netcentric.security/pickaxe)
[![License](https://img.shields.io/badge/License-EPL%201.0-red.svg)](https://opensource.org/licenses/EPL-1.0)
[![Build Status](https://github.com/netcentric/pickaxe-security-scanner/actions/workflows/ci.yml/badge.svg?branch=develop)](https://github.com/netcentric/pickaxe-security-scanner/actions/workflows/ci.yml)![pickaxe-logo2-kl](https://user-images.githubusercontent.com/3109217/134664102-fad8ef35-68da-4466-aa22-8558638c2109.png)
# Pickaxe - AEM and Dispatcher Security ScannerSecuring an AEM installation requires to continuously check the overall stack. Any failure in one of the involved layers may likely affect a totally different technical layer or even the whole platform.
The purpose if this project is to simplify continuous automated security testing of Adobe Experience Manager and especially the AEM Dispatcher.
If further enables projects to customize the actual test behaviou to specific project requirements and to easily add additional project specific checks.## Highly customizable for your project needs
Pickaxe is scriptable web application test framework with a customizable http scan engine and a large predefined set of security checks for Adobe Experience Manager (AEM) projects.
It can be easily customized and extended either through a groovy based DSL or using YAML based scan and check configurations.
The scanner can be integrated
* into a Maven project,
* started from Docker container
* or simply called via its commandline interface.Pickaxe is fully customizable without having to touch or change the project's core and
is designed to be integrated into build and CICD ecosystems.But Pickaxe is not necessarily limited to AEM only and could be used to scan other web applications and API services.
## Features
What is in for my project if I decide to use Pickaxe?
- More than 35 built-in Dispatcher and AEM Security Checks
- Easy remote or local execution
- Commandline Interface
- Maven build integration as a Maven plugin
- Easy Jenkins integration
- Fully configurable and customizable scans and checks for any project need
- Groovy Configuration DSL
- YAML Configuration
- Authentication support
- Fast and scalable through async and parallel scan execution
- Multiple report handlers and formats (html, json, console or just-break-the-build)# Attack Vectors
Please check [Pickaxe Scans Module Readme](/pickaxe-scans/README.md) for a list of all supported attack vectors.
# Installation
If you want to build and run it locally, just run a simple maven build from the root of the project and trigger the commandline version.
mvn clean install
java -jar pickaxe-scans/target/pickaxe-security-scanner.jar --url http:///path-to-a-page --output /Users//scans
Alternatively pull the docker image and run it from via docker:docker pull ghcr.io/netcentric/pickaxe-security-scanner:latest
docker run --rm -it -v /Users//temp/output:/app/output ghcr.io/netcentric/pickaxe-security-scanner:latest --url http://host.docker.internal/content/we-retail/us/en.html
Please check our specific documentation for details on how to run the scanner.
* [Maven Build Integration](/documentation/run-with-maven.md)
* [Run from Commandline](/documentation/run-with-cli.md)
* [Run via Docker](/documentation/run-with-docker.md)# Scan Configuration
Before starting to deep dive into advanced topics,
it is crucial to understand the domain specific terminology and meaning of certain buzzwords.| Term | Description |
|---------|-------------|
| scan| The term _scan_ refers to a scan configuration which configures the target and the parameters to use when scanning the target. |
| check | The term check refers to a single configuration which tells the scanner how to attack a certain vulnerability. |
| reporter | A reporter is a report handlers or writer which is used to process the scan results and acts according to it's implementation. It can either print output or terminate further processing when issues are detected.|
| config dsl | Configuration language to influence the runtime behaviour of the scan angine usig an external configuration. |### Advanced Configurations
* [Custom Scan Configurations](/documentation/custom-scan.md)
* [Custom Security Checks](/documentation/custom-checks.md)
* [Reporting Configurations](/documentation/reporting.md)## Configuration Languages: Groovy vs. YAML
Pickaxe uses either a Groovy Configuration DSL or a YAML config to allow customization or configuration of the scan process or to define custom checks.
The Groovy DSL refers to the scan engines domain specific configuration language, which is used to define most buildin scans or checks.
The YAML config is a way simpler format which allows quick customizations without needing to now any internals.* The scan engine interprets and understands it and acts accordingly.
* It can be loaded via filesystem and dynamically extend the capabilities of the scanner.
* If you want to keep it simpler, then just go for the YAML based configs, but be aware the groovy DSL is more powerful.# Questions
If you have any questions which are still answered after reading the documentation feel free to raise them in the discussion forum.
# Contributions
Contributions are highly welcome in the form of [issue reports](https://github.com/Netcentric/pickaxe-security-scanner/issues), [pull request](https://docs.github.com/en/free-pro-team@latest/github/collaborating-with-issues-and-pull-requests/creating-a-pull-request-from-a-fork) or providing help in our [discussion forum](https://github.com/Netcentric/pickaxe-security-scanner/discussions).
## Pickaxe Development and Backlog
If you want to contribute or develop on top of pickaxe please have a look into the following documentation chapters.
* [Runtime Requirements](/documentation/runtime-requirements.md)
* [Pickaxe Architecture](/documentation/architecture.md)
* [Pickaxe Development](/documentation/development.md)
* [Product Features and Backlog](/documentation/backlog.md)# License
Pickaxe is licensed under the [Eclipse Public License - v 1.0](LICENSE.txt).