A simple application that extracts your IoCs from garbage input and checks their reputation using multiple services.
š demo.cyberbro.net
Inspired by Cybergordon and IntelOwl.
This project aims to provide a simple and efficient way to check the reputation of your observables using multiple services, without having to deploy a complex solution. Read the docs at https://docs.cyberbro.net/
Tip
To build custom reports, use Cyberbro with your favorite LLM (Claude, OpenAI gpt-4o...) via MCP (Model Context Protocol)
Checkout Cyberbro MCP for more information.
Tip
If you are lazy, you need Docker.
Do a git clone
; copy secrets-sample.json
to secrets.json
; docker compose up
then go to localhost:5000
. Yep, that's it!
git clone https://github.com/stanfrbd/cyberbro cd cyberbroEdit the config file (mandatory)
cp secrets-sample.json secrets.json
Note
Don't have API keys? No problem, just copy the secrets-sample.json
to secrets.json
and leave all like this. Be careful if a proxy is used.
You will be able to use all free engines!
secrets.json
file.{ "abuseipdb": "token_here", "alienvault": "token_here", "criminalip_api_key": "token_here", "crowdstrike_client_id": "client_id_here", "crowdstrike_client_secret": "client_secret_here", "google_safe_browsing": "token_here", "ipinfo": "token_here", "mde_client_id": "client_id_here", "mde_client_secret": "client_secret_here", "mde_tenant_id": "tenant_here", "misp_api_key": "token_here", "misp_url": "https://misp.local", "opencti_api_key": "token_here", "opencti_url": "https://demo.opencti.io", "proxy_url": "", "shodan": "token_here", "threatfox": "token_here", "virustotal": "token_here", "webscout": "token_here" }
Important
You can modify the configuration via the GUI at http://127.0.0.1:5000/config.
This endpoint is disabled by default for security reasons, as it is not protected.
To enable it, set "config_page_enabled":true
in secrets.json
or use CONFIG_PAGE_ENABLED=true
as environment variable.
This is not recommended for public or team use, as it exposes your API keys.
See Advanced options for deployment in the docs to get all custom option.
Lazy and easy - use dockerWarning
Make sure you install the compose
plugin as docker compose
and not docker-compose
.
docker compose up # use -d to run in background and use --build to rebuild the image
Don't forget to edit the
secrets.json
before building the image.
See Advanced options for deployment in the docs to get all Docker deployment options.
You might want to create a venv
before installing the dependencies.
pip install -r requirements.txt
gunicorn
(clean mode).gunicorn -b 0.0.0.0:5000 app:app
Caution
If you intend to use this in a production environment, use well configured Reverse Proxy + WAF to prevent security issues.
Cyberbro browser extension/api/
and can be accessed via the GUI or command-line.There are currently 3 endpoints:
/api/analyze
- Analyze a text and return analysis ID (JSON)./api/is_analysis_complete/<analysis_id>
- Check if the analysis is complete (JSON)./api/results/<analysis_id>
- Retrieve the results of a previous analysis (JSON).curl -X POST "http://localhost:5000/api/analyze" -H "Content-Type: application/json" -d '{"text": "20minutes.fr", "engines": ["reverse_dns", "rdap"]}'
{ "analysis_id": "e88de647-b153-4904-91e5-8f5c79174854", "link": "/results/e88de647-b153-4904-91e5-8f5c79174854" }
curl "http://localhost:5000/api/is_analysis_complete/e88de647-b153-4904-91e5-8f5c79174854"
curl "http://localhost:5000/api/results/e88de647-b153-4904-91e5-8f5c79174854"
[ { "observable": "20minutes.fr", "rdap": { "abuse_contact": "", "creation_date": "2001-07-11", "expiration_date": "2028-01-08", "link": "https://rdap.nic.fr/domain/20minutes.fr", "name_servers": [ "ns-1271.awsdns-30.org", "ns-748.awsdns-29.net", "ns-16.awsdns-02.com", "ns-1958.awsdns-52.co.uk" ], "organization": "", "registrant": "20 MINUTES FRANCE SAS", "registrant_email": "0d6621ed24c26f0d32e2c4f76b507da9-679847@contact.gandi.net", "registrar": "GANDI", "update_date": "2024-11-18" }, "reverse_dns": { "reverse_dns": [ "13.249.9.82", "13.249.9.92", "13.249.9.83", "13.249.9.129" ] }, "reversed_success": true, "type": "FQDN" } ]API and third-party services
A huge thank you to all the amazing contributors who made pull requests and helped improve this project:
Your contributions are greatly appreciated!
MIT License
Copyright (c) 2025 stanfrbd
Permission is hereby granted, free of charge, to any person obtaining a copy
of this software and associated documentation files (the "Software"), to deal
in the Software without restriction, including without limitation the rights
to use, copy, modify, merge, publish, distribute, sublicense, and/or sell
copies of the Software, and to permit persons to whom the Software is
furnished to do so, subject to the following conditions:
The above copyright notice and this permission notice shall be included
in all copies or substantial portions of the Software.
THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS
OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,
FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL
THE AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER
LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING
FROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER
DEALINGS IN THE SOFTWARE.
The logo used in this project is free for personal and commercial use and can be found here.
RetroSearch is an open source project built by @garambo | Open a GitHub Issue
Search and Browse the WWW like it's 1997 | Search results from DuckDuckGo
HTML:
3.2
| Encoding:
UTF-8
| Version:
0.7.4