Secret Scanner for Slack, Jira, Confluence, Asana, Wrike, Linear, Zendesk, GitHub and GitLab. Prevent credential leaks with n0s1.
Project description
n0s1 - Secret Scanner
n0s1 (pronunciation) is a secret scanner for Slack, Jira, Confluence, Asana, Wrike, Linear, Zendesk, GitHub and GitLab. It scans all channels/tickets/items/issues within the target platform in search of any leaked secrets in the titles, bodies, messages and comments. It is open-source and it can be easily extended to support scanning many others ticketing and messaging platforms.
See USER_MANUAL.md to learn how to run a scan.
Secrets are defined by an adaptable configuration file: regex.yaml or regex.toml. The scanner loads the configuration and searches for sensitive information, which includes:
- Github Personal Access Tokens
- GitLab Personal Access Tokens
- AWS Access Tokens
- PKCS8 private keys
- RSA private keys
- SSH private keys
- npm access tokens
Currently supported target platforms:
Install
python3 -m ensurepip --upgrade
python3 -m pip install --upgrade n0s1
n0s1 --help
Quick Start
python3 -m pip install n0s1
n0s1 jira_scan --server "https://<YOUR_JIRA_SERVER>.atlassian.net" --api-key "<YOUR_JIRA_API_TOKEN>"
docker run spark1security/n0s1 jira_scan --server "https://<YOUR_JIRA_SERVER>.atlassian.net" --api-key "<YOUR_JIRA_API_TOKEN>"
git clone https://github.com/spark1security/n0s1.git
cd n0s1/src/n0s1
python3 -m venv n0s1_python
source n0s1_python/bin/activate
python3 -m pip install -r ../../requirements.txt
python3 n0s1.py jira_scan --server "https://<YOUR_JIRA_SERVER>.atlassian.net" --api-key "<YOUR_JIRA_API_TOKEN>"
deactivate
Python SDK - See SDK_GUIDE.md:
python3 -m pip install n0s1
try:
import scanner
except:
import n0s1.scanner as scanner
# Create scanner instance
scanner_instance = scanner.SecretScanner(
target="jira_scan",
server="https://yourcompany.atlassian.net",
email="your-email@company.com",
api_key="your-jira-api-token",
debug=True
)
# Run the scan
result = scanner_instance.scan()
# Process results
print(f"Scan complete. Found {len(result.get('findings', {}))} potential secrets")
jobs:
jira_secret_scanning:
steps:
- uses: spark1security/n0s1-action@main
env:
JIRA_TOKEN: ${{ secrets.JIRA_API_TOKEN }}
with:
scan-target: 'jira_scan'
user-email: 'service_account@<YOUR_COMPANY>.atlassian.net'
platform-url: 'https://<YOUR_COMPANY>.atlassian.net'
GitLab CI - Add the following job to your .gitlab-ci.yml file:
jira-scan:
stage: test
image:
name: spark1security/n0s1
entrypoint: [""]
script:
- n0s1 jira_scan --email "service_account@<YOUR_COMPANY>.atlassian.net" --api-key $JIRA_TOKEN --server "https://<YOUR_COMPANY>.atlassian.net" --report-file gl-dast-report.json --report-format gitlab
- apt-get update
- apt-get -y install jq
- cat gl-dast-report.json | jq
artifacts:
reports:
dast:
- gl-dast-report.json
Want more? Check out Spark 1
If you liked n0s1, you will love Spark 1 which builds on top of n0s1 to provide even more enhanced capabilities for a complete security management offering.
Don't forget to check out the https://spark1.us website for more information about our products and services.
If you'd like to contact Spark 1 or request a demo, please use the free consultation form.
Community
n0s1 is a Spark 1 open source project.
Learn about our open source work and portfolio here.
Contact us about any matter by opening a GitHub Discussion here
Project details
Release history Release notifications | RSS feed
Download files
Download the file for your platform. If you're not sure which to choose, learn more about installing packages.
Source Distribution
Built Distribution
Filter files by name, interpreter, ABI, and platform.
If you're not sure about the file name format, learn more about wheel file names.
Copy a direct link to the current filters
File details
Details for the file n0s1-1.1.0.tar.gz.
File metadata
- Download URL: n0s1-1.1.0.tar.gz
- Upload date:
- Size: 70.9 kB
- Tags: Source
- Uploaded using Trusted Publishing? No
- Uploaded via: twine/6.2.0 CPython/3.13.7
File hashes
| Algorithm | Hash digest | |
|---|---|---|
| SHA256 |
7fbcfa10b6a84cc640c84030fb035b8599270d982affa590230bc830c04964d0
|
|
| MD5 |
ac085dd7199f70dd1fbe38d2023fdb35
|
|
| BLAKE2b-256 |
ae0862aacda170cfe084dbedbb09e79351fb0e64c6e895359fde120d9432de5a
|
File details
Details for the file n0s1-1.1.0-py3-none-any.whl.
File metadata
- Download URL: n0s1-1.1.0-py3-none-any.whl
- Upload date:
- Size: 85.6 kB
- Tags: Python 3
- Uploaded using Trusted Publishing? No
- Uploaded via: twine/6.2.0 CPython/3.13.7
File hashes
| Algorithm | Hash digest | |
|---|---|---|
| SHA256 |
96913f9665d12bc1e54742434002011541545c2c1001042c94a57e2315e6e075
|
|
| MD5 |
8fd0f09a8dc1d452ea0ae85438b6a5b0
|
|
| BLAKE2b-256 |
112881aa8e53201da9d801ac0c637ba9cba3ae2b0db15b2e7d1dadc5e4bae595
|