bbot 2.4.2.6596rc0__tar.gz → 2.4.2.6611rc0__tar.gz
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Potentially problematic release.
This version of bbot might be problematic. Click here for more details.
- {bbot-2.4.2.6596rc0 → bbot-2.4.2.6611rc0}/PKG-INFO +1 -1
- {bbot-2.4.2.6596rc0 → bbot-2.4.2.6611rc0}/bbot/__init__.py +1 -1
- {bbot-2.4.2.6596rc0 → bbot-2.4.2.6611rc0}/bbot/modules/internal/excavate.py +53 -43
- {bbot-2.4.2.6596rc0 → bbot-2.4.2.6611rc0}/bbot/modules/lightfuzz/submodules/serial.py +1 -1
- {bbot-2.4.2.6596rc0 → bbot-2.4.2.6611rc0}/bbot/test/test_step_2/module_tests/base.py +2 -2
- {bbot-2.4.2.6596rc0 → bbot-2.4.2.6611rc0}/bbot/test/test_step_2/module_tests/test_module_excavate.py +14 -0
- {bbot-2.4.2.6596rc0 → bbot-2.4.2.6611rc0}/pyproject.toml +1 -1
- bbot-2.4.2.6596rc0/bbot/modules/dastardly.py +0 -137
- bbot-2.4.2.6596rc0/bbot/test/test_step_2/module_tests/test_module_dastardly.py +0 -70
- {bbot-2.4.2.6596rc0 → bbot-2.4.2.6611rc0}/LICENSE +0 -0
- {bbot-2.4.2.6596rc0 → bbot-2.4.2.6611rc0}/README.md +0 -0
- {bbot-2.4.2.6596rc0 → bbot-2.4.2.6611rc0}/bbot/cli.py +0 -0
- {bbot-2.4.2.6596rc0 → bbot-2.4.2.6611rc0}/bbot/core/__init__.py +0 -0
- {bbot-2.4.2.6596rc0 → bbot-2.4.2.6611rc0}/bbot/core/config/__init__.py +0 -0
- {bbot-2.4.2.6596rc0 → bbot-2.4.2.6611rc0}/bbot/core/config/files.py +0 -0
- {bbot-2.4.2.6596rc0 → bbot-2.4.2.6611rc0}/bbot/core/config/logger.py +0 -0
- {bbot-2.4.2.6596rc0 → bbot-2.4.2.6611rc0}/bbot/core/core.py +0 -0
- {bbot-2.4.2.6596rc0 → bbot-2.4.2.6611rc0}/bbot/core/engine.py +0 -0
- {bbot-2.4.2.6596rc0 → bbot-2.4.2.6611rc0}/bbot/core/event/__init__.py +0 -0
- {bbot-2.4.2.6596rc0 → bbot-2.4.2.6611rc0}/bbot/core/event/base.py +0 -0
- {bbot-2.4.2.6596rc0 → bbot-2.4.2.6611rc0}/bbot/core/event/helpers.py +0 -0
- {bbot-2.4.2.6596rc0 → bbot-2.4.2.6611rc0}/bbot/core/flags.py +0 -0
- {bbot-2.4.2.6596rc0 → bbot-2.4.2.6611rc0}/bbot/core/helpers/__init__.py +0 -0
- {bbot-2.4.2.6596rc0 → bbot-2.4.2.6611rc0}/bbot/core/helpers/async_helpers.py +0 -0
- {bbot-2.4.2.6596rc0 → bbot-2.4.2.6611rc0}/bbot/core/helpers/bloom.py +0 -0
- {bbot-2.4.2.6596rc0 → bbot-2.4.2.6611rc0}/bbot/core/helpers/cache.py +0 -0
- {bbot-2.4.2.6596rc0 → bbot-2.4.2.6611rc0}/bbot/core/helpers/command.py +0 -0
- {bbot-2.4.2.6596rc0 → bbot-2.4.2.6611rc0}/bbot/core/helpers/depsinstaller/__init__.py +0 -0
- {bbot-2.4.2.6596rc0 → bbot-2.4.2.6611rc0}/bbot/core/helpers/depsinstaller/installer.py +0 -0
- {bbot-2.4.2.6596rc0 → bbot-2.4.2.6611rc0}/bbot/core/helpers/depsinstaller/sudo_askpass.py +0 -0
- {bbot-2.4.2.6596rc0 → bbot-2.4.2.6611rc0}/bbot/core/helpers/diff.py +0 -0
- {bbot-2.4.2.6596rc0 → bbot-2.4.2.6611rc0}/bbot/core/helpers/dns/__init__.py +0 -0
- {bbot-2.4.2.6596rc0 → bbot-2.4.2.6611rc0}/bbot/core/helpers/dns/brute.py +0 -0
- {bbot-2.4.2.6596rc0 → bbot-2.4.2.6611rc0}/bbot/core/helpers/dns/dns.py +0 -0
- {bbot-2.4.2.6596rc0 → bbot-2.4.2.6611rc0}/bbot/core/helpers/dns/engine.py +0 -0
- {bbot-2.4.2.6596rc0 → bbot-2.4.2.6611rc0}/bbot/core/helpers/dns/helpers.py +0 -0
- {bbot-2.4.2.6596rc0 → bbot-2.4.2.6611rc0}/bbot/core/helpers/dns/mock.py +0 -0
- {bbot-2.4.2.6596rc0 → bbot-2.4.2.6611rc0}/bbot/core/helpers/files.py +0 -0
- {bbot-2.4.2.6596rc0 → bbot-2.4.2.6611rc0}/bbot/core/helpers/helper.py +0 -0
- {bbot-2.4.2.6596rc0 → bbot-2.4.2.6611rc0}/bbot/core/helpers/interactsh.py +0 -0
- {bbot-2.4.2.6596rc0 → bbot-2.4.2.6611rc0}/bbot/core/helpers/libmagic.py +0 -0
- {bbot-2.4.2.6596rc0 → bbot-2.4.2.6611rc0}/bbot/core/helpers/misc.py +0 -0
- {bbot-2.4.2.6596rc0 → bbot-2.4.2.6611rc0}/bbot/core/helpers/names_generator.py +0 -0
- {bbot-2.4.2.6596rc0 → bbot-2.4.2.6611rc0}/bbot/core/helpers/ntlm.py +0 -0
- {bbot-2.4.2.6596rc0 → bbot-2.4.2.6611rc0}/bbot/core/helpers/process.py +0 -0
- {bbot-2.4.2.6596rc0 → bbot-2.4.2.6611rc0}/bbot/core/helpers/ratelimiter.py +0 -0
- {bbot-2.4.2.6596rc0 → bbot-2.4.2.6611rc0}/bbot/core/helpers/regex.py +0 -0
- {bbot-2.4.2.6596rc0 → bbot-2.4.2.6611rc0}/bbot/core/helpers/regexes.py +0 -0
- {bbot-2.4.2.6596rc0 → bbot-2.4.2.6611rc0}/bbot/core/helpers/url.py +0 -0
- {bbot-2.4.2.6596rc0 → bbot-2.4.2.6611rc0}/bbot/core/helpers/validators.py +0 -0
- {bbot-2.4.2.6596rc0 → bbot-2.4.2.6611rc0}/bbot/core/helpers/web/__init__.py +0 -0
- {bbot-2.4.2.6596rc0 → bbot-2.4.2.6611rc0}/bbot/core/helpers/web/client.py +0 -0
- {bbot-2.4.2.6596rc0 → bbot-2.4.2.6611rc0}/bbot/core/helpers/web/engine.py +0 -0
- {bbot-2.4.2.6596rc0 → bbot-2.4.2.6611rc0}/bbot/core/helpers/web/envelopes.py +0 -0
- {bbot-2.4.2.6596rc0 → bbot-2.4.2.6611rc0}/bbot/core/helpers/web/ssl_context.py +0 -0
- {bbot-2.4.2.6596rc0 → bbot-2.4.2.6611rc0}/bbot/core/helpers/web/web.py +0 -0
- {bbot-2.4.2.6596rc0 → bbot-2.4.2.6611rc0}/bbot/core/helpers/wordcloud.py +0 -0
- {bbot-2.4.2.6596rc0 → bbot-2.4.2.6611rc0}/bbot/core/helpers/yara_helper.py +0 -0
- {bbot-2.4.2.6596rc0 → bbot-2.4.2.6611rc0}/bbot/core/modules.py +0 -0
- {bbot-2.4.2.6596rc0 → bbot-2.4.2.6611rc0}/bbot/core/multiprocess.py +0 -0
- {bbot-2.4.2.6596rc0 → bbot-2.4.2.6611rc0}/bbot/core/shared_deps.py +0 -0
- {bbot-2.4.2.6596rc0 → bbot-2.4.2.6611rc0}/bbot/db/sql/models.py +0 -0
- {bbot-2.4.2.6596rc0 → bbot-2.4.2.6611rc0}/bbot/defaults.yml +0 -0
- {bbot-2.4.2.6596rc0 → bbot-2.4.2.6611rc0}/bbot/errors.py +0 -0
- {bbot-2.4.2.6596rc0 → bbot-2.4.2.6611rc0}/bbot/logger.py +0 -0
- {bbot-2.4.2.6596rc0 → bbot-2.4.2.6611rc0}/bbot/modules/__init__.py +0 -0
- {bbot-2.4.2.6596rc0 → bbot-2.4.2.6611rc0}/bbot/modules/ajaxpro.py +0 -0
- {bbot-2.4.2.6596rc0 → bbot-2.4.2.6611rc0}/bbot/modules/anubisdb.py +0 -0
- {bbot-2.4.2.6596rc0 → bbot-2.4.2.6611rc0}/bbot/modules/apkpure.py +0 -0
- {bbot-2.4.2.6596rc0 → bbot-2.4.2.6611rc0}/bbot/modules/azure_realm.py +0 -0
- {bbot-2.4.2.6596rc0 → bbot-2.4.2.6611rc0}/bbot/modules/azure_tenant.py +0 -0
- {bbot-2.4.2.6596rc0 → bbot-2.4.2.6611rc0}/bbot/modules/baddns.py +0 -0
- {bbot-2.4.2.6596rc0 → bbot-2.4.2.6611rc0}/bbot/modules/baddns_direct.py +0 -0
- {bbot-2.4.2.6596rc0 → bbot-2.4.2.6611rc0}/bbot/modules/baddns_zone.py +0 -0
- {bbot-2.4.2.6596rc0 → bbot-2.4.2.6611rc0}/bbot/modules/badsecrets.py +0 -0
- {bbot-2.4.2.6596rc0 → bbot-2.4.2.6611rc0}/bbot/modules/base.py +0 -0
- {bbot-2.4.2.6596rc0 → bbot-2.4.2.6611rc0}/bbot/modules/bevigil.py +0 -0
- {bbot-2.4.2.6596rc0 → bbot-2.4.2.6611rc0}/bbot/modules/binaryedge.py +0 -0
- {bbot-2.4.2.6596rc0 → bbot-2.4.2.6611rc0}/bbot/modules/bucket_amazon.py +0 -0
- {bbot-2.4.2.6596rc0 → bbot-2.4.2.6611rc0}/bbot/modules/bucket_azure.py +0 -0
- {bbot-2.4.2.6596rc0 → bbot-2.4.2.6611rc0}/bbot/modules/bucket_digitalocean.py +0 -0
- {bbot-2.4.2.6596rc0 → bbot-2.4.2.6611rc0}/bbot/modules/bucket_file_enum.py +0 -0
- {bbot-2.4.2.6596rc0 → bbot-2.4.2.6611rc0}/bbot/modules/bucket_firebase.py +0 -0
- {bbot-2.4.2.6596rc0 → bbot-2.4.2.6611rc0}/bbot/modules/bucket_google.py +0 -0
- {bbot-2.4.2.6596rc0 → bbot-2.4.2.6611rc0}/bbot/modules/bufferoverrun.py +0 -0
- {bbot-2.4.2.6596rc0 → bbot-2.4.2.6611rc0}/bbot/modules/builtwith.py +0 -0
- {bbot-2.4.2.6596rc0 → bbot-2.4.2.6611rc0}/bbot/modules/bypass403.py +0 -0
- {bbot-2.4.2.6596rc0 → bbot-2.4.2.6611rc0}/bbot/modules/c99.py +0 -0
- {bbot-2.4.2.6596rc0 → bbot-2.4.2.6611rc0}/bbot/modules/censys.py +0 -0
- {bbot-2.4.2.6596rc0 → bbot-2.4.2.6611rc0}/bbot/modules/certspotter.py +0 -0
- {bbot-2.4.2.6596rc0 → bbot-2.4.2.6611rc0}/bbot/modules/chaos.py +0 -0
- {bbot-2.4.2.6596rc0 → bbot-2.4.2.6611rc0}/bbot/modules/code_repository.py +0 -0
- {bbot-2.4.2.6596rc0 → bbot-2.4.2.6611rc0}/bbot/modules/credshed.py +0 -0
- {bbot-2.4.2.6596rc0 → bbot-2.4.2.6611rc0}/bbot/modules/crt.py +0 -0
- {bbot-2.4.2.6596rc0 → bbot-2.4.2.6611rc0}/bbot/modules/crt_db.py +0 -0
- {bbot-2.4.2.6596rc0 → bbot-2.4.2.6611rc0}/bbot/modules/dehashed.py +0 -0
- {bbot-2.4.2.6596rc0 → bbot-2.4.2.6611rc0}/bbot/modules/digitorus.py +0 -0
- {bbot-2.4.2.6596rc0 → bbot-2.4.2.6611rc0}/bbot/modules/dnsbimi.py +0 -0
- {bbot-2.4.2.6596rc0 → bbot-2.4.2.6611rc0}/bbot/modules/dnsbrute.py +0 -0
- {bbot-2.4.2.6596rc0 → bbot-2.4.2.6611rc0}/bbot/modules/dnsbrute_mutations.py +0 -0
- {bbot-2.4.2.6596rc0 → bbot-2.4.2.6611rc0}/bbot/modules/dnscaa.py +0 -0
- {bbot-2.4.2.6596rc0 → bbot-2.4.2.6611rc0}/bbot/modules/dnscommonsrv.py +0 -0
- {bbot-2.4.2.6596rc0 → bbot-2.4.2.6611rc0}/bbot/modules/dnsdumpster.py +0 -0
- {bbot-2.4.2.6596rc0 → bbot-2.4.2.6611rc0}/bbot/modules/dnstlsrpt.py +0 -0
- {bbot-2.4.2.6596rc0 → bbot-2.4.2.6611rc0}/bbot/modules/docker_pull.py +0 -0
- {bbot-2.4.2.6596rc0 → bbot-2.4.2.6611rc0}/bbot/modules/dockerhub.py +0 -0
- {bbot-2.4.2.6596rc0 → bbot-2.4.2.6611rc0}/bbot/modules/dotnetnuke.py +0 -0
- {bbot-2.4.2.6596rc0 → bbot-2.4.2.6611rc0}/bbot/modules/emailformat.py +0 -0
- {bbot-2.4.2.6596rc0 → bbot-2.4.2.6611rc0}/bbot/modules/extractous.py +0 -0
- {bbot-2.4.2.6596rc0 → bbot-2.4.2.6611rc0}/bbot/modules/ffuf.py +0 -0
- {bbot-2.4.2.6596rc0 → bbot-2.4.2.6611rc0}/bbot/modules/ffuf_shortnames.py +0 -0
- {bbot-2.4.2.6596rc0 → bbot-2.4.2.6611rc0}/bbot/modules/filedownload.py +0 -0
- {bbot-2.4.2.6596rc0 → bbot-2.4.2.6611rc0}/bbot/modules/fingerprintx.py +0 -0
- {bbot-2.4.2.6596rc0 → bbot-2.4.2.6611rc0}/bbot/modules/fullhunt.py +0 -0
- {bbot-2.4.2.6596rc0 → bbot-2.4.2.6611rc0}/bbot/modules/generic_ssrf.py +0 -0
- {bbot-2.4.2.6596rc0 → bbot-2.4.2.6611rc0}/bbot/modules/git.py +0 -0
- {bbot-2.4.2.6596rc0 → bbot-2.4.2.6611rc0}/bbot/modules/git_clone.py +0 -0
- {bbot-2.4.2.6596rc0 → bbot-2.4.2.6611rc0}/bbot/modules/gitdumper.py +0 -0
- {bbot-2.4.2.6596rc0 → bbot-2.4.2.6611rc0}/bbot/modules/github_codesearch.py +0 -0
- {bbot-2.4.2.6596rc0 → bbot-2.4.2.6611rc0}/bbot/modules/github_org.py +0 -0
- {bbot-2.4.2.6596rc0 → bbot-2.4.2.6611rc0}/bbot/modules/github_workflows.py +0 -0
- {bbot-2.4.2.6596rc0 → bbot-2.4.2.6611rc0}/bbot/modules/gitlab.py +0 -0
- {bbot-2.4.2.6596rc0 → bbot-2.4.2.6611rc0}/bbot/modules/google_playstore.py +0 -0
- {bbot-2.4.2.6596rc0 → bbot-2.4.2.6611rc0}/bbot/modules/gowitness.py +0 -0
- {bbot-2.4.2.6596rc0 → bbot-2.4.2.6611rc0}/bbot/modules/hackertarget.py +0 -0
- {bbot-2.4.2.6596rc0 → bbot-2.4.2.6611rc0}/bbot/modules/host_header.py +0 -0
- {bbot-2.4.2.6596rc0 → bbot-2.4.2.6611rc0}/bbot/modules/httpx.py +0 -0
- {bbot-2.4.2.6596rc0 → bbot-2.4.2.6611rc0}/bbot/modules/hunt.py +0 -0
- {bbot-2.4.2.6596rc0 → bbot-2.4.2.6611rc0}/bbot/modules/hunterio.py +0 -0
- {bbot-2.4.2.6596rc0 → bbot-2.4.2.6611rc0}/bbot/modules/iis_shortnames.py +0 -0
- {bbot-2.4.2.6596rc0 → bbot-2.4.2.6611rc0}/bbot/modules/internal/__init__.py +0 -0
- {bbot-2.4.2.6596rc0 → bbot-2.4.2.6611rc0}/bbot/modules/internal/aggregate.py +0 -0
- {bbot-2.4.2.6596rc0 → bbot-2.4.2.6611rc0}/bbot/modules/internal/base.py +0 -0
- {bbot-2.4.2.6596rc0 → bbot-2.4.2.6611rc0}/bbot/modules/internal/cloudcheck.py +0 -0
- {bbot-2.4.2.6596rc0 → bbot-2.4.2.6611rc0}/bbot/modules/internal/dnsresolve.py +0 -0
- {bbot-2.4.2.6596rc0 → bbot-2.4.2.6611rc0}/bbot/modules/internal/speculate.py +0 -0
- {bbot-2.4.2.6596rc0 → bbot-2.4.2.6611rc0}/bbot/modules/internal/unarchive.py +0 -0
- {bbot-2.4.2.6596rc0 → bbot-2.4.2.6611rc0}/bbot/modules/ip2location.py +0 -0
- {bbot-2.4.2.6596rc0 → bbot-2.4.2.6611rc0}/bbot/modules/ipneighbor.py +0 -0
- {bbot-2.4.2.6596rc0 → bbot-2.4.2.6611rc0}/bbot/modules/ipstack.py +0 -0
- {bbot-2.4.2.6596rc0 → bbot-2.4.2.6611rc0}/bbot/modules/jadx.py +0 -0
- {bbot-2.4.2.6596rc0 → bbot-2.4.2.6611rc0}/bbot/modules/leakix.py +0 -0
- {bbot-2.4.2.6596rc0 → bbot-2.4.2.6611rc0}/bbot/modules/lightfuzz/lightfuzz.py +0 -0
- {bbot-2.4.2.6596rc0 → bbot-2.4.2.6611rc0}/bbot/modules/lightfuzz/submodules/__init__.py +0 -0
- {bbot-2.4.2.6596rc0 → bbot-2.4.2.6611rc0}/bbot/modules/lightfuzz/submodules/base.py +0 -0
- {bbot-2.4.2.6596rc0 → bbot-2.4.2.6611rc0}/bbot/modules/lightfuzz/submodules/cmdi.py +0 -0
- {bbot-2.4.2.6596rc0 → bbot-2.4.2.6611rc0}/bbot/modules/lightfuzz/submodules/crypto.py +0 -0
- {bbot-2.4.2.6596rc0 → bbot-2.4.2.6611rc0}/bbot/modules/lightfuzz/submodules/nosqli.py +0 -0
- {bbot-2.4.2.6596rc0 → bbot-2.4.2.6611rc0}/bbot/modules/lightfuzz/submodules/path.py +0 -0
- {bbot-2.4.2.6596rc0 → bbot-2.4.2.6611rc0}/bbot/modules/lightfuzz/submodules/sqli.py +0 -0
- {bbot-2.4.2.6596rc0 → bbot-2.4.2.6611rc0}/bbot/modules/lightfuzz/submodules/ssti.py +0 -0
- {bbot-2.4.2.6596rc0 → bbot-2.4.2.6611rc0}/bbot/modules/lightfuzz/submodules/xss.py +0 -0
- {bbot-2.4.2.6596rc0 → bbot-2.4.2.6611rc0}/bbot/modules/myssl.py +0 -0
- {bbot-2.4.2.6596rc0 → bbot-2.4.2.6611rc0}/bbot/modules/newsletters.py +0 -0
- {bbot-2.4.2.6596rc0 → bbot-2.4.2.6611rc0}/bbot/modules/ntlm.py +0 -0
- {bbot-2.4.2.6596rc0 → bbot-2.4.2.6611rc0}/bbot/modules/nuclei.py +0 -0
- {bbot-2.4.2.6596rc0 → bbot-2.4.2.6611rc0}/bbot/modules/oauth.py +0 -0
- {bbot-2.4.2.6596rc0 → bbot-2.4.2.6611rc0}/bbot/modules/otx.py +0 -0
- {bbot-2.4.2.6596rc0 → bbot-2.4.2.6611rc0}/bbot/modules/output/__init__.py +0 -0
- {bbot-2.4.2.6596rc0 → bbot-2.4.2.6611rc0}/bbot/modules/output/asset_inventory.py +0 -0
- {bbot-2.4.2.6596rc0 → bbot-2.4.2.6611rc0}/bbot/modules/output/base.py +0 -0
- {bbot-2.4.2.6596rc0 → bbot-2.4.2.6611rc0}/bbot/modules/output/csv.py +0 -0
- {bbot-2.4.2.6596rc0 → bbot-2.4.2.6611rc0}/bbot/modules/output/discord.py +0 -0
- {bbot-2.4.2.6596rc0 → bbot-2.4.2.6611rc0}/bbot/modules/output/emails.py +0 -0
- {bbot-2.4.2.6596rc0 → bbot-2.4.2.6611rc0}/bbot/modules/output/http.py +0 -0
- {bbot-2.4.2.6596rc0 → bbot-2.4.2.6611rc0}/bbot/modules/output/json.py +0 -0
- {bbot-2.4.2.6596rc0 → bbot-2.4.2.6611rc0}/bbot/modules/output/mysql.py +0 -0
- {bbot-2.4.2.6596rc0 → bbot-2.4.2.6611rc0}/bbot/modules/output/neo4j.py +0 -0
- {bbot-2.4.2.6596rc0 → bbot-2.4.2.6611rc0}/bbot/modules/output/nmap_xml.py +0 -0
- {bbot-2.4.2.6596rc0 → bbot-2.4.2.6611rc0}/bbot/modules/output/postgres.py +0 -0
- {bbot-2.4.2.6596rc0 → bbot-2.4.2.6611rc0}/bbot/modules/output/python.py +0 -0
- {bbot-2.4.2.6596rc0 → bbot-2.4.2.6611rc0}/bbot/modules/output/slack.py +0 -0
- {bbot-2.4.2.6596rc0 → bbot-2.4.2.6611rc0}/bbot/modules/output/splunk.py +0 -0
- {bbot-2.4.2.6596rc0 → bbot-2.4.2.6611rc0}/bbot/modules/output/sqlite.py +0 -0
- {bbot-2.4.2.6596rc0 → bbot-2.4.2.6611rc0}/bbot/modules/output/stdout.py +0 -0
- {bbot-2.4.2.6596rc0 → bbot-2.4.2.6611rc0}/bbot/modules/output/subdomains.py +0 -0
- {bbot-2.4.2.6596rc0 → bbot-2.4.2.6611rc0}/bbot/modules/output/teams.py +0 -0
- {bbot-2.4.2.6596rc0 → bbot-2.4.2.6611rc0}/bbot/modules/output/txt.py +0 -0
- {bbot-2.4.2.6596rc0 → bbot-2.4.2.6611rc0}/bbot/modules/output/web_parameters.py +0 -0
- {bbot-2.4.2.6596rc0 → bbot-2.4.2.6611rc0}/bbot/modules/output/web_report.py +0 -0
- {bbot-2.4.2.6596rc0 → bbot-2.4.2.6611rc0}/bbot/modules/output/websocket.py +0 -0
- {bbot-2.4.2.6596rc0 → bbot-2.4.2.6611rc0}/bbot/modules/paramminer_cookies.py +0 -0
- {bbot-2.4.2.6596rc0 → bbot-2.4.2.6611rc0}/bbot/modules/paramminer_getparams.py +0 -0
- {bbot-2.4.2.6596rc0 → bbot-2.4.2.6611rc0}/bbot/modules/paramminer_headers.py +0 -0
- {bbot-2.4.2.6596rc0 → bbot-2.4.2.6611rc0}/bbot/modules/passivetotal.py +0 -0
- {bbot-2.4.2.6596rc0 → bbot-2.4.2.6611rc0}/bbot/modules/pgp.py +0 -0
- {bbot-2.4.2.6596rc0 → bbot-2.4.2.6611rc0}/bbot/modules/portfilter.py +0 -0
- {bbot-2.4.2.6596rc0 → bbot-2.4.2.6611rc0}/bbot/modules/portscan.py +0 -0
- {bbot-2.4.2.6596rc0 → bbot-2.4.2.6611rc0}/bbot/modules/postman.py +0 -0
- {bbot-2.4.2.6596rc0 → bbot-2.4.2.6611rc0}/bbot/modules/postman_download.py +0 -0
- {bbot-2.4.2.6596rc0 → bbot-2.4.2.6611rc0}/bbot/modules/rapiddns.py +0 -0
- {bbot-2.4.2.6596rc0 → bbot-2.4.2.6611rc0}/bbot/modules/reflected_parameters.py +0 -0
- {bbot-2.4.2.6596rc0 → bbot-2.4.2.6611rc0}/bbot/modules/report/affiliates.py +0 -0
- {bbot-2.4.2.6596rc0 → bbot-2.4.2.6611rc0}/bbot/modules/report/asn.py +0 -0
- {bbot-2.4.2.6596rc0 → bbot-2.4.2.6611rc0}/bbot/modules/report/base.py +0 -0
- {bbot-2.4.2.6596rc0 → bbot-2.4.2.6611rc0}/bbot/modules/robots.py +0 -0
- {bbot-2.4.2.6596rc0 → bbot-2.4.2.6611rc0}/bbot/modules/securitytrails.py +0 -0
- {bbot-2.4.2.6596rc0 → bbot-2.4.2.6611rc0}/bbot/modules/securitytxt.py +0 -0
- {bbot-2.4.2.6596rc0 → bbot-2.4.2.6611rc0}/bbot/modules/shodan_dns.py +0 -0
- {bbot-2.4.2.6596rc0 → bbot-2.4.2.6611rc0}/bbot/modules/shodan_idb.py +0 -0
- {bbot-2.4.2.6596rc0 → bbot-2.4.2.6611rc0}/bbot/modules/sitedossier.py +0 -0
- {bbot-2.4.2.6596rc0 → bbot-2.4.2.6611rc0}/bbot/modules/skymem.py +0 -0
- {bbot-2.4.2.6596rc0 → bbot-2.4.2.6611rc0}/bbot/modules/smuggler.py +0 -0
- {bbot-2.4.2.6596rc0 → bbot-2.4.2.6611rc0}/bbot/modules/social.py +0 -0
- {bbot-2.4.2.6596rc0 → bbot-2.4.2.6611rc0}/bbot/modules/sslcert.py +0 -0
- {bbot-2.4.2.6596rc0 → bbot-2.4.2.6611rc0}/bbot/modules/subdomaincenter.py +0 -0
- {bbot-2.4.2.6596rc0 → bbot-2.4.2.6611rc0}/bbot/modules/subdomainradar.py +0 -0
- {bbot-2.4.2.6596rc0 → bbot-2.4.2.6611rc0}/bbot/modules/telerik.py +0 -0
- {bbot-2.4.2.6596rc0 → bbot-2.4.2.6611rc0}/bbot/modules/templates/bucket.py +0 -0
- {bbot-2.4.2.6596rc0 → bbot-2.4.2.6611rc0}/bbot/modules/templates/github.py +0 -0
- {bbot-2.4.2.6596rc0 → bbot-2.4.2.6611rc0}/bbot/modules/templates/postman.py +0 -0
- {bbot-2.4.2.6596rc0 → bbot-2.4.2.6611rc0}/bbot/modules/templates/shodan.py +0 -0
- {bbot-2.4.2.6596rc0 → bbot-2.4.2.6611rc0}/bbot/modules/templates/sql.py +0 -0
- {bbot-2.4.2.6596rc0 → bbot-2.4.2.6611rc0}/bbot/modules/templates/subdomain_enum.py +0 -0
- {bbot-2.4.2.6596rc0 → bbot-2.4.2.6611rc0}/bbot/modules/templates/webhook.py +0 -0
- {bbot-2.4.2.6596rc0 → bbot-2.4.2.6611rc0}/bbot/modules/trickest.py +0 -0
- {bbot-2.4.2.6596rc0 → bbot-2.4.2.6611rc0}/bbot/modules/trufflehog.py +0 -0
- {bbot-2.4.2.6596rc0 → bbot-2.4.2.6611rc0}/bbot/modules/url_manipulation.py +0 -0
- {bbot-2.4.2.6596rc0 → bbot-2.4.2.6611rc0}/bbot/modules/urlscan.py +0 -0
- {bbot-2.4.2.6596rc0 → bbot-2.4.2.6611rc0}/bbot/modules/vhost.py +0 -0
- {bbot-2.4.2.6596rc0 → bbot-2.4.2.6611rc0}/bbot/modules/viewdns.py +0 -0
- {bbot-2.4.2.6596rc0 → bbot-2.4.2.6611rc0}/bbot/modules/virustotal.py +0 -0
- {bbot-2.4.2.6596rc0 → bbot-2.4.2.6611rc0}/bbot/modules/wafw00f.py +0 -0
- {bbot-2.4.2.6596rc0 → bbot-2.4.2.6611rc0}/bbot/modules/wappalyzer.py +0 -0
- {bbot-2.4.2.6596rc0 → bbot-2.4.2.6611rc0}/bbot/modules/wayback.py +0 -0
- {bbot-2.4.2.6596rc0 → bbot-2.4.2.6611rc0}/bbot/modules/wpscan.py +0 -0
- {bbot-2.4.2.6596rc0 → bbot-2.4.2.6611rc0}/bbot/modules/zoomeye.py +0 -0
- {bbot-2.4.2.6596rc0 → bbot-2.4.2.6611rc0}/bbot/presets/baddns-intense.yml +0 -0
- {bbot-2.4.2.6596rc0 → bbot-2.4.2.6611rc0}/bbot/presets/cloud-enum.yml +0 -0
- {bbot-2.4.2.6596rc0 → bbot-2.4.2.6611rc0}/bbot/presets/code-enum.yml +0 -0
- {bbot-2.4.2.6596rc0 → bbot-2.4.2.6611rc0}/bbot/presets/email-enum.yml +0 -0
- {bbot-2.4.2.6596rc0 → bbot-2.4.2.6611rc0}/bbot/presets/fast.yml +0 -0
- {bbot-2.4.2.6596rc0 → bbot-2.4.2.6611rc0}/bbot/presets/kitchen-sink.yml +0 -0
- {bbot-2.4.2.6596rc0 → bbot-2.4.2.6611rc0}/bbot/presets/nuclei/nuclei-budget.yml +0 -0
- {bbot-2.4.2.6596rc0 → bbot-2.4.2.6611rc0}/bbot/presets/nuclei/nuclei-intense.yml +0 -0
- {bbot-2.4.2.6596rc0 → bbot-2.4.2.6611rc0}/bbot/presets/nuclei/nuclei-technology.yml +0 -0
- {bbot-2.4.2.6596rc0 → bbot-2.4.2.6611rc0}/bbot/presets/nuclei/nuclei.yml +0 -0
- {bbot-2.4.2.6596rc0 → bbot-2.4.2.6611rc0}/bbot/presets/spider-intense.yml +0 -0
- {bbot-2.4.2.6596rc0 → bbot-2.4.2.6611rc0}/bbot/presets/spider.yml +0 -0
- {bbot-2.4.2.6596rc0 → bbot-2.4.2.6611rc0}/bbot/presets/subdomain-enum.yml +0 -0
- {bbot-2.4.2.6596rc0 → bbot-2.4.2.6611rc0}/bbot/presets/tech-detect.yml +0 -0
- {bbot-2.4.2.6596rc0 → bbot-2.4.2.6611rc0}/bbot/presets/web/dirbust-heavy.yml +0 -0
- {bbot-2.4.2.6596rc0 → bbot-2.4.2.6611rc0}/bbot/presets/web/dirbust-light.yml +0 -0
- {bbot-2.4.2.6596rc0 → bbot-2.4.2.6611rc0}/bbot/presets/web/dotnet-audit.yml +0 -0
- {bbot-2.4.2.6596rc0 → bbot-2.4.2.6611rc0}/bbot/presets/web/iis-shortnames.yml +0 -0
- {bbot-2.4.2.6596rc0 → bbot-2.4.2.6611rc0}/bbot/presets/web/lightfuzz-heavy.yml +0 -0
- {bbot-2.4.2.6596rc0 → bbot-2.4.2.6611rc0}/bbot/presets/web/lightfuzz-light.yml +0 -0
- {bbot-2.4.2.6596rc0 → bbot-2.4.2.6611rc0}/bbot/presets/web/lightfuzz-medium.yml +0 -0
- {bbot-2.4.2.6596rc0 → bbot-2.4.2.6611rc0}/bbot/presets/web/lightfuzz-superheavy.yml +0 -0
- {bbot-2.4.2.6596rc0 → bbot-2.4.2.6611rc0}/bbot/presets/web/lightfuzz-xss.yml +0 -0
- {bbot-2.4.2.6596rc0 → bbot-2.4.2.6611rc0}/bbot/presets/web/paramminer.yml +0 -0
- {bbot-2.4.2.6596rc0 → bbot-2.4.2.6611rc0}/bbot/presets/web-basic.yml +0 -0
- {bbot-2.4.2.6596rc0 → bbot-2.4.2.6611rc0}/bbot/presets/web-screenshots.yml +0 -0
- {bbot-2.4.2.6596rc0 → bbot-2.4.2.6611rc0}/bbot/presets/web-thorough.yml +0 -0
- {bbot-2.4.2.6596rc0 → bbot-2.4.2.6611rc0}/bbot/scanner/__init__.py +0 -0
- {bbot-2.4.2.6596rc0 → bbot-2.4.2.6611rc0}/bbot/scanner/dispatcher.py +0 -0
- {bbot-2.4.2.6596rc0 → bbot-2.4.2.6611rc0}/bbot/scanner/manager.py +0 -0
- {bbot-2.4.2.6596rc0 → bbot-2.4.2.6611rc0}/bbot/scanner/preset/__init__.py +0 -0
- {bbot-2.4.2.6596rc0 → bbot-2.4.2.6611rc0}/bbot/scanner/preset/args.py +0 -0
- {bbot-2.4.2.6596rc0 → bbot-2.4.2.6611rc0}/bbot/scanner/preset/conditions.py +0 -0
- {bbot-2.4.2.6596rc0 → bbot-2.4.2.6611rc0}/bbot/scanner/preset/environ.py +0 -0
- {bbot-2.4.2.6596rc0 → bbot-2.4.2.6611rc0}/bbot/scanner/preset/path.py +0 -0
- {bbot-2.4.2.6596rc0 → bbot-2.4.2.6611rc0}/bbot/scanner/preset/preset.py +0 -0
- {bbot-2.4.2.6596rc0 → bbot-2.4.2.6611rc0}/bbot/scanner/scanner.py +0 -0
- {bbot-2.4.2.6596rc0 → bbot-2.4.2.6611rc0}/bbot/scanner/stats.py +0 -0
- {bbot-2.4.2.6596rc0 → bbot-2.4.2.6611rc0}/bbot/scanner/target.py +0 -0
- {bbot-2.4.2.6596rc0 → bbot-2.4.2.6611rc0}/bbot/scripts/docs.py +0 -0
- {bbot-2.4.2.6596rc0 → bbot-2.4.2.6611rc0}/bbot/test/__init__.py +0 -0
- {bbot-2.4.2.6596rc0 → bbot-2.4.2.6611rc0}/bbot/test/bbot_fixtures.py +0 -0
- {bbot-2.4.2.6596rc0 → bbot-2.4.2.6611rc0}/bbot/test/conftest.py +0 -0
- {bbot-2.4.2.6596rc0 → bbot-2.4.2.6611rc0}/bbot/test/coverage.cfg +0 -0
- {bbot-2.4.2.6596rc0 → bbot-2.4.2.6611rc0}/bbot/test/fastapi_test.py +0 -0
- {bbot-2.4.2.6596rc0 → bbot-2.4.2.6611rc0}/bbot/test/owasp_mastg.apk +0 -0
- {bbot-2.4.2.6596rc0 → bbot-2.4.2.6611rc0}/bbot/test/run_tests.sh +0 -0
- {bbot-2.4.2.6596rc0 → bbot-2.4.2.6611rc0}/bbot/test/test.conf +0 -0
- {bbot-2.4.2.6596rc0 → bbot-2.4.2.6611rc0}/bbot/test/test_output.ndjson +0 -0
- {bbot-2.4.2.6596rc0 → bbot-2.4.2.6611rc0}/bbot/test/test_step_1/__init__.py +0 -0
- {bbot-2.4.2.6596rc0 → bbot-2.4.2.6611rc0}/bbot/test/test_step_1/test__module__tests.py +0 -0
- {bbot-2.4.2.6596rc0 → bbot-2.4.2.6611rc0}/bbot/test/test_step_1/test_bbot_fastapi.py +0 -0
- {bbot-2.4.2.6596rc0 → bbot-2.4.2.6611rc0}/bbot/test/test_step_1/test_bloom_filter.py +0 -0
- {bbot-2.4.2.6596rc0 → bbot-2.4.2.6611rc0}/bbot/test/test_step_1/test_cli.py +0 -0
- {bbot-2.4.2.6596rc0 → bbot-2.4.2.6611rc0}/bbot/test/test_step_1/test_command.py +0 -0
- {bbot-2.4.2.6596rc0 → bbot-2.4.2.6611rc0}/bbot/test/test_step_1/test_config.py +0 -0
- {bbot-2.4.2.6596rc0 → bbot-2.4.2.6611rc0}/bbot/test/test_step_1/test_depsinstaller.py +0 -0
- {bbot-2.4.2.6596rc0 → bbot-2.4.2.6611rc0}/bbot/test/test_step_1/test_dns.py +0 -0
- {bbot-2.4.2.6596rc0 → bbot-2.4.2.6611rc0}/bbot/test/test_step_1/test_docs.py +0 -0
- {bbot-2.4.2.6596rc0 → bbot-2.4.2.6611rc0}/bbot/test/test_step_1/test_engine.py +0 -0
- {bbot-2.4.2.6596rc0 → bbot-2.4.2.6611rc0}/bbot/test/test_step_1/test_event_seeds.py +0 -0
- {bbot-2.4.2.6596rc0 → bbot-2.4.2.6611rc0}/bbot/test/test_step_1/test_events.py +0 -0
- {bbot-2.4.2.6596rc0 → bbot-2.4.2.6611rc0}/bbot/test/test_step_1/test_files.py +0 -0
- {bbot-2.4.2.6596rc0 → bbot-2.4.2.6611rc0}/bbot/test/test_step_1/test_helpers.py +0 -0
- {bbot-2.4.2.6596rc0 → bbot-2.4.2.6611rc0}/bbot/test/test_step_1/test_manager_deduplication.py +0 -0
- {bbot-2.4.2.6596rc0 → bbot-2.4.2.6611rc0}/bbot/test/test_step_1/test_manager_scope_accuracy.py +0 -0
- {bbot-2.4.2.6596rc0 → bbot-2.4.2.6611rc0}/bbot/test/test_step_1/test_modules_basic.py +0 -0
- {bbot-2.4.2.6596rc0 → bbot-2.4.2.6611rc0}/bbot/test/test_step_1/test_presets.py +0 -0
- {bbot-2.4.2.6596rc0 → bbot-2.4.2.6611rc0}/bbot/test/test_step_1/test_python_api.py +0 -0
- {bbot-2.4.2.6596rc0 → bbot-2.4.2.6611rc0}/bbot/test/test_step_1/test_regexes.py +0 -0
- {bbot-2.4.2.6596rc0 → bbot-2.4.2.6611rc0}/bbot/test/test_step_1/test_scan.py +0 -0
- {bbot-2.4.2.6596rc0 → bbot-2.4.2.6611rc0}/bbot/test/test_step_1/test_scope.py +0 -0
- {bbot-2.4.2.6596rc0 → bbot-2.4.2.6611rc0}/bbot/test/test_step_1/test_target.py +0 -0
- {bbot-2.4.2.6596rc0 → bbot-2.4.2.6611rc0}/bbot/test/test_step_1/test_web.py +0 -0
- {bbot-2.4.2.6596rc0 → bbot-2.4.2.6611rc0}/bbot/test/test_step_1/test_web_envelopes.py +0 -0
- {bbot-2.4.2.6596rc0 → bbot-2.4.2.6611rc0}/bbot/test/test_step_2/__init__.py +0 -0
- {bbot-2.4.2.6596rc0 → bbot-2.4.2.6611rc0}/bbot/test/test_step_2/module_tests/__init__.py +0 -0
- {bbot-2.4.2.6596rc0 → bbot-2.4.2.6611rc0}/bbot/test/test_step_2/module_tests/test_module_affiliates.py +0 -0
- {bbot-2.4.2.6596rc0 → bbot-2.4.2.6611rc0}/bbot/test/test_step_2/module_tests/test_module_aggregate.py +0 -0
- {bbot-2.4.2.6596rc0 → bbot-2.4.2.6611rc0}/bbot/test/test_step_2/module_tests/test_module_ajaxpro.py +0 -0
- {bbot-2.4.2.6596rc0 → bbot-2.4.2.6611rc0}/bbot/test/test_step_2/module_tests/test_module_anubisdb.py +0 -0
- {bbot-2.4.2.6596rc0 → bbot-2.4.2.6611rc0}/bbot/test/test_step_2/module_tests/test_module_apkpure.py +0 -0
- {bbot-2.4.2.6596rc0 → bbot-2.4.2.6611rc0}/bbot/test/test_step_2/module_tests/test_module_asn.py +0 -0
- {bbot-2.4.2.6596rc0 → bbot-2.4.2.6611rc0}/bbot/test/test_step_2/module_tests/test_module_asset_inventory.py +0 -0
- {bbot-2.4.2.6596rc0 → bbot-2.4.2.6611rc0}/bbot/test/test_step_2/module_tests/test_module_azure_realm.py +0 -0
- {bbot-2.4.2.6596rc0 → bbot-2.4.2.6611rc0}/bbot/test/test_step_2/module_tests/test_module_azure_tenant.py +0 -0
- {bbot-2.4.2.6596rc0 → bbot-2.4.2.6611rc0}/bbot/test/test_step_2/module_tests/test_module_baddns.py +0 -0
- {bbot-2.4.2.6596rc0 → bbot-2.4.2.6611rc0}/bbot/test/test_step_2/module_tests/test_module_baddns_direct.py +0 -0
- {bbot-2.4.2.6596rc0 → bbot-2.4.2.6611rc0}/bbot/test/test_step_2/module_tests/test_module_baddns_zone.py +0 -0
- {bbot-2.4.2.6596rc0 → bbot-2.4.2.6611rc0}/bbot/test/test_step_2/module_tests/test_module_badsecrets.py +0 -0
- {bbot-2.4.2.6596rc0 → bbot-2.4.2.6611rc0}/bbot/test/test_step_2/module_tests/test_module_bevigil.py +0 -0
- {bbot-2.4.2.6596rc0 → bbot-2.4.2.6611rc0}/bbot/test/test_step_2/module_tests/test_module_binaryedge.py +0 -0
- {bbot-2.4.2.6596rc0 → bbot-2.4.2.6611rc0}/bbot/test/test_step_2/module_tests/test_module_bucket_amazon.py +0 -0
- {bbot-2.4.2.6596rc0 → bbot-2.4.2.6611rc0}/bbot/test/test_step_2/module_tests/test_module_bucket_azure.py +0 -0
- {bbot-2.4.2.6596rc0 → bbot-2.4.2.6611rc0}/bbot/test/test_step_2/module_tests/test_module_bucket_digitalocean.py +0 -0
- {bbot-2.4.2.6596rc0 → bbot-2.4.2.6611rc0}/bbot/test/test_step_2/module_tests/test_module_bucket_file_enum.py +0 -0
- {bbot-2.4.2.6596rc0 → bbot-2.4.2.6611rc0}/bbot/test/test_step_2/module_tests/test_module_bucket_firebase.py +0 -0
- {bbot-2.4.2.6596rc0 → bbot-2.4.2.6611rc0}/bbot/test/test_step_2/module_tests/test_module_bucket_google.py +0 -0
- {bbot-2.4.2.6596rc0 → bbot-2.4.2.6611rc0}/bbot/test/test_step_2/module_tests/test_module_bufferoverrun.py +0 -0
- {bbot-2.4.2.6596rc0 → bbot-2.4.2.6611rc0}/bbot/test/test_step_2/module_tests/test_module_builtwith.py +0 -0
- {bbot-2.4.2.6596rc0 → bbot-2.4.2.6611rc0}/bbot/test/test_step_2/module_tests/test_module_bypass403.py +0 -0
- {bbot-2.4.2.6596rc0 → bbot-2.4.2.6611rc0}/bbot/test/test_step_2/module_tests/test_module_c99.py +0 -0
- {bbot-2.4.2.6596rc0 → bbot-2.4.2.6611rc0}/bbot/test/test_step_2/module_tests/test_module_censys.py +0 -0
- {bbot-2.4.2.6596rc0 → bbot-2.4.2.6611rc0}/bbot/test/test_step_2/module_tests/test_module_certspotter.py +0 -0
- {bbot-2.4.2.6596rc0 → bbot-2.4.2.6611rc0}/bbot/test/test_step_2/module_tests/test_module_chaos.py +0 -0
- {bbot-2.4.2.6596rc0 → bbot-2.4.2.6611rc0}/bbot/test/test_step_2/module_tests/test_module_cloudcheck.py +0 -0
- {bbot-2.4.2.6596rc0 → bbot-2.4.2.6611rc0}/bbot/test/test_step_2/module_tests/test_module_code_repository.py +0 -0
- {bbot-2.4.2.6596rc0 → bbot-2.4.2.6611rc0}/bbot/test/test_step_2/module_tests/test_module_credshed.py +0 -0
- {bbot-2.4.2.6596rc0 → bbot-2.4.2.6611rc0}/bbot/test/test_step_2/module_tests/test_module_crt.py +0 -0
- {bbot-2.4.2.6596rc0 → bbot-2.4.2.6611rc0}/bbot/test/test_step_2/module_tests/test_module_crt_db.py +0 -0
- {bbot-2.4.2.6596rc0 → bbot-2.4.2.6611rc0}/bbot/test/test_step_2/module_tests/test_module_csv.py +0 -0
- {bbot-2.4.2.6596rc0 → bbot-2.4.2.6611rc0}/bbot/test/test_step_2/module_tests/test_module_dehashed.py +0 -0
- {bbot-2.4.2.6596rc0 → bbot-2.4.2.6611rc0}/bbot/test/test_step_2/module_tests/test_module_digitorus.py +0 -0
- {bbot-2.4.2.6596rc0 → bbot-2.4.2.6611rc0}/bbot/test/test_step_2/module_tests/test_module_discord.py +0 -0
- {bbot-2.4.2.6596rc0 → bbot-2.4.2.6611rc0}/bbot/test/test_step_2/module_tests/test_module_dnsbimi.py +0 -0
- {bbot-2.4.2.6596rc0 → bbot-2.4.2.6611rc0}/bbot/test/test_step_2/module_tests/test_module_dnsbrute.py +0 -0
- {bbot-2.4.2.6596rc0 → bbot-2.4.2.6611rc0}/bbot/test/test_step_2/module_tests/test_module_dnsbrute_mutations.py +0 -0
- {bbot-2.4.2.6596rc0 → bbot-2.4.2.6611rc0}/bbot/test/test_step_2/module_tests/test_module_dnscaa.py +0 -0
- {bbot-2.4.2.6596rc0 → bbot-2.4.2.6611rc0}/bbot/test/test_step_2/module_tests/test_module_dnscommonsrv.py +0 -0
- {bbot-2.4.2.6596rc0 → bbot-2.4.2.6611rc0}/bbot/test/test_step_2/module_tests/test_module_dnsdumpster.py +0 -0
- {bbot-2.4.2.6596rc0 → bbot-2.4.2.6611rc0}/bbot/test/test_step_2/module_tests/test_module_dnsresolve.py +0 -0
- {bbot-2.4.2.6596rc0 → bbot-2.4.2.6611rc0}/bbot/test/test_step_2/module_tests/test_module_dnstlsrpt.py +0 -0
- {bbot-2.4.2.6596rc0 → bbot-2.4.2.6611rc0}/bbot/test/test_step_2/module_tests/test_module_docker_pull.py +0 -0
- {bbot-2.4.2.6596rc0 → bbot-2.4.2.6611rc0}/bbot/test/test_step_2/module_tests/test_module_dockerhub.py +0 -0
- {bbot-2.4.2.6596rc0 → bbot-2.4.2.6611rc0}/bbot/test/test_step_2/module_tests/test_module_dotnetnuke.py +0 -0
- {bbot-2.4.2.6596rc0 → bbot-2.4.2.6611rc0}/bbot/test/test_step_2/module_tests/test_module_emailformat.py +0 -0
- {bbot-2.4.2.6596rc0 → bbot-2.4.2.6611rc0}/bbot/test/test_step_2/module_tests/test_module_emails.py +0 -0
- {bbot-2.4.2.6596rc0 → bbot-2.4.2.6611rc0}/bbot/test/test_step_2/module_tests/test_module_extractous.py +0 -0
- {bbot-2.4.2.6596rc0 → bbot-2.4.2.6611rc0}/bbot/test/test_step_2/module_tests/test_module_ffuf.py +0 -0
- {bbot-2.4.2.6596rc0 → bbot-2.4.2.6611rc0}/bbot/test/test_step_2/module_tests/test_module_ffuf_shortnames.py +0 -0
- {bbot-2.4.2.6596rc0 → bbot-2.4.2.6611rc0}/bbot/test/test_step_2/module_tests/test_module_filedownload.py +0 -0
- {bbot-2.4.2.6596rc0 → bbot-2.4.2.6611rc0}/bbot/test/test_step_2/module_tests/test_module_fingerprintx.py +0 -0
- {bbot-2.4.2.6596rc0 → bbot-2.4.2.6611rc0}/bbot/test/test_step_2/module_tests/test_module_fullhunt.py +0 -0
- {bbot-2.4.2.6596rc0 → bbot-2.4.2.6611rc0}/bbot/test/test_step_2/module_tests/test_module_generic_ssrf.py +0 -0
- {bbot-2.4.2.6596rc0 → bbot-2.4.2.6611rc0}/bbot/test/test_step_2/module_tests/test_module_git.py +0 -0
- {bbot-2.4.2.6596rc0 → bbot-2.4.2.6611rc0}/bbot/test/test_step_2/module_tests/test_module_git_clone.py +0 -0
- {bbot-2.4.2.6596rc0 → bbot-2.4.2.6611rc0}/bbot/test/test_step_2/module_tests/test_module_gitdumper.py +0 -0
- {bbot-2.4.2.6596rc0 → bbot-2.4.2.6611rc0}/bbot/test/test_step_2/module_tests/test_module_github_codesearch.py +0 -0
- {bbot-2.4.2.6596rc0 → bbot-2.4.2.6611rc0}/bbot/test/test_step_2/module_tests/test_module_github_org.py +0 -0
- {bbot-2.4.2.6596rc0 → bbot-2.4.2.6611rc0}/bbot/test/test_step_2/module_tests/test_module_github_workflows.py +0 -0
- {bbot-2.4.2.6596rc0 → bbot-2.4.2.6611rc0}/bbot/test/test_step_2/module_tests/test_module_gitlab.py +0 -0
- {bbot-2.4.2.6596rc0 → bbot-2.4.2.6611rc0}/bbot/test/test_step_2/module_tests/test_module_google_playstore.py +0 -0
- {bbot-2.4.2.6596rc0 → bbot-2.4.2.6611rc0}/bbot/test/test_step_2/module_tests/test_module_gowitness.py +0 -0
- {bbot-2.4.2.6596rc0 → bbot-2.4.2.6611rc0}/bbot/test/test_step_2/module_tests/test_module_hackertarget.py +0 -0
- {bbot-2.4.2.6596rc0 → bbot-2.4.2.6611rc0}/bbot/test/test_step_2/module_tests/test_module_host_header.py +0 -0
- {bbot-2.4.2.6596rc0 → bbot-2.4.2.6611rc0}/bbot/test/test_step_2/module_tests/test_module_http.py +0 -0
- {bbot-2.4.2.6596rc0 → bbot-2.4.2.6611rc0}/bbot/test/test_step_2/module_tests/test_module_httpx.py +0 -0
- {bbot-2.4.2.6596rc0 → bbot-2.4.2.6611rc0}/bbot/test/test_step_2/module_tests/test_module_hunt.py +0 -0
- {bbot-2.4.2.6596rc0 → bbot-2.4.2.6611rc0}/bbot/test/test_step_2/module_tests/test_module_hunterio.py +0 -0
- {bbot-2.4.2.6596rc0 → bbot-2.4.2.6611rc0}/bbot/test/test_step_2/module_tests/test_module_iis_shortnames.py +0 -0
- {bbot-2.4.2.6596rc0 → bbot-2.4.2.6611rc0}/bbot/test/test_step_2/module_tests/test_module_ip2location.py +0 -0
- {bbot-2.4.2.6596rc0 → bbot-2.4.2.6611rc0}/bbot/test/test_step_2/module_tests/test_module_ipneighbor.py +0 -0
- {bbot-2.4.2.6596rc0 → bbot-2.4.2.6611rc0}/bbot/test/test_step_2/module_tests/test_module_ipstack.py +0 -0
- {bbot-2.4.2.6596rc0 → bbot-2.4.2.6611rc0}/bbot/test/test_step_2/module_tests/test_module_jadx.py +0 -0
- {bbot-2.4.2.6596rc0 → bbot-2.4.2.6611rc0}/bbot/test/test_step_2/module_tests/test_module_json.py +0 -0
- {bbot-2.4.2.6596rc0 → bbot-2.4.2.6611rc0}/bbot/test/test_step_2/module_tests/test_module_leakix.py +0 -0
- {bbot-2.4.2.6596rc0 → bbot-2.4.2.6611rc0}/bbot/test/test_step_2/module_tests/test_module_lightfuzz.py +0 -0
- {bbot-2.4.2.6596rc0 → bbot-2.4.2.6611rc0}/bbot/test/test_step_2/module_tests/test_module_mysql.py +0 -0
- {bbot-2.4.2.6596rc0 → bbot-2.4.2.6611rc0}/bbot/test/test_step_2/module_tests/test_module_myssl.py +0 -0
- {bbot-2.4.2.6596rc0 → bbot-2.4.2.6611rc0}/bbot/test/test_step_2/module_tests/test_module_neo4j.py +0 -0
- {bbot-2.4.2.6596rc0 → bbot-2.4.2.6611rc0}/bbot/test/test_step_2/module_tests/test_module_newsletters.py +0 -0
- {bbot-2.4.2.6596rc0 → bbot-2.4.2.6611rc0}/bbot/test/test_step_2/module_tests/test_module_nmap_xml.py +0 -0
- {bbot-2.4.2.6596rc0 → bbot-2.4.2.6611rc0}/bbot/test/test_step_2/module_tests/test_module_ntlm.py +0 -0
- {bbot-2.4.2.6596rc0 → bbot-2.4.2.6611rc0}/bbot/test/test_step_2/module_tests/test_module_nuclei.py +0 -0
- {bbot-2.4.2.6596rc0 → bbot-2.4.2.6611rc0}/bbot/test/test_step_2/module_tests/test_module_oauth.py +0 -0
- {bbot-2.4.2.6596rc0 → bbot-2.4.2.6611rc0}/bbot/test/test_step_2/module_tests/test_module_otx.py +0 -0
- {bbot-2.4.2.6596rc0 → bbot-2.4.2.6611rc0}/bbot/test/test_step_2/module_tests/test_module_paramminer_cookies.py +0 -0
- {bbot-2.4.2.6596rc0 → bbot-2.4.2.6611rc0}/bbot/test/test_step_2/module_tests/test_module_paramminer_getparams.py +0 -0
- {bbot-2.4.2.6596rc0 → bbot-2.4.2.6611rc0}/bbot/test/test_step_2/module_tests/test_module_paramminer_headers.py +0 -0
- {bbot-2.4.2.6596rc0 → bbot-2.4.2.6611rc0}/bbot/test/test_step_2/module_tests/test_module_passivetotal.py +0 -0
- {bbot-2.4.2.6596rc0 → bbot-2.4.2.6611rc0}/bbot/test/test_step_2/module_tests/test_module_pgp.py +0 -0
- {bbot-2.4.2.6596rc0 → bbot-2.4.2.6611rc0}/bbot/test/test_step_2/module_tests/test_module_portfilter.py +0 -0
- {bbot-2.4.2.6596rc0 → bbot-2.4.2.6611rc0}/bbot/test/test_step_2/module_tests/test_module_portscan.py +0 -0
- {bbot-2.4.2.6596rc0 → bbot-2.4.2.6611rc0}/bbot/test/test_step_2/module_tests/test_module_postgres.py +0 -0
- {bbot-2.4.2.6596rc0 → bbot-2.4.2.6611rc0}/bbot/test/test_step_2/module_tests/test_module_postman.py +0 -0
- {bbot-2.4.2.6596rc0 → bbot-2.4.2.6611rc0}/bbot/test/test_step_2/module_tests/test_module_postman_download.py +0 -0
- {bbot-2.4.2.6596rc0 → bbot-2.4.2.6611rc0}/bbot/test/test_step_2/module_tests/test_module_python.py +0 -0
- {bbot-2.4.2.6596rc0 → bbot-2.4.2.6611rc0}/bbot/test/test_step_2/module_tests/test_module_rapiddns.py +0 -0
- {bbot-2.4.2.6596rc0 → bbot-2.4.2.6611rc0}/bbot/test/test_step_2/module_tests/test_module_reflected_parameters.py +0 -0
- {bbot-2.4.2.6596rc0 → bbot-2.4.2.6611rc0}/bbot/test/test_step_2/module_tests/test_module_robots.py +0 -0
- {bbot-2.4.2.6596rc0 → bbot-2.4.2.6611rc0}/bbot/test/test_step_2/module_tests/test_module_securitytrails.py +0 -0
- {bbot-2.4.2.6596rc0 → bbot-2.4.2.6611rc0}/bbot/test/test_step_2/module_tests/test_module_securitytxt.py +0 -0
- {bbot-2.4.2.6596rc0 → bbot-2.4.2.6611rc0}/bbot/test/test_step_2/module_tests/test_module_shodan_dns.py +0 -0
- {bbot-2.4.2.6596rc0 → bbot-2.4.2.6611rc0}/bbot/test/test_step_2/module_tests/test_module_shodan_idb.py +0 -0
- {bbot-2.4.2.6596rc0 → bbot-2.4.2.6611rc0}/bbot/test/test_step_2/module_tests/test_module_sitedossier.py +0 -0
- {bbot-2.4.2.6596rc0 → bbot-2.4.2.6611rc0}/bbot/test/test_step_2/module_tests/test_module_skymem.py +0 -0
- {bbot-2.4.2.6596rc0 → bbot-2.4.2.6611rc0}/bbot/test/test_step_2/module_tests/test_module_slack.py +0 -0
- {bbot-2.4.2.6596rc0 → bbot-2.4.2.6611rc0}/bbot/test/test_step_2/module_tests/test_module_smuggler.py +0 -0
- {bbot-2.4.2.6596rc0 → bbot-2.4.2.6611rc0}/bbot/test/test_step_2/module_tests/test_module_social.py +0 -0
- {bbot-2.4.2.6596rc0 → bbot-2.4.2.6611rc0}/bbot/test/test_step_2/module_tests/test_module_speculate.py +0 -0
- {bbot-2.4.2.6596rc0 → bbot-2.4.2.6611rc0}/bbot/test/test_step_2/module_tests/test_module_splunk.py +0 -0
- {bbot-2.4.2.6596rc0 → bbot-2.4.2.6611rc0}/bbot/test/test_step_2/module_tests/test_module_sqlite.py +0 -0
- {bbot-2.4.2.6596rc0 → bbot-2.4.2.6611rc0}/bbot/test/test_step_2/module_tests/test_module_sslcert.py +0 -0
- {bbot-2.4.2.6596rc0 → bbot-2.4.2.6611rc0}/bbot/test/test_step_2/module_tests/test_module_stdout.py +0 -0
- {bbot-2.4.2.6596rc0 → bbot-2.4.2.6611rc0}/bbot/test/test_step_2/module_tests/test_module_subdomaincenter.py +0 -0
- {bbot-2.4.2.6596rc0 → bbot-2.4.2.6611rc0}/bbot/test/test_step_2/module_tests/test_module_subdomainradar.py +0 -0
- {bbot-2.4.2.6596rc0 → bbot-2.4.2.6611rc0}/bbot/test/test_step_2/module_tests/test_module_subdomains.py +0 -0
- {bbot-2.4.2.6596rc0 → bbot-2.4.2.6611rc0}/bbot/test/test_step_2/module_tests/test_module_teams.py +0 -0
- {bbot-2.4.2.6596rc0 → bbot-2.4.2.6611rc0}/bbot/test/test_step_2/module_tests/test_module_telerik.py +0 -0
- {bbot-2.4.2.6596rc0 → bbot-2.4.2.6611rc0}/bbot/test/test_step_2/module_tests/test_module_trickest.py +0 -0
- {bbot-2.4.2.6596rc0 → bbot-2.4.2.6611rc0}/bbot/test/test_step_2/module_tests/test_module_trufflehog.py +0 -0
- {bbot-2.4.2.6596rc0 → bbot-2.4.2.6611rc0}/bbot/test/test_step_2/module_tests/test_module_txt.py +0 -0
- {bbot-2.4.2.6596rc0 → bbot-2.4.2.6611rc0}/bbot/test/test_step_2/module_tests/test_module_unarchive.py +0 -0
- {bbot-2.4.2.6596rc0 → bbot-2.4.2.6611rc0}/bbot/test/test_step_2/module_tests/test_module_url_manipulation.py +0 -0
- {bbot-2.4.2.6596rc0 → bbot-2.4.2.6611rc0}/bbot/test/test_step_2/module_tests/test_module_urlscan.py +0 -0
- {bbot-2.4.2.6596rc0 → bbot-2.4.2.6611rc0}/bbot/test/test_step_2/module_tests/test_module_vhost.py +0 -0
- {bbot-2.4.2.6596rc0 → bbot-2.4.2.6611rc0}/bbot/test/test_step_2/module_tests/test_module_viewdns.py +0 -0
- {bbot-2.4.2.6596rc0 → bbot-2.4.2.6611rc0}/bbot/test/test_step_2/module_tests/test_module_virustotal.py +0 -0
- {bbot-2.4.2.6596rc0 → bbot-2.4.2.6611rc0}/bbot/test/test_step_2/module_tests/test_module_wafw00f.py +0 -0
- {bbot-2.4.2.6596rc0 → bbot-2.4.2.6611rc0}/bbot/test/test_step_2/module_tests/test_module_wappalyzer.py +0 -0
- {bbot-2.4.2.6596rc0 → bbot-2.4.2.6611rc0}/bbot/test/test_step_2/module_tests/test_module_wayback.py +0 -0
- {bbot-2.4.2.6596rc0 → bbot-2.4.2.6611rc0}/bbot/test/test_step_2/module_tests/test_module_web_parameters.py +0 -0
- {bbot-2.4.2.6596rc0 → bbot-2.4.2.6611rc0}/bbot/test/test_step_2/module_tests/test_module_web_report.py +0 -0
- {bbot-2.4.2.6596rc0 → bbot-2.4.2.6611rc0}/bbot/test/test_step_2/module_tests/test_module_websocket.py +0 -0
- {bbot-2.4.2.6596rc0 → bbot-2.4.2.6611rc0}/bbot/test/test_step_2/module_tests/test_module_wpscan.py +0 -0
- {bbot-2.4.2.6596rc0 → bbot-2.4.2.6611rc0}/bbot/test/test_step_2/module_tests/test_module_zoomeye.py +0 -0
- {bbot-2.4.2.6596rc0 → bbot-2.4.2.6611rc0}/bbot/test/test_step_2/template_tests/__init__.py +0 -0
- {bbot-2.4.2.6596rc0 → bbot-2.4.2.6611rc0}/bbot/test/test_step_2/template_tests/test_template_subdomain_enum.py +0 -0
- {bbot-2.4.2.6596rc0 → bbot-2.4.2.6611rc0}/bbot/test/testsslcert.pem +0 -0
- {bbot-2.4.2.6596rc0 → bbot-2.4.2.6611rc0}/bbot/test/testsslkey.pem +0 -0
- {bbot-2.4.2.6596rc0 → bbot-2.4.2.6611rc0}/bbot/wordlists/devops_mutations.txt +0 -0
- {bbot-2.4.2.6596rc0 → bbot-2.4.2.6611rc0}/bbot/wordlists/ms_on_prem_subdomains.txt +0 -0
- {bbot-2.4.2.6596rc0 → bbot-2.4.2.6611rc0}/bbot/wordlists/nameservers.txt +0 -0
- {bbot-2.4.2.6596rc0 → bbot-2.4.2.6611rc0}/bbot/wordlists/paramminer_headers.txt +0 -0
- {bbot-2.4.2.6596rc0 → bbot-2.4.2.6611rc0}/bbot/wordlists/paramminer_parameters.txt +0 -0
- {bbot-2.4.2.6596rc0 → bbot-2.4.2.6611rc0}/bbot/wordlists/raft-small-extensions-lowercase_CLEANED.txt +0 -0
- {bbot-2.4.2.6596rc0 → bbot-2.4.2.6611rc0}/bbot/wordlists/top_open_ports_nmap.txt +0 -0
- {bbot-2.4.2.6596rc0 → bbot-2.4.2.6611rc0}/bbot/wordlists/valid_url_schemes.txt +0 -0
- {bbot-2.4.2.6596rc0 → bbot-2.4.2.6611rc0}/bbot/wordlists/wordninja_dns.txt.gz +0 -0
|
@@ -1,6 +1,6 @@
|
|
|
1
1
|
Metadata-Version: 2.3
|
|
2
2
|
Name: bbot
|
|
3
|
-
Version: 2.4.2.
|
|
3
|
+
Version: 2.4.2.6611rc0
|
|
4
4
|
Summary: OSINT automation for hackers.
|
|
5
5
|
License: GPL-3.0
|
|
6
6
|
Keywords: python,cli,automation,osint,threat-intel,intelligence,neo4j,scanner,python-library,hacking,recursion,pentesting,recon,command-line-tool,bugbounty,subdomains,security-tools,subdomain-scanner,osint-framework,attack-surface,subdomain-enumeration,osint-tool
|
|
@@ -5,7 +5,7 @@ import time
|
|
|
5
5
|
import inspect
|
|
6
6
|
import regex as re
|
|
7
7
|
from pathlib import Path
|
|
8
|
-
from bbot.errors import ExcavateError
|
|
8
|
+
from bbot.errors import ExcavateError, ValidationError
|
|
9
9
|
import bbot.core.helpers.regexes as bbot_regexes
|
|
10
10
|
from bbot.modules.base import BaseInterceptModule
|
|
11
11
|
from bbot.modules.internal.base import BaseInternalModule
|
|
@@ -622,14 +622,15 @@ class excavate(BaseInternalModule, BaseInterceptModule):
|
|
|
622
622
|
base_url += f"?{event.parsed_url.query}"
|
|
623
623
|
url = urljoin(base_url, endpoint)
|
|
624
624
|
|
|
625
|
+
try:
|
|
626
|
+
# Validate the URL before using it
|
|
627
|
+
parsed_url = self.excavate.helpers.validators.validate_url_parsed(url)
|
|
628
|
+
except (ValidationError, ValueError) as e:
|
|
629
|
+
self.excavate.debug(f"Invalid URL [{url}]: {e}")
|
|
630
|
+
continue
|
|
631
|
+
|
|
625
632
|
if self.excavate.helpers.validate_parameter(parameter_name, parameter_type):
|
|
626
633
|
if self.excavate.in_bl(parameter_name) is False:
|
|
627
|
-
parsed_url = urlparse(url)
|
|
628
|
-
if not parsed_url.hostname:
|
|
629
|
-
self.excavate.warning(
|
|
630
|
-
f"Error Parsing reconstructed URL [{url}] during parameter extraction, missing hostname"
|
|
631
|
-
)
|
|
632
|
-
continue
|
|
633
634
|
description = f"HTTP Extracted Parameter [{parameter_name}] ({parameterExtractorSubModule.name} Submodule)"
|
|
634
635
|
data = {
|
|
635
636
|
"host": parsed_url.hostname,
|
|
@@ -848,45 +849,51 @@ class excavate(BaseInternalModule, BaseInterceptModule):
|
|
|
848
849
|
urls_found = 0
|
|
849
850
|
final_url = ""
|
|
850
851
|
for url_str in results:
|
|
851
|
-
|
|
852
|
-
if
|
|
852
|
+
try:
|
|
853
|
+
if identifier == "url_full":
|
|
854
|
+
if not await self.helpers.re.search(self.full_url_regex, url_str):
|
|
855
|
+
self.excavate.debug(
|
|
856
|
+
f"Rejecting potential full URL [{url_str}] as did not match full_url_regex"
|
|
857
|
+
)
|
|
858
|
+
continue
|
|
859
|
+
final_url = url_str
|
|
860
|
+
self.excavate.debug(f"Discovered Full URL [{final_url}]")
|
|
861
|
+
|
|
862
|
+
elif identifier == "url_attr" and hasattr(event, "parsed_url"):
|
|
863
|
+
m = await self.helpers.re.search(self.tag_attribute_regex, url_str)
|
|
864
|
+
if not m:
|
|
865
|
+
self.excavate.debug(
|
|
866
|
+
f"Rejecting potential attribute URL [{url_str}] as did not match tag_attribute_regex"
|
|
867
|
+
)
|
|
868
|
+
continue
|
|
869
|
+
unescaped_url = html.unescape(m.group(1))
|
|
870
|
+
source_url = event.parsed_url.geturl()
|
|
871
|
+
final_url = urldefrag(urljoin(source_url, unescaped_url)).url
|
|
872
|
+
if not await self.helpers.re.search(self.full_url_regex_strict, final_url):
|
|
873
|
+
self.excavate.debug(
|
|
874
|
+
f"Rejecting reconstructed URL [{final_url}] as did not match full_url_regex_strict"
|
|
875
|
+
)
|
|
876
|
+
continue
|
|
853
877
|
self.excavate.debug(
|
|
854
|
-
f"
|
|
878
|
+
f"Reconstructed Full URL [{final_url}] from extracted relative URL [{unescaped_url}] "
|
|
855
879
|
)
|
|
856
|
-
continue
|
|
857
|
-
final_url = url_str
|
|
858
880
|
|
|
859
|
-
|
|
860
|
-
|
|
861
|
-
|
|
862
|
-
|
|
863
|
-
|
|
864
|
-
|
|
881
|
+
if final_url:
|
|
882
|
+
# Validate the URL before using it
|
|
883
|
+
self.excavate.helpers.validators.validate_url_parsed(final_url)
|
|
884
|
+
if self.excavate.scan.in_scope(final_url):
|
|
885
|
+
urls_found += 1
|
|
886
|
+
await self.report(
|
|
887
|
+
final_url,
|
|
888
|
+
event,
|
|
889
|
+
yara_rule_settings,
|
|
890
|
+
discovery_context,
|
|
891
|
+
event_type="URL_UNVERIFIED",
|
|
892
|
+
urls_found=urls_found,
|
|
865
893
|
)
|
|
866
|
-
|
|
867
|
-
|
|
868
|
-
|
|
869
|
-
final_url = urldefrag(urljoin(source_url, unescaped_url)).url
|
|
870
|
-
if not await self.helpers.re.search(self.full_url_regex_strict, final_url):
|
|
871
|
-
self.excavate.debug(
|
|
872
|
-
f"Rejecting reconstructed URL [{final_url}] as did not match full_url_regex_strict"
|
|
873
|
-
)
|
|
874
|
-
continue
|
|
875
|
-
self.excavate.debug(
|
|
876
|
-
f"Reconstructed Full URL [{final_url}] from extracted relative URL [{unescaped_url}] "
|
|
877
|
-
)
|
|
878
|
-
|
|
879
|
-
if final_url:
|
|
880
|
-
if self.excavate.scan.in_scope(final_url):
|
|
881
|
-
urls_found += 1
|
|
882
|
-
await self.report(
|
|
883
|
-
final_url,
|
|
884
|
-
event,
|
|
885
|
-
yara_rule_settings,
|
|
886
|
-
discovery_context,
|
|
887
|
-
event_type="URL_UNVERIFIED",
|
|
888
|
-
urls_found=urls_found,
|
|
889
|
-
)
|
|
894
|
+
except (ValidationError, ValueError) as e:
|
|
895
|
+
self.excavate.debug(f"Invalid URL [{url_str if not final_url else final_url}]: {e}")
|
|
896
|
+
continue
|
|
890
897
|
|
|
891
898
|
async def report_prep(self, event_data, event_type, event, tags, **kwargs):
|
|
892
899
|
event_draft = self.excavate.make_event(event_data, event_type, parent=event)
|
|
@@ -1114,7 +1121,10 @@ class excavate(BaseInternalModule, BaseInterceptModule):
|
|
|
1114
1121
|
|
|
1115
1122
|
# Check if rule processing function exists
|
|
1116
1123
|
if rule_name in self.yara_preprocess_dict:
|
|
1117
|
-
|
|
1124
|
+
try:
|
|
1125
|
+
await self.yara_preprocess_dict[rule_name](result, event, discovery_context)
|
|
1126
|
+
except ValidationError as e:
|
|
1127
|
+
self.debug(f"ValidationError in rule {rule_name} for result {result}: {e}")
|
|
1118
1128
|
else:
|
|
1119
1129
|
self.hugewarning(f"YARA Rule {rule_name} not found in pre-compiled rules")
|
|
1120
1130
|
|
|
@@ -22,7 +22,7 @@ class serial(BaseLightfuzz):
|
|
|
22
22
|
CONTROL_PAYLOAD_PHP_RAW = "z:0:{}"
|
|
23
23
|
|
|
24
24
|
BASE64_SERIALIZATION_PAYLOADS = {
|
|
25
|
-
"php_base64": "
|
|
25
|
+
"php_base64": "YToxOntpOjA7aToxO30=",
|
|
26
26
|
"java_base64": "rO0ABXNyABFqYXZhLmxhbmcuQm9vbGVhbs0gcoDVnPruAgABWgAFdmFsdWV4cAA=",
|
|
27
27
|
"java_base64_string_error": "rO0ABXQABHRlc3Q=",
|
|
28
28
|
"java_base64_OptionalDataException": "rO0ABXcEAAAAAAEAAAABc3IAEGphdmEudXRpbC5IYXNoTWFwAAAAAAAAAAECAAJMAARrZXkxYgABAAAAAAAAAAJ4cHcBAAAAB3QABHRlc3Q=",
|
|
@@ -91,9 +91,9 @@ class ModuleTestBase:
|
|
|
91
91
|
async def module_test(
|
|
92
92
|
self, httpx_mock, bbot_httpserver, bbot_httpserver_ssl, monkeypatch, request, caplog, capsys
|
|
93
93
|
):
|
|
94
|
-
#
|
|
94
|
+
# If a test uses docker, we can't run it in the distro tests
|
|
95
95
|
if os.getenv("BBOT_DISTRO_TESTS") and self.skip_distro_tests:
|
|
96
|
-
pytest.skip("Skipping
|
|
96
|
+
pytest.skip("Skipping test since it uses docker")
|
|
97
97
|
|
|
98
98
|
self.log.info(f"Starting {self.name} module test")
|
|
99
99
|
module_test = self.ModuleTest(
|
{bbot-2.4.2.6596rc0 → bbot-2.4.2.6611rc0}/bbot/test/test_step_2/module_tests/test_module_excavate.py
RENAMED
|
@@ -1418,3 +1418,17 @@ class TestExcavateBadURLs(ModuleTestBase):
|
|
|
1418
1418
|
|
|
1419
1419
|
url_events = [e for e in events if e.type == "URL_UNVERIFIED"]
|
|
1420
1420
|
assert sorted([e.data for e in url_events]) == sorted(["https://ssl/", "http://127.0.0.1:8888/"])
|
|
1421
|
+
|
|
1422
|
+
|
|
1423
|
+
class TestExcavateURL_InvalidPort(TestExcavate):
|
|
1424
|
+
modules_overrides = ["excavate", "httpx", "hunt"]
|
|
1425
|
+
|
|
1426
|
+
async def setup_before_prep(self, module_test):
|
|
1427
|
+
# Test URL with invalid port (greater than 65535)
|
|
1428
|
+
module_test.httpserver.expect_request("/").respond_with_data(
|
|
1429
|
+
'<div><img loading="lazy" src="https://asdffoo.test.notreal:9212952841/whatever.jpg" width="576" height="382" alt="...." /></div>'
|
|
1430
|
+
)
|
|
1431
|
+
|
|
1432
|
+
def check(self, module_test, events):
|
|
1433
|
+
# Verify we got the hostname
|
|
1434
|
+
assert any(e.data == "asdffoo.test.notreal" for e in events)
|
|
@@ -1,137 +0,0 @@
|
|
|
1
|
-
from lxml import etree
|
|
2
|
-
from bbot.modules.base import BaseModule
|
|
3
|
-
|
|
4
|
-
|
|
5
|
-
class dastardly(BaseModule):
|
|
6
|
-
watched_events = ["HTTP_RESPONSE"]
|
|
7
|
-
produced_events = ["FINDING", "VULNERABILITY"]
|
|
8
|
-
flags = ["active", "aggressive", "slow", "web-thorough", "deadly"]
|
|
9
|
-
meta = {
|
|
10
|
-
"description": "Lightweight web application security scanner",
|
|
11
|
-
"created_date": "2023-12-11",
|
|
12
|
-
"author": "@domwhewell-sage",
|
|
13
|
-
}
|
|
14
|
-
|
|
15
|
-
deps_pip = ["lxml~=5.3.0"]
|
|
16
|
-
deps_common = ["docker"]
|
|
17
|
-
per_hostport_only = True
|
|
18
|
-
|
|
19
|
-
default_discovery_context = "{module} performed a light web scan against {event.parent.data['url']} and discovered {event.data['description']} at {event.data['url']}"
|
|
20
|
-
|
|
21
|
-
async def setup(self):
|
|
22
|
-
await self.run_process("systemctl", "start", "docker", sudo=True)
|
|
23
|
-
await self.run_process("docker", "pull", "public.ecr.aws/portswigger/dastardly:latest", sudo=True)
|
|
24
|
-
self.output_dir = self.scan.home / "dastardly"
|
|
25
|
-
self.helpers.mkdir(self.output_dir)
|
|
26
|
-
return True
|
|
27
|
-
|
|
28
|
-
async def filter_event(self, event):
|
|
29
|
-
# Reject redirects. This helps to avoid scanning the same site twice.
|
|
30
|
-
is_redirect = str(event.data["status_code"]).startswith("30")
|
|
31
|
-
if is_redirect:
|
|
32
|
-
return False, "URL is a redirect"
|
|
33
|
-
return True
|
|
34
|
-
|
|
35
|
-
async def handle_event(self, event):
|
|
36
|
-
host = event.parsed_url._replace(path="/").geturl()
|
|
37
|
-
self.verbose(f"Running Dastardly scan against {host}")
|
|
38
|
-
command, output_file = self.construct_command(host)
|
|
39
|
-
finished_proc = await self.run_process(command, sudo=True)
|
|
40
|
-
self.debug(f"dastardly stdout: {getattr(finished_proc, 'stdout', '')}")
|
|
41
|
-
self.debug(f"dastardly stderr: {getattr(finished_proc, 'stderr', '')}")
|
|
42
|
-
for testsuite in self.parse_dastardly_xml(output_file):
|
|
43
|
-
url = testsuite.endpoint
|
|
44
|
-
for testcase in testsuite.testcases:
|
|
45
|
-
for failure in testcase.failures:
|
|
46
|
-
if failure.severity == "Info":
|
|
47
|
-
await self.emit_event(
|
|
48
|
-
{
|
|
49
|
-
"host": str(event.host),
|
|
50
|
-
"url": url,
|
|
51
|
-
"description": failure.instance,
|
|
52
|
-
},
|
|
53
|
-
"FINDING",
|
|
54
|
-
event,
|
|
55
|
-
context=f"{{module}} executed web scan against {host} and identified {{event.type}}: {failure.instance}",
|
|
56
|
-
)
|
|
57
|
-
else:
|
|
58
|
-
await self.emit_event(
|
|
59
|
-
{
|
|
60
|
-
"severity": failure.severity,
|
|
61
|
-
"host": str(event.host),
|
|
62
|
-
"url": url,
|
|
63
|
-
"description": failure.instance,
|
|
64
|
-
},
|
|
65
|
-
"VULNERABILITY",
|
|
66
|
-
event,
|
|
67
|
-
context=f"{{module}} executed web scan against {host} and identified {failure.severity.lower()} {{event.type}}: {failure.instance}",
|
|
68
|
-
)
|
|
69
|
-
|
|
70
|
-
def construct_command(self, target):
|
|
71
|
-
date_time = self.helpers.make_date()
|
|
72
|
-
file_name = self.helpers.tagify(target)
|
|
73
|
-
temp_path = self.output_dir / f"{date_time}_{file_name}.xml"
|
|
74
|
-
command = [
|
|
75
|
-
"docker",
|
|
76
|
-
"run",
|
|
77
|
-
"--user",
|
|
78
|
-
"0",
|
|
79
|
-
"--rm",
|
|
80
|
-
"-v",
|
|
81
|
-
f"{self.output_dir}:/dastardly",
|
|
82
|
-
"-e",
|
|
83
|
-
f"BURP_START_URL={target}",
|
|
84
|
-
"-e",
|
|
85
|
-
f"BURP_REPORT_FILE_PATH=/dastardly/{temp_path.name}",
|
|
86
|
-
"public.ecr.aws/portswigger/dastardly:latest",
|
|
87
|
-
]
|
|
88
|
-
return command, temp_path
|
|
89
|
-
|
|
90
|
-
def parse_dastardly_xml(self, xml_file):
|
|
91
|
-
try:
|
|
92
|
-
with open(xml_file, "rb") as f:
|
|
93
|
-
et = etree.parse(f, parser=etree.XMLParser(recover=True, resolve_entities=False))
|
|
94
|
-
for testsuite in et.iter("testsuite"):
|
|
95
|
-
yield TestSuite(testsuite)
|
|
96
|
-
except FileNotFoundError:
|
|
97
|
-
self.debug(f"Could not find Dastardly XML file at {xml_file}")
|
|
98
|
-
except OSError as e:
|
|
99
|
-
self.verbose(f"Error opening Dastardly XML file at {xml_file}: {e}")
|
|
100
|
-
except etree.ParseError as e:
|
|
101
|
-
self.warning(f"Error parsing Dastardly XML at {xml_file}: {e}")
|
|
102
|
-
|
|
103
|
-
|
|
104
|
-
class Failure:
|
|
105
|
-
def __init__(self, xml):
|
|
106
|
-
self.etree = xml
|
|
107
|
-
|
|
108
|
-
# instance information
|
|
109
|
-
self.instance = self.etree.attrib.get("message", "")
|
|
110
|
-
self.severity = self.etree.attrib.get("type", "")
|
|
111
|
-
self.text = self.etree.text
|
|
112
|
-
|
|
113
|
-
|
|
114
|
-
class TestCase:
|
|
115
|
-
def __init__(self, xml):
|
|
116
|
-
self.etree = xml
|
|
117
|
-
|
|
118
|
-
# title information
|
|
119
|
-
self.title = self.etree.attrib.get("name", "")
|
|
120
|
-
|
|
121
|
-
# findings / failures(as dastardly names them)
|
|
122
|
-
self.failures = []
|
|
123
|
-
for failure in self.etree.findall("failure"):
|
|
124
|
-
self.failures.append(Failure(failure))
|
|
125
|
-
|
|
126
|
-
|
|
127
|
-
class TestSuite:
|
|
128
|
-
def __init__(self, xml):
|
|
129
|
-
self.etree = xml
|
|
130
|
-
|
|
131
|
-
# endpoint information
|
|
132
|
-
self.endpoint = self.etree.attrib.get("name", "")
|
|
133
|
-
|
|
134
|
-
# test cases
|
|
135
|
-
self.testcases = []
|
|
136
|
-
for testcase in self.etree.findall("testcase"):
|
|
137
|
-
self.testcases.append(TestCase(testcase))
|
|
@@ -1,70 +0,0 @@
|
|
|
1
|
-
import json
|
|
2
|
-
from werkzeug import Response
|
|
3
|
-
|
|
4
|
-
from .base import ModuleTestBase
|
|
5
|
-
|
|
6
|
-
|
|
7
|
-
class TestDastardly(ModuleTestBase):
|
|
8
|
-
targets = ["http://127.0.0.1:5556/"]
|
|
9
|
-
modules_overrides = ["httpx", "dastardly"]
|
|
10
|
-
skip_distro_tests = True
|
|
11
|
-
|
|
12
|
-
web_response = """<!DOCTYPE html>
|
|
13
|
-
<html>
|
|
14
|
-
<body>
|
|
15
|
-
<a href="/test?test=yes">visit this<a/>
|
|
16
|
-
</body>
|
|
17
|
-
</html>"""
|
|
18
|
-
|
|
19
|
-
def xss_handler(self, request):
|
|
20
|
-
response = f"""<!DOCTYPE html>
|
|
21
|
-
<html>
|
|
22
|
-
<head>
|
|
23
|
-
<title>Email Form</title>
|
|
24
|
-
</head>
|
|
25
|
-
<body>
|
|
26
|
-
{request.args.get("test", "")}
|
|
27
|
-
</body>
|
|
28
|
-
</html>"""
|
|
29
|
-
return Response(response, content_type="text/html")
|
|
30
|
-
|
|
31
|
-
async def get_docker_ip(self, module_test):
|
|
32
|
-
docker_ip = "172.17.0.1"
|
|
33
|
-
try:
|
|
34
|
-
ip_output = await module_test.scan.helpers.run(["ip", "-j", "-4", "a", "show", "dev", "docker0"])
|
|
35
|
-
interface_json = json.loads(ip_output.stdout)
|
|
36
|
-
docker_ip = interface_json[0]["addr_info"][0]["local"]
|
|
37
|
-
except Exception:
|
|
38
|
-
pass
|
|
39
|
-
return docker_ip
|
|
40
|
-
|
|
41
|
-
async def setup_after_prep(self, module_test):
|
|
42
|
-
httpserver = module_test.request_fixture.getfixturevalue("bbot_httpserver_allinterfaces")
|
|
43
|
-
httpserver.expect_request("/").respond_with_data(self.web_response)
|
|
44
|
-
httpserver.expect_request("/test").respond_with_handler(self.xss_handler)
|
|
45
|
-
|
|
46
|
-
# get docker IP
|
|
47
|
-
docker_ip = await self.get_docker_ip(module_test)
|
|
48
|
-
module_test.scan.target.seeds.add(docker_ip)
|
|
49
|
-
|
|
50
|
-
# replace 127.0.0.1 with docker host IP to allow dastardly access to local http server
|
|
51
|
-
old_filter_event = module_test.module.filter_event
|
|
52
|
-
|
|
53
|
-
def new_filter_event(event):
|
|
54
|
-
self.new_url = f"http://{docker_ip}:5556/"
|
|
55
|
-
event.data["url"] = self.new_url
|
|
56
|
-
event.parsed_url = module_test.scan.helpers.urlparse(self.new_url)
|
|
57
|
-
return old_filter_event(event)
|
|
58
|
-
|
|
59
|
-
module_test.monkeypatch.setattr(module_test.module, "filter_event", new_filter_event)
|
|
60
|
-
|
|
61
|
-
def check(self, module_test, events):
|
|
62
|
-
assert 1 == len(
|
|
63
|
-
[
|
|
64
|
-
e
|
|
65
|
-
for e in events
|
|
66
|
-
if e.type == "VULNERABILITY"
|
|
67
|
-
and f"{self.new_url}test" in e.data["description"]
|
|
68
|
-
and "Cross-site scripting".lower() in e.data["description"].lower()
|
|
69
|
-
]
|
|
70
|
-
)
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|