bbot 2.5.0.6742rc0__tar.gz → 2.5.0.6765rc0__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.

Files changed (457) hide show
  1. {bbot-2.5.0.6742rc0 → bbot-2.5.0.6765rc0}/PKG-INFO +1 -1
  2. {bbot-2.5.0.6742rc0 → bbot-2.5.0.6765rc0}/bbot/__init__.py +1 -1
  3. {bbot-2.5.0.6742rc0 → bbot-2.5.0.6765rc0}/bbot/core/helpers/names_generator.py +2 -0
  4. bbot-2.5.0.6765rc0/bbot/modules/aspnet_bin_exposure.py +80 -0
  5. {bbot-2.5.0.6742rc0 → bbot-2.5.0.6765rc0}/bbot/modules/hunt.py +10 -3
  6. {bbot-2.5.0.6742rc0 → bbot-2.5.0.6765rc0}/bbot/modules/iis_shortnames.py +16 -0
  7. {bbot-2.5.0.6742rc0 → bbot-2.5.0.6765rc0}/bbot/presets/web/dotnet-audit.yml +1 -0
  8. bbot-2.5.0.6765rc0/bbot/test/test_step_2/module_tests/test_module_aspnet_bin_exposure.py +73 -0
  9. {bbot-2.5.0.6742rc0 → bbot-2.5.0.6765rc0}/bbot/test/test_step_2/module_tests/test_module_iis_shortnames.py +46 -1
  10. {bbot-2.5.0.6742rc0 → bbot-2.5.0.6765rc0}/pyproject.toml +1 -1
  11. {bbot-2.5.0.6742rc0 → bbot-2.5.0.6765rc0}/LICENSE +0 -0
  12. {bbot-2.5.0.6742rc0 → bbot-2.5.0.6765rc0}/README.md +0 -0
  13. {bbot-2.5.0.6742rc0 → bbot-2.5.0.6765rc0}/bbot/cli.py +0 -0
  14. {bbot-2.5.0.6742rc0 → bbot-2.5.0.6765rc0}/bbot/core/__init__.py +0 -0
  15. {bbot-2.5.0.6742rc0 → bbot-2.5.0.6765rc0}/bbot/core/config/__init__.py +0 -0
  16. {bbot-2.5.0.6742rc0 → bbot-2.5.0.6765rc0}/bbot/core/config/files.py +0 -0
  17. {bbot-2.5.0.6742rc0 → bbot-2.5.0.6765rc0}/bbot/core/config/logger.py +0 -0
  18. {bbot-2.5.0.6742rc0 → bbot-2.5.0.6765rc0}/bbot/core/core.py +0 -0
  19. {bbot-2.5.0.6742rc0 → bbot-2.5.0.6765rc0}/bbot/core/engine.py +0 -0
  20. {bbot-2.5.0.6742rc0 → bbot-2.5.0.6765rc0}/bbot/core/event/__init__.py +0 -0
  21. {bbot-2.5.0.6742rc0 → bbot-2.5.0.6765rc0}/bbot/core/event/base.py +0 -0
  22. {bbot-2.5.0.6742rc0 → bbot-2.5.0.6765rc0}/bbot/core/event/helpers.py +0 -0
  23. {bbot-2.5.0.6742rc0 → bbot-2.5.0.6765rc0}/bbot/core/flags.py +0 -0
  24. {bbot-2.5.0.6742rc0 → bbot-2.5.0.6765rc0}/bbot/core/helpers/__init__.py +0 -0
  25. {bbot-2.5.0.6742rc0 → bbot-2.5.0.6765rc0}/bbot/core/helpers/async_helpers.py +0 -0
  26. {bbot-2.5.0.6742rc0 → bbot-2.5.0.6765rc0}/bbot/core/helpers/bloom.py +0 -0
  27. {bbot-2.5.0.6742rc0 → bbot-2.5.0.6765rc0}/bbot/core/helpers/cache.py +0 -0
  28. {bbot-2.5.0.6742rc0 → bbot-2.5.0.6765rc0}/bbot/core/helpers/command.py +0 -0
  29. {bbot-2.5.0.6742rc0 → bbot-2.5.0.6765rc0}/bbot/core/helpers/depsinstaller/__init__.py +0 -0
  30. {bbot-2.5.0.6742rc0 → bbot-2.5.0.6765rc0}/bbot/core/helpers/depsinstaller/installer.py +0 -0
  31. {bbot-2.5.0.6742rc0 → bbot-2.5.0.6765rc0}/bbot/core/helpers/depsinstaller/sudo_askpass.py +0 -0
  32. {bbot-2.5.0.6742rc0 → bbot-2.5.0.6765rc0}/bbot/core/helpers/diff.py +0 -0
  33. {bbot-2.5.0.6742rc0 → bbot-2.5.0.6765rc0}/bbot/core/helpers/dns/__init__.py +0 -0
  34. {bbot-2.5.0.6742rc0 → bbot-2.5.0.6765rc0}/bbot/core/helpers/dns/brute.py +0 -0
  35. {bbot-2.5.0.6742rc0 → bbot-2.5.0.6765rc0}/bbot/core/helpers/dns/dns.py +0 -0
  36. {bbot-2.5.0.6742rc0 → bbot-2.5.0.6765rc0}/bbot/core/helpers/dns/engine.py +0 -0
  37. {bbot-2.5.0.6742rc0 → bbot-2.5.0.6765rc0}/bbot/core/helpers/dns/helpers.py +0 -0
  38. {bbot-2.5.0.6742rc0 → bbot-2.5.0.6765rc0}/bbot/core/helpers/dns/mock.py +0 -0
  39. {bbot-2.5.0.6742rc0 → bbot-2.5.0.6765rc0}/bbot/core/helpers/files.py +0 -0
  40. {bbot-2.5.0.6742rc0 → bbot-2.5.0.6765rc0}/bbot/core/helpers/helper.py +0 -0
  41. {bbot-2.5.0.6742rc0 → bbot-2.5.0.6765rc0}/bbot/core/helpers/interactsh.py +0 -0
  42. {bbot-2.5.0.6742rc0 → bbot-2.5.0.6765rc0}/bbot/core/helpers/libmagic.py +0 -0
  43. {bbot-2.5.0.6742rc0 → bbot-2.5.0.6765rc0}/bbot/core/helpers/misc.py +0 -0
  44. {bbot-2.5.0.6742rc0 → bbot-2.5.0.6765rc0}/bbot/core/helpers/ntlm.py +0 -0
  45. {bbot-2.5.0.6742rc0 → bbot-2.5.0.6765rc0}/bbot/core/helpers/process.py +0 -0
  46. {bbot-2.5.0.6742rc0 → bbot-2.5.0.6765rc0}/bbot/core/helpers/ratelimiter.py +0 -0
  47. {bbot-2.5.0.6742rc0 → bbot-2.5.0.6765rc0}/bbot/core/helpers/regex.py +0 -0
  48. {bbot-2.5.0.6742rc0 → bbot-2.5.0.6765rc0}/bbot/core/helpers/regexes.py +0 -0
  49. {bbot-2.5.0.6742rc0 → bbot-2.5.0.6765rc0}/bbot/core/helpers/url.py +0 -0
  50. {bbot-2.5.0.6742rc0 → bbot-2.5.0.6765rc0}/bbot/core/helpers/validators.py +0 -0
  51. {bbot-2.5.0.6742rc0 → bbot-2.5.0.6765rc0}/bbot/core/helpers/web/__init__.py +0 -0
  52. {bbot-2.5.0.6742rc0 → bbot-2.5.0.6765rc0}/bbot/core/helpers/web/client.py +0 -0
  53. {bbot-2.5.0.6742rc0 → bbot-2.5.0.6765rc0}/bbot/core/helpers/web/engine.py +0 -0
  54. {bbot-2.5.0.6742rc0 → bbot-2.5.0.6765rc0}/bbot/core/helpers/web/envelopes.py +0 -0
  55. {bbot-2.5.0.6742rc0 → bbot-2.5.0.6765rc0}/bbot/core/helpers/web/ssl_context.py +0 -0
  56. {bbot-2.5.0.6742rc0 → bbot-2.5.0.6765rc0}/bbot/core/helpers/web/web.py +0 -0
  57. {bbot-2.5.0.6742rc0 → bbot-2.5.0.6765rc0}/bbot/core/helpers/wordcloud.py +0 -0
  58. {bbot-2.5.0.6742rc0 → bbot-2.5.0.6765rc0}/bbot/core/helpers/yara_helper.py +0 -0
  59. {bbot-2.5.0.6742rc0 → bbot-2.5.0.6765rc0}/bbot/core/modules.py +0 -0
  60. {bbot-2.5.0.6742rc0 → bbot-2.5.0.6765rc0}/bbot/core/multiprocess.py +0 -0
  61. {bbot-2.5.0.6742rc0 → bbot-2.5.0.6765rc0}/bbot/core/shared_deps.py +0 -0
  62. {bbot-2.5.0.6742rc0 → bbot-2.5.0.6765rc0}/bbot/db/sql/models.py +0 -0
  63. {bbot-2.5.0.6742rc0 → bbot-2.5.0.6765rc0}/bbot/defaults.yml +0 -0
  64. {bbot-2.5.0.6742rc0 → bbot-2.5.0.6765rc0}/bbot/errors.py +0 -0
  65. {bbot-2.5.0.6742rc0 → bbot-2.5.0.6765rc0}/bbot/logger.py +0 -0
  66. {bbot-2.5.0.6742rc0 → bbot-2.5.0.6765rc0}/bbot/modules/__init__.py +0 -0
  67. {bbot-2.5.0.6742rc0 → bbot-2.5.0.6765rc0}/bbot/modules/ajaxpro.py +0 -0
  68. {bbot-2.5.0.6742rc0 → bbot-2.5.0.6765rc0}/bbot/modules/anubisdb.py +0 -0
  69. {bbot-2.5.0.6742rc0 → bbot-2.5.0.6765rc0}/bbot/modules/apkpure.py +0 -0
  70. {bbot-2.5.0.6742rc0 → bbot-2.5.0.6765rc0}/bbot/modules/azure_realm.py +0 -0
  71. {bbot-2.5.0.6742rc0 → bbot-2.5.0.6765rc0}/bbot/modules/azure_tenant.py +0 -0
  72. {bbot-2.5.0.6742rc0 → bbot-2.5.0.6765rc0}/bbot/modules/baddns.py +0 -0
  73. {bbot-2.5.0.6742rc0 → bbot-2.5.0.6765rc0}/bbot/modules/baddns_direct.py +0 -0
  74. {bbot-2.5.0.6742rc0 → bbot-2.5.0.6765rc0}/bbot/modules/baddns_zone.py +0 -0
  75. {bbot-2.5.0.6742rc0 → bbot-2.5.0.6765rc0}/bbot/modules/badsecrets.py +0 -0
  76. {bbot-2.5.0.6742rc0 → bbot-2.5.0.6765rc0}/bbot/modules/base.py +0 -0
  77. {bbot-2.5.0.6742rc0 → bbot-2.5.0.6765rc0}/bbot/modules/bevigil.py +0 -0
  78. {bbot-2.5.0.6742rc0 → bbot-2.5.0.6765rc0}/bbot/modules/bucket_amazon.py +0 -0
  79. {bbot-2.5.0.6742rc0 → bbot-2.5.0.6765rc0}/bbot/modules/bucket_azure.py +0 -0
  80. {bbot-2.5.0.6742rc0 → bbot-2.5.0.6765rc0}/bbot/modules/bucket_digitalocean.py +0 -0
  81. {bbot-2.5.0.6742rc0 → bbot-2.5.0.6765rc0}/bbot/modules/bucket_file_enum.py +0 -0
  82. {bbot-2.5.0.6742rc0 → bbot-2.5.0.6765rc0}/bbot/modules/bucket_firebase.py +0 -0
  83. {bbot-2.5.0.6742rc0 → bbot-2.5.0.6765rc0}/bbot/modules/bucket_google.py +0 -0
  84. {bbot-2.5.0.6742rc0 → bbot-2.5.0.6765rc0}/bbot/modules/bufferoverrun.py +0 -0
  85. {bbot-2.5.0.6742rc0 → bbot-2.5.0.6765rc0}/bbot/modules/builtwith.py +0 -0
  86. {bbot-2.5.0.6742rc0 → bbot-2.5.0.6765rc0}/bbot/modules/bypass403.py +0 -0
  87. {bbot-2.5.0.6742rc0 → bbot-2.5.0.6765rc0}/bbot/modules/c99.py +0 -0
  88. {bbot-2.5.0.6742rc0 → bbot-2.5.0.6765rc0}/bbot/modules/censys.py +0 -0
  89. {bbot-2.5.0.6742rc0 → bbot-2.5.0.6765rc0}/bbot/modules/certspotter.py +0 -0
  90. {bbot-2.5.0.6742rc0 → bbot-2.5.0.6765rc0}/bbot/modules/chaos.py +0 -0
  91. {bbot-2.5.0.6742rc0 → bbot-2.5.0.6765rc0}/bbot/modules/code_repository.py +0 -0
  92. {bbot-2.5.0.6742rc0 → bbot-2.5.0.6765rc0}/bbot/modules/credshed.py +0 -0
  93. {bbot-2.5.0.6742rc0 → bbot-2.5.0.6765rc0}/bbot/modules/crt.py +0 -0
  94. {bbot-2.5.0.6742rc0 → bbot-2.5.0.6765rc0}/bbot/modules/crt_db.py +0 -0
  95. {bbot-2.5.0.6742rc0 → bbot-2.5.0.6765rc0}/bbot/modules/deadly/medusa.py +0 -0
  96. {bbot-2.5.0.6742rc0 → bbot-2.5.0.6765rc0}/bbot/modules/dehashed.py +0 -0
  97. {bbot-2.5.0.6742rc0 → bbot-2.5.0.6765rc0}/bbot/modules/digitorus.py +0 -0
  98. {bbot-2.5.0.6742rc0 → bbot-2.5.0.6765rc0}/bbot/modules/dnsbimi.py +0 -0
  99. {bbot-2.5.0.6742rc0 → bbot-2.5.0.6765rc0}/bbot/modules/dnsbrute.py +0 -0
  100. {bbot-2.5.0.6742rc0 → bbot-2.5.0.6765rc0}/bbot/modules/dnsbrute_mutations.py +0 -0
  101. {bbot-2.5.0.6742rc0 → bbot-2.5.0.6765rc0}/bbot/modules/dnscaa.py +0 -0
  102. {bbot-2.5.0.6742rc0 → bbot-2.5.0.6765rc0}/bbot/modules/dnscommonsrv.py +0 -0
  103. {bbot-2.5.0.6742rc0 → bbot-2.5.0.6765rc0}/bbot/modules/dnsdumpster.py +0 -0
  104. {bbot-2.5.0.6742rc0 → bbot-2.5.0.6765rc0}/bbot/modules/dnstlsrpt.py +0 -0
  105. {bbot-2.5.0.6742rc0 → bbot-2.5.0.6765rc0}/bbot/modules/docker_pull.py +0 -0
  106. {bbot-2.5.0.6742rc0 → bbot-2.5.0.6765rc0}/bbot/modules/dockerhub.py +0 -0
  107. {bbot-2.5.0.6742rc0 → bbot-2.5.0.6765rc0}/bbot/modules/dotnetnuke.py +0 -0
  108. {bbot-2.5.0.6742rc0 → bbot-2.5.0.6765rc0}/bbot/modules/emailformat.py +0 -0
  109. {bbot-2.5.0.6742rc0 → bbot-2.5.0.6765rc0}/bbot/modules/extractous.py +0 -0
  110. {bbot-2.5.0.6742rc0 → bbot-2.5.0.6765rc0}/bbot/modules/ffuf.py +0 -0
  111. {bbot-2.5.0.6742rc0 → bbot-2.5.0.6765rc0}/bbot/modules/ffuf_shortnames.py +0 -0
  112. {bbot-2.5.0.6742rc0 → bbot-2.5.0.6765rc0}/bbot/modules/filedownload.py +0 -0
  113. {bbot-2.5.0.6742rc0 → bbot-2.5.0.6765rc0}/bbot/modules/fingerprintx.py +0 -0
  114. {bbot-2.5.0.6742rc0 → bbot-2.5.0.6765rc0}/bbot/modules/fullhunt.py +0 -0
  115. {bbot-2.5.0.6742rc0 → bbot-2.5.0.6765rc0}/bbot/modules/generic_ssrf.py +0 -0
  116. {bbot-2.5.0.6742rc0 → bbot-2.5.0.6765rc0}/bbot/modules/git.py +0 -0
  117. {bbot-2.5.0.6742rc0 → bbot-2.5.0.6765rc0}/bbot/modules/git_clone.py +0 -0
  118. {bbot-2.5.0.6742rc0 → bbot-2.5.0.6765rc0}/bbot/modules/gitdumper.py +0 -0
  119. {bbot-2.5.0.6742rc0 → bbot-2.5.0.6765rc0}/bbot/modules/github_codesearch.py +0 -0
  120. {bbot-2.5.0.6742rc0 → bbot-2.5.0.6765rc0}/bbot/modules/github_org.py +0 -0
  121. {bbot-2.5.0.6742rc0 → bbot-2.5.0.6765rc0}/bbot/modules/github_usersearch.py +0 -0
  122. {bbot-2.5.0.6742rc0 → bbot-2.5.0.6765rc0}/bbot/modules/github_workflows.py +0 -0
  123. {bbot-2.5.0.6742rc0 → bbot-2.5.0.6765rc0}/bbot/modules/gitlab.py +0 -0
  124. {bbot-2.5.0.6742rc0 → bbot-2.5.0.6765rc0}/bbot/modules/google_playstore.py +0 -0
  125. {bbot-2.5.0.6742rc0 → bbot-2.5.0.6765rc0}/bbot/modules/gowitness.py +0 -0
  126. {bbot-2.5.0.6742rc0 → bbot-2.5.0.6765rc0}/bbot/modules/hackertarget.py +0 -0
  127. {bbot-2.5.0.6742rc0 → bbot-2.5.0.6765rc0}/bbot/modules/host_header.py +0 -0
  128. {bbot-2.5.0.6742rc0 → bbot-2.5.0.6765rc0}/bbot/modules/httpx.py +0 -0
  129. {bbot-2.5.0.6742rc0 → bbot-2.5.0.6765rc0}/bbot/modules/hunterio.py +0 -0
  130. {bbot-2.5.0.6742rc0 → bbot-2.5.0.6765rc0}/bbot/modules/internal/__init__.py +0 -0
  131. {bbot-2.5.0.6742rc0 → bbot-2.5.0.6765rc0}/bbot/modules/internal/aggregate.py +0 -0
  132. {bbot-2.5.0.6742rc0 → bbot-2.5.0.6765rc0}/bbot/modules/internal/base.py +0 -0
  133. {bbot-2.5.0.6742rc0 → bbot-2.5.0.6765rc0}/bbot/modules/internal/cloudcheck.py +0 -0
  134. {bbot-2.5.0.6742rc0 → bbot-2.5.0.6765rc0}/bbot/modules/internal/dnsresolve.py +0 -0
  135. {bbot-2.5.0.6742rc0 → bbot-2.5.0.6765rc0}/bbot/modules/internal/excavate.py +0 -0
  136. {bbot-2.5.0.6742rc0 → bbot-2.5.0.6765rc0}/bbot/modules/internal/speculate.py +0 -0
  137. {bbot-2.5.0.6742rc0 → bbot-2.5.0.6765rc0}/bbot/modules/internal/unarchive.py +0 -0
  138. {bbot-2.5.0.6742rc0 → bbot-2.5.0.6765rc0}/bbot/modules/ip2location.py +0 -0
  139. {bbot-2.5.0.6742rc0 → bbot-2.5.0.6765rc0}/bbot/modules/ipneighbor.py +0 -0
  140. {bbot-2.5.0.6742rc0 → bbot-2.5.0.6765rc0}/bbot/modules/ipstack.py +0 -0
  141. {bbot-2.5.0.6742rc0 → bbot-2.5.0.6765rc0}/bbot/modules/jadx.py +0 -0
  142. {bbot-2.5.0.6742rc0 → bbot-2.5.0.6765rc0}/bbot/modules/leakix.py +0 -0
  143. {bbot-2.5.0.6742rc0 → bbot-2.5.0.6765rc0}/bbot/modules/lightfuzz/lightfuzz.py +0 -0
  144. {bbot-2.5.0.6742rc0 → bbot-2.5.0.6765rc0}/bbot/modules/lightfuzz/submodules/__init__.py +0 -0
  145. {bbot-2.5.0.6742rc0 → bbot-2.5.0.6765rc0}/bbot/modules/lightfuzz/submodules/base.py +0 -0
  146. {bbot-2.5.0.6742rc0 → bbot-2.5.0.6765rc0}/bbot/modules/lightfuzz/submodules/cmdi.py +0 -0
  147. {bbot-2.5.0.6742rc0 → bbot-2.5.0.6765rc0}/bbot/modules/lightfuzz/submodules/crypto.py +0 -0
  148. {bbot-2.5.0.6742rc0 → bbot-2.5.0.6765rc0}/bbot/modules/lightfuzz/submodules/path.py +0 -0
  149. {bbot-2.5.0.6742rc0 → bbot-2.5.0.6765rc0}/bbot/modules/lightfuzz/submodules/serial.py +0 -0
  150. {bbot-2.5.0.6742rc0 → bbot-2.5.0.6765rc0}/bbot/modules/lightfuzz/submodules/sqli.py +0 -0
  151. {bbot-2.5.0.6742rc0 → bbot-2.5.0.6765rc0}/bbot/modules/lightfuzz/submodules/ssti.py +0 -0
  152. {bbot-2.5.0.6742rc0 → bbot-2.5.0.6765rc0}/bbot/modules/lightfuzz/submodules/xss.py +0 -0
  153. {bbot-2.5.0.6742rc0 → bbot-2.5.0.6765rc0}/bbot/modules/myssl.py +0 -0
  154. {bbot-2.5.0.6742rc0 → bbot-2.5.0.6765rc0}/bbot/modules/newsletters.py +0 -0
  155. {bbot-2.5.0.6742rc0 → bbot-2.5.0.6765rc0}/bbot/modules/ntlm.py +0 -0
  156. {bbot-2.5.0.6742rc0 → bbot-2.5.0.6765rc0}/bbot/modules/nuclei.py +0 -0
  157. {bbot-2.5.0.6742rc0 → bbot-2.5.0.6765rc0}/bbot/modules/oauth.py +0 -0
  158. {bbot-2.5.0.6742rc0 → bbot-2.5.0.6765rc0}/bbot/modules/otx.py +0 -0
  159. {bbot-2.5.0.6742rc0 → bbot-2.5.0.6765rc0}/bbot/modules/output/__init__.py +0 -0
  160. {bbot-2.5.0.6742rc0 → bbot-2.5.0.6765rc0}/bbot/modules/output/asset_inventory.py +0 -0
  161. {bbot-2.5.0.6742rc0 → bbot-2.5.0.6765rc0}/bbot/modules/output/base.py +0 -0
  162. {bbot-2.5.0.6742rc0 → bbot-2.5.0.6765rc0}/bbot/modules/output/csv.py +0 -0
  163. {bbot-2.5.0.6742rc0 → bbot-2.5.0.6765rc0}/bbot/modules/output/discord.py +0 -0
  164. {bbot-2.5.0.6742rc0 → bbot-2.5.0.6765rc0}/bbot/modules/output/emails.py +0 -0
  165. {bbot-2.5.0.6742rc0 → bbot-2.5.0.6765rc0}/bbot/modules/output/http.py +0 -0
  166. {bbot-2.5.0.6742rc0 → bbot-2.5.0.6765rc0}/bbot/modules/output/json.py +0 -0
  167. {bbot-2.5.0.6742rc0 → bbot-2.5.0.6765rc0}/bbot/modules/output/mysql.py +0 -0
  168. {bbot-2.5.0.6742rc0 → bbot-2.5.0.6765rc0}/bbot/modules/output/neo4j.py +0 -0
  169. {bbot-2.5.0.6742rc0 → bbot-2.5.0.6765rc0}/bbot/modules/output/nmap_xml.py +0 -0
  170. {bbot-2.5.0.6742rc0 → bbot-2.5.0.6765rc0}/bbot/modules/output/postgres.py +0 -0
  171. {bbot-2.5.0.6742rc0 → bbot-2.5.0.6765rc0}/bbot/modules/output/python.py +0 -0
  172. {bbot-2.5.0.6742rc0 → bbot-2.5.0.6765rc0}/bbot/modules/output/slack.py +0 -0
  173. {bbot-2.5.0.6742rc0 → bbot-2.5.0.6765rc0}/bbot/modules/output/splunk.py +0 -0
  174. {bbot-2.5.0.6742rc0 → bbot-2.5.0.6765rc0}/bbot/modules/output/sqlite.py +0 -0
  175. {bbot-2.5.0.6742rc0 → bbot-2.5.0.6765rc0}/bbot/modules/output/stdout.py +0 -0
  176. {bbot-2.5.0.6742rc0 → bbot-2.5.0.6765rc0}/bbot/modules/output/subdomains.py +0 -0
  177. {bbot-2.5.0.6742rc0 → bbot-2.5.0.6765rc0}/bbot/modules/output/teams.py +0 -0
  178. {bbot-2.5.0.6742rc0 → bbot-2.5.0.6765rc0}/bbot/modules/output/txt.py +0 -0
  179. {bbot-2.5.0.6742rc0 → bbot-2.5.0.6765rc0}/bbot/modules/output/web_parameters.py +0 -0
  180. {bbot-2.5.0.6742rc0 → bbot-2.5.0.6765rc0}/bbot/modules/output/web_report.py +0 -0
  181. {bbot-2.5.0.6742rc0 → bbot-2.5.0.6765rc0}/bbot/modules/output/websocket.py +0 -0
  182. {bbot-2.5.0.6742rc0 → bbot-2.5.0.6765rc0}/bbot/modules/paramminer_cookies.py +0 -0
  183. {bbot-2.5.0.6742rc0 → bbot-2.5.0.6765rc0}/bbot/modules/paramminer_getparams.py +0 -0
  184. {bbot-2.5.0.6742rc0 → bbot-2.5.0.6765rc0}/bbot/modules/paramminer_headers.py +0 -0
  185. {bbot-2.5.0.6742rc0 → bbot-2.5.0.6765rc0}/bbot/modules/passivetotal.py +0 -0
  186. {bbot-2.5.0.6742rc0 → bbot-2.5.0.6765rc0}/bbot/modules/pgp.py +0 -0
  187. {bbot-2.5.0.6742rc0 → bbot-2.5.0.6765rc0}/bbot/modules/portfilter.py +0 -0
  188. {bbot-2.5.0.6742rc0 → bbot-2.5.0.6765rc0}/bbot/modules/portscan.py +0 -0
  189. {bbot-2.5.0.6742rc0 → bbot-2.5.0.6765rc0}/bbot/modules/postman.py +0 -0
  190. {bbot-2.5.0.6742rc0 → bbot-2.5.0.6765rc0}/bbot/modules/postman_download.py +0 -0
  191. {bbot-2.5.0.6742rc0 → bbot-2.5.0.6765rc0}/bbot/modules/rapiddns.py +0 -0
  192. {bbot-2.5.0.6742rc0 → bbot-2.5.0.6765rc0}/bbot/modules/reflected_parameters.py +0 -0
  193. {bbot-2.5.0.6742rc0 → bbot-2.5.0.6765rc0}/bbot/modules/report/affiliates.py +0 -0
  194. {bbot-2.5.0.6742rc0 → bbot-2.5.0.6765rc0}/bbot/modules/report/asn.py +0 -0
  195. {bbot-2.5.0.6742rc0 → bbot-2.5.0.6765rc0}/bbot/modules/report/base.py +0 -0
  196. {bbot-2.5.0.6742rc0 → bbot-2.5.0.6765rc0}/bbot/modules/robots.py +0 -0
  197. {bbot-2.5.0.6742rc0 → bbot-2.5.0.6765rc0}/bbot/modules/securitytrails.py +0 -0
  198. {bbot-2.5.0.6742rc0 → bbot-2.5.0.6765rc0}/bbot/modules/securitytxt.py +0 -0
  199. {bbot-2.5.0.6742rc0 → bbot-2.5.0.6765rc0}/bbot/modules/shodan_dns.py +0 -0
  200. {bbot-2.5.0.6742rc0 → bbot-2.5.0.6765rc0}/bbot/modules/shodan_idb.py +0 -0
  201. {bbot-2.5.0.6742rc0 → bbot-2.5.0.6765rc0}/bbot/modules/sitedossier.py +0 -0
  202. {bbot-2.5.0.6742rc0 → bbot-2.5.0.6765rc0}/bbot/modules/skymem.py +0 -0
  203. {bbot-2.5.0.6742rc0 → bbot-2.5.0.6765rc0}/bbot/modules/smuggler.py +0 -0
  204. {bbot-2.5.0.6742rc0 → bbot-2.5.0.6765rc0}/bbot/modules/social.py +0 -0
  205. {bbot-2.5.0.6742rc0 → bbot-2.5.0.6765rc0}/bbot/modules/sslcert.py +0 -0
  206. {bbot-2.5.0.6742rc0 → bbot-2.5.0.6765rc0}/bbot/modules/subdomaincenter.py +0 -0
  207. {bbot-2.5.0.6742rc0 → bbot-2.5.0.6765rc0}/bbot/modules/subdomainradar.py +0 -0
  208. {bbot-2.5.0.6742rc0 → bbot-2.5.0.6765rc0}/bbot/modules/telerik.py +0 -0
  209. {bbot-2.5.0.6742rc0 → bbot-2.5.0.6765rc0}/bbot/modules/templates/bucket.py +0 -0
  210. {bbot-2.5.0.6742rc0 → bbot-2.5.0.6765rc0}/bbot/modules/templates/github.py +0 -0
  211. {bbot-2.5.0.6742rc0 → bbot-2.5.0.6765rc0}/bbot/modules/templates/postman.py +0 -0
  212. {bbot-2.5.0.6742rc0 → bbot-2.5.0.6765rc0}/bbot/modules/templates/shodan.py +0 -0
  213. {bbot-2.5.0.6742rc0 → bbot-2.5.0.6765rc0}/bbot/modules/templates/sql.py +0 -0
  214. {bbot-2.5.0.6742rc0 → bbot-2.5.0.6765rc0}/bbot/modules/templates/subdomain_enum.py +0 -0
  215. {bbot-2.5.0.6742rc0 → bbot-2.5.0.6765rc0}/bbot/modules/templates/webhook.py +0 -0
  216. {bbot-2.5.0.6742rc0 → bbot-2.5.0.6765rc0}/bbot/modules/trickest.py +0 -0
  217. {bbot-2.5.0.6742rc0 → bbot-2.5.0.6765rc0}/bbot/modules/trufflehog.py +0 -0
  218. {bbot-2.5.0.6742rc0 → bbot-2.5.0.6765rc0}/bbot/modules/url_manipulation.py +0 -0
  219. {bbot-2.5.0.6742rc0 → bbot-2.5.0.6765rc0}/bbot/modules/urlscan.py +0 -0
  220. {bbot-2.5.0.6742rc0 → bbot-2.5.0.6765rc0}/bbot/modules/vhost.py +0 -0
  221. {bbot-2.5.0.6742rc0 → bbot-2.5.0.6765rc0}/bbot/modules/viewdns.py +0 -0
  222. {bbot-2.5.0.6742rc0 → bbot-2.5.0.6765rc0}/bbot/modules/virustotal.py +0 -0
  223. {bbot-2.5.0.6742rc0 → bbot-2.5.0.6765rc0}/bbot/modules/wafw00f.py +0 -0
  224. {bbot-2.5.0.6742rc0 → bbot-2.5.0.6765rc0}/bbot/modules/wappalyzer.py +0 -0
  225. {bbot-2.5.0.6742rc0 → bbot-2.5.0.6765rc0}/bbot/modules/wayback.py +0 -0
  226. {bbot-2.5.0.6742rc0 → bbot-2.5.0.6765rc0}/bbot/modules/wpscan.py +0 -0
  227. {bbot-2.5.0.6742rc0 → bbot-2.5.0.6765rc0}/bbot/modules/zoomeye.py +0 -0
  228. {bbot-2.5.0.6742rc0 → bbot-2.5.0.6765rc0}/bbot/presets/baddns-intense.yml +0 -0
  229. {bbot-2.5.0.6742rc0 → bbot-2.5.0.6765rc0}/bbot/presets/cloud-enum.yml +0 -0
  230. {bbot-2.5.0.6742rc0 → bbot-2.5.0.6765rc0}/bbot/presets/code-enum.yml +0 -0
  231. {bbot-2.5.0.6742rc0 → bbot-2.5.0.6765rc0}/bbot/presets/email-enum.yml +0 -0
  232. {bbot-2.5.0.6742rc0 → bbot-2.5.0.6765rc0}/bbot/presets/fast.yml +0 -0
  233. {bbot-2.5.0.6742rc0 → bbot-2.5.0.6765rc0}/bbot/presets/kitchen-sink.yml +0 -0
  234. {bbot-2.5.0.6742rc0 → bbot-2.5.0.6765rc0}/bbot/presets/nuclei/nuclei-budget.yml +0 -0
  235. {bbot-2.5.0.6742rc0 → bbot-2.5.0.6765rc0}/bbot/presets/nuclei/nuclei-intense.yml +0 -0
  236. {bbot-2.5.0.6742rc0 → bbot-2.5.0.6765rc0}/bbot/presets/nuclei/nuclei-technology.yml +0 -0
  237. {bbot-2.5.0.6742rc0 → bbot-2.5.0.6765rc0}/bbot/presets/nuclei/nuclei.yml +0 -0
  238. {bbot-2.5.0.6742rc0 → bbot-2.5.0.6765rc0}/bbot/presets/spider-intense.yml +0 -0
  239. {bbot-2.5.0.6742rc0 → bbot-2.5.0.6765rc0}/bbot/presets/spider.yml +0 -0
  240. {bbot-2.5.0.6742rc0 → bbot-2.5.0.6765rc0}/bbot/presets/subdomain-enum.yml +0 -0
  241. {bbot-2.5.0.6742rc0 → bbot-2.5.0.6765rc0}/bbot/presets/tech-detect.yml +0 -0
  242. {bbot-2.5.0.6742rc0 → bbot-2.5.0.6765rc0}/bbot/presets/web/dirbust-heavy.yml +0 -0
  243. {bbot-2.5.0.6742rc0 → bbot-2.5.0.6765rc0}/bbot/presets/web/dirbust-light.yml +0 -0
  244. {bbot-2.5.0.6742rc0 → bbot-2.5.0.6765rc0}/bbot/presets/web/iis-shortnames.yml +0 -0
  245. {bbot-2.5.0.6742rc0 → bbot-2.5.0.6765rc0}/bbot/presets/web/lightfuzz-heavy.yml +0 -0
  246. {bbot-2.5.0.6742rc0 → bbot-2.5.0.6765rc0}/bbot/presets/web/lightfuzz-light.yml +0 -0
  247. {bbot-2.5.0.6742rc0 → bbot-2.5.0.6765rc0}/bbot/presets/web/lightfuzz-medium.yml +0 -0
  248. {bbot-2.5.0.6742rc0 → bbot-2.5.0.6765rc0}/bbot/presets/web/lightfuzz-superheavy.yml +0 -0
  249. {bbot-2.5.0.6742rc0 → bbot-2.5.0.6765rc0}/bbot/presets/web/lightfuzz-xss.yml +0 -0
  250. {bbot-2.5.0.6742rc0 → bbot-2.5.0.6765rc0}/bbot/presets/web/paramminer.yml +0 -0
  251. {bbot-2.5.0.6742rc0 → bbot-2.5.0.6765rc0}/bbot/presets/web-basic.yml +0 -0
  252. {bbot-2.5.0.6742rc0 → bbot-2.5.0.6765rc0}/bbot/presets/web-screenshots.yml +0 -0
  253. {bbot-2.5.0.6742rc0 → bbot-2.5.0.6765rc0}/bbot/presets/web-thorough.yml +0 -0
  254. {bbot-2.5.0.6742rc0 → bbot-2.5.0.6765rc0}/bbot/scanner/__init__.py +0 -0
  255. {bbot-2.5.0.6742rc0 → bbot-2.5.0.6765rc0}/bbot/scanner/dispatcher.py +0 -0
  256. {bbot-2.5.0.6742rc0 → bbot-2.5.0.6765rc0}/bbot/scanner/manager.py +0 -0
  257. {bbot-2.5.0.6742rc0 → bbot-2.5.0.6765rc0}/bbot/scanner/preset/__init__.py +0 -0
  258. {bbot-2.5.0.6742rc0 → bbot-2.5.0.6765rc0}/bbot/scanner/preset/args.py +0 -0
  259. {bbot-2.5.0.6742rc0 → bbot-2.5.0.6765rc0}/bbot/scanner/preset/conditions.py +0 -0
  260. {bbot-2.5.0.6742rc0 → bbot-2.5.0.6765rc0}/bbot/scanner/preset/environ.py +0 -0
  261. {bbot-2.5.0.6742rc0 → bbot-2.5.0.6765rc0}/bbot/scanner/preset/path.py +0 -0
  262. {bbot-2.5.0.6742rc0 → bbot-2.5.0.6765rc0}/bbot/scanner/preset/preset.py +0 -0
  263. {bbot-2.5.0.6742rc0 → bbot-2.5.0.6765rc0}/bbot/scanner/scanner.py +0 -0
  264. {bbot-2.5.0.6742rc0 → bbot-2.5.0.6765rc0}/bbot/scanner/stats.py +0 -0
  265. {bbot-2.5.0.6742rc0 → bbot-2.5.0.6765rc0}/bbot/scanner/target.py +0 -0
  266. {bbot-2.5.0.6742rc0 → bbot-2.5.0.6765rc0}/bbot/scripts/docs.py +0 -0
  267. {bbot-2.5.0.6742rc0 → bbot-2.5.0.6765rc0}/bbot/test/__init__.py +0 -0
  268. {bbot-2.5.0.6742rc0 → bbot-2.5.0.6765rc0}/bbot/test/bbot_fixtures.py +0 -0
  269. {bbot-2.5.0.6742rc0 → bbot-2.5.0.6765rc0}/bbot/test/conftest.py +0 -0
  270. {bbot-2.5.0.6742rc0 → bbot-2.5.0.6765rc0}/bbot/test/coverage.cfg +0 -0
  271. {bbot-2.5.0.6742rc0 → bbot-2.5.0.6765rc0}/bbot/test/fastapi_test.py +0 -0
  272. {bbot-2.5.0.6742rc0 → bbot-2.5.0.6765rc0}/bbot/test/owasp_mastg.apk +0 -0
  273. {bbot-2.5.0.6742rc0 → bbot-2.5.0.6765rc0}/bbot/test/run_tests.sh +0 -0
  274. {bbot-2.5.0.6742rc0 → bbot-2.5.0.6765rc0}/bbot/test/test.conf +0 -0
  275. {bbot-2.5.0.6742rc0 → bbot-2.5.0.6765rc0}/bbot/test/test_output.ndjson +0 -0
  276. {bbot-2.5.0.6742rc0 → bbot-2.5.0.6765rc0}/bbot/test/test_step_1/__init__.py +0 -0
  277. {bbot-2.5.0.6742rc0 → bbot-2.5.0.6765rc0}/bbot/test/test_step_1/test__module__tests.py +0 -0
  278. {bbot-2.5.0.6742rc0 → bbot-2.5.0.6765rc0}/bbot/test/test_step_1/test_bbot_fastapi.py +0 -0
  279. {bbot-2.5.0.6742rc0 → bbot-2.5.0.6765rc0}/bbot/test/test_step_1/test_bloom_filter.py +0 -0
  280. {bbot-2.5.0.6742rc0 → bbot-2.5.0.6765rc0}/bbot/test/test_step_1/test_cli.py +0 -0
  281. {bbot-2.5.0.6742rc0 → bbot-2.5.0.6765rc0}/bbot/test/test_step_1/test_command.py +0 -0
  282. {bbot-2.5.0.6742rc0 → bbot-2.5.0.6765rc0}/bbot/test/test_step_1/test_config.py +0 -0
  283. {bbot-2.5.0.6742rc0 → bbot-2.5.0.6765rc0}/bbot/test/test_step_1/test_depsinstaller.py +0 -0
  284. {bbot-2.5.0.6742rc0 → bbot-2.5.0.6765rc0}/bbot/test/test_step_1/test_dns.py +0 -0
  285. {bbot-2.5.0.6742rc0 → bbot-2.5.0.6765rc0}/bbot/test/test_step_1/test_docs.py +0 -0
  286. {bbot-2.5.0.6742rc0 → bbot-2.5.0.6765rc0}/bbot/test/test_step_1/test_engine.py +0 -0
  287. {bbot-2.5.0.6742rc0 → bbot-2.5.0.6765rc0}/bbot/test/test_step_1/test_event_seeds.py +0 -0
  288. {bbot-2.5.0.6742rc0 → bbot-2.5.0.6765rc0}/bbot/test/test_step_1/test_events.py +0 -0
  289. {bbot-2.5.0.6742rc0 → bbot-2.5.0.6765rc0}/bbot/test/test_step_1/test_files.py +0 -0
  290. {bbot-2.5.0.6742rc0 → bbot-2.5.0.6765rc0}/bbot/test/test_step_1/test_helpers.py +0 -0
  291. {bbot-2.5.0.6742rc0 → bbot-2.5.0.6765rc0}/bbot/test/test_step_1/test_manager_deduplication.py +0 -0
  292. {bbot-2.5.0.6742rc0 → bbot-2.5.0.6765rc0}/bbot/test/test_step_1/test_manager_scope_accuracy.py +0 -0
  293. {bbot-2.5.0.6742rc0 → bbot-2.5.0.6765rc0}/bbot/test/test_step_1/test_modules_basic.py +0 -0
  294. {bbot-2.5.0.6742rc0 → bbot-2.5.0.6765rc0}/bbot/test/test_step_1/test_presets.py +0 -0
  295. {bbot-2.5.0.6742rc0 → bbot-2.5.0.6765rc0}/bbot/test/test_step_1/test_python_api.py +0 -0
  296. {bbot-2.5.0.6742rc0 → bbot-2.5.0.6765rc0}/bbot/test/test_step_1/test_regexes.py +0 -0
  297. {bbot-2.5.0.6742rc0 → bbot-2.5.0.6765rc0}/bbot/test/test_step_1/test_scan.py +0 -0
  298. {bbot-2.5.0.6742rc0 → bbot-2.5.0.6765rc0}/bbot/test/test_step_1/test_scope.py +0 -0
  299. {bbot-2.5.0.6742rc0 → bbot-2.5.0.6765rc0}/bbot/test/test_step_1/test_target.py +0 -0
  300. {bbot-2.5.0.6742rc0 → bbot-2.5.0.6765rc0}/bbot/test/test_step_1/test_web.py +0 -0
  301. {bbot-2.5.0.6742rc0 → bbot-2.5.0.6765rc0}/bbot/test/test_step_1/test_web_envelopes.py +0 -0
  302. {bbot-2.5.0.6742rc0 → bbot-2.5.0.6765rc0}/bbot/test/test_step_2/__init__.py +0 -0
  303. {bbot-2.5.0.6742rc0 → bbot-2.5.0.6765rc0}/bbot/test/test_step_2/module_tests/__init__.py +0 -0
  304. {bbot-2.5.0.6742rc0 → bbot-2.5.0.6765rc0}/bbot/test/test_step_2/module_tests/base.py +0 -0
  305. {bbot-2.5.0.6742rc0 → bbot-2.5.0.6765rc0}/bbot/test/test_step_2/module_tests/test_module_affiliates.py +0 -0
  306. {bbot-2.5.0.6742rc0 → bbot-2.5.0.6765rc0}/bbot/test/test_step_2/module_tests/test_module_aggregate.py +0 -0
  307. {bbot-2.5.0.6742rc0 → bbot-2.5.0.6765rc0}/bbot/test/test_step_2/module_tests/test_module_ajaxpro.py +0 -0
  308. {bbot-2.5.0.6742rc0 → bbot-2.5.0.6765rc0}/bbot/test/test_step_2/module_tests/test_module_anubisdb.py +0 -0
  309. {bbot-2.5.0.6742rc0 → bbot-2.5.0.6765rc0}/bbot/test/test_step_2/module_tests/test_module_apkpure.py +0 -0
  310. {bbot-2.5.0.6742rc0 → bbot-2.5.0.6765rc0}/bbot/test/test_step_2/module_tests/test_module_asn.py +0 -0
  311. {bbot-2.5.0.6742rc0 → bbot-2.5.0.6765rc0}/bbot/test/test_step_2/module_tests/test_module_asset_inventory.py +0 -0
  312. {bbot-2.5.0.6742rc0 → bbot-2.5.0.6765rc0}/bbot/test/test_step_2/module_tests/test_module_azure_realm.py +0 -0
  313. {bbot-2.5.0.6742rc0 → bbot-2.5.0.6765rc0}/bbot/test/test_step_2/module_tests/test_module_azure_tenant.py +0 -0
  314. {bbot-2.5.0.6742rc0 → bbot-2.5.0.6765rc0}/bbot/test/test_step_2/module_tests/test_module_baddns.py +0 -0
  315. {bbot-2.5.0.6742rc0 → bbot-2.5.0.6765rc0}/bbot/test/test_step_2/module_tests/test_module_baddns_direct.py +0 -0
  316. {bbot-2.5.0.6742rc0 → bbot-2.5.0.6765rc0}/bbot/test/test_step_2/module_tests/test_module_baddns_zone.py +0 -0
  317. {bbot-2.5.0.6742rc0 → bbot-2.5.0.6765rc0}/bbot/test/test_step_2/module_tests/test_module_badsecrets.py +0 -0
  318. {bbot-2.5.0.6742rc0 → bbot-2.5.0.6765rc0}/bbot/test/test_step_2/module_tests/test_module_bevigil.py +0 -0
  319. {bbot-2.5.0.6742rc0 → bbot-2.5.0.6765rc0}/bbot/test/test_step_2/module_tests/test_module_bucket_amazon.py +0 -0
  320. {bbot-2.5.0.6742rc0 → bbot-2.5.0.6765rc0}/bbot/test/test_step_2/module_tests/test_module_bucket_azure.py +0 -0
  321. {bbot-2.5.0.6742rc0 → bbot-2.5.0.6765rc0}/bbot/test/test_step_2/module_tests/test_module_bucket_digitalocean.py +0 -0
  322. {bbot-2.5.0.6742rc0 → bbot-2.5.0.6765rc0}/bbot/test/test_step_2/module_tests/test_module_bucket_file_enum.py +0 -0
  323. {bbot-2.5.0.6742rc0 → bbot-2.5.0.6765rc0}/bbot/test/test_step_2/module_tests/test_module_bucket_firebase.py +0 -0
  324. {bbot-2.5.0.6742rc0 → bbot-2.5.0.6765rc0}/bbot/test/test_step_2/module_tests/test_module_bucket_google.py +0 -0
  325. {bbot-2.5.0.6742rc0 → bbot-2.5.0.6765rc0}/bbot/test/test_step_2/module_tests/test_module_bufferoverrun.py +0 -0
  326. {bbot-2.5.0.6742rc0 → bbot-2.5.0.6765rc0}/bbot/test/test_step_2/module_tests/test_module_builtwith.py +0 -0
  327. {bbot-2.5.0.6742rc0 → bbot-2.5.0.6765rc0}/bbot/test/test_step_2/module_tests/test_module_bypass403.py +0 -0
  328. {bbot-2.5.0.6742rc0 → bbot-2.5.0.6765rc0}/bbot/test/test_step_2/module_tests/test_module_c99.py +0 -0
  329. {bbot-2.5.0.6742rc0 → bbot-2.5.0.6765rc0}/bbot/test/test_step_2/module_tests/test_module_censys.py +0 -0
  330. {bbot-2.5.0.6742rc0 → bbot-2.5.0.6765rc0}/bbot/test/test_step_2/module_tests/test_module_certspotter.py +0 -0
  331. {bbot-2.5.0.6742rc0 → bbot-2.5.0.6765rc0}/bbot/test/test_step_2/module_tests/test_module_chaos.py +0 -0
  332. {bbot-2.5.0.6742rc0 → bbot-2.5.0.6765rc0}/bbot/test/test_step_2/module_tests/test_module_cloudcheck.py +0 -0
  333. {bbot-2.5.0.6742rc0 → bbot-2.5.0.6765rc0}/bbot/test/test_step_2/module_tests/test_module_code_repository.py +0 -0
  334. {bbot-2.5.0.6742rc0 → bbot-2.5.0.6765rc0}/bbot/test/test_step_2/module_tests/test_module_credshed.py +0 -0
  335. {bbot-2.5.0.6742rc0 → bbot-2.5.0.6765rc0}/bbot/test/test_step_2/module_tests/test_module_crt.py +0 -0
  336. {bbot-2.5.0.6742rc0 → bbot-2.5.0.6765rc0}/bbot/test/test_step_2/module_tests/test_module_crt_db.py +0 -0
  337. {bbot-2.5.0.6742rc0 → bbot-2.5.0.6765rc0}/bbot/test/test_step_2/module_tests/test_module_csv.py +0 -0
  338. {bbot-2.5.0.6742rc0 → bbot-2.5.0.6765rc0}/bbot/test/test_step_2/module_tests/test_module_dehashed.py +0 -0
  339. {bbot-2.5.0.6742rc0 → bbot-2.5.0.6765rc0}/bbot/test/test_step_2/module_tests/test_module_digitorus.py +0 -0
  340. {bbot-2.5.0.6742rc0 → bbot-2.5.0.6765rc0}/bbot/test/test_step_2/module_tests/test_module_discord.py +0 -0
  341. {bbot-2.5.0.6742rc0 → bbot-2.5.0.6765rc0}/bbot/test/test_step_2/module_tests/test_module_dnsbimi.py +0 -0
  342. {bbot-2.5.0.6742rc0 → bbot-2.5.0.6765rc0}/bbot/test/test_step_2/module_tests/test_module_dnsbrute.py +0 -0
  343. {bbot-2.5.0.6742rc0 → bbot-2.5.0.6765rc0}/bbot/test/test_step_2/module_tests/test_module_dnsbrute_mutations.py +0 -0
  344. {bbot-2.5.0.6742rc0 → bbot-2.5.0.6765rc0}/bbot/test/test_step_2/module_tests/test_module_dnscaa.py +0 -0
  345. {bbot-2.5.0.6742rc0 → bbot-2.5.0.6765rc0}/bbot/test/test_step_2/module_tests/test_module_dnscommonsrv.py +0 -0
  346. {bbot-2.5.0.6742rc0 → bbot-2.5.0.6765rc0}/bbot/test/test_step_2/module_tests/test_module_dnsdumpster.py +0 -0
  347. {bbot-2.5.0.6742rc0 → bbot-2.5.0.6765rc0}/bbot/test/test_step_2/module_tests/test_module_dnsresolve.py +0 -0
  348. {bbot-2.5.0.6742rc0 → bbot-2.5.0.6765rc0}/bbot/test/test_step_2/module_tests/test_module_dnstlsrpt.py +0 -0
  349. {bbot-2.5.0.6742rc0 → bbot-2.5.0.6765rc0}/bbot/test/test_step_2/module_tests/test_module_docker_pull.py +0 -0
  350. {bbot-2.5.0.6742rc0 → bbot-2.5.0.6765rc0}/bbot/test/test_step_2/module_tests/test_module_dockerhub.py +0 -0
  351. {bbot-2.5.0.6742rc0 → bbot-2.5.0.6765rc0}/bbot/test/test_step_2/module_tests/test_module_dotnetnuke.py +0 -0
  352. {bbot-2.5.0.6742rc0 → bbot-2.5.0.6765rc0}/bbot/test/test_step_2/module_tests/test_module_emailformat.py +0 -0
  353. {bbot-2.5.0.6742rc0 → bbot-2.5.0.6765rc0}/bbot/test/test_step_2/module_tests/test_module_emails.py +0 -0
  354. {bbot-2.5.0.6742rc0 → bbot-2.5.0.6765rc0}/bbot/test/test_step_2/module_tests/test_module_excavate.py +0 -0
  355. {bbot-2.5.0.6742rc0 → bbot-2.5.0.6765rc0}/bbot/test/test_step_2/module_tests/test_module_extractous.py +0 -0
  356. {bbot-2.5.0.6742rc0 → bbot-2.5.0.6765rc0}/bbot/test/test_step_2/module_tests/test_module_ffuf.py +0 -0
  357. {bbot-2.5.0.6742rc0 → bbot-2.5.0.6765rc0}/bbot/test/test_step_2/module_tests/test_module_ffuf_shortnames.py +0 -0
  358. {bbot-2.5.0.6742rc0 → bbot-2.5.0.6765rc0}/bbot/test/test_step_2/module_tests/test_module_filedownload.py +0 -0
  359. {bbot-2.5.0.6742rc0 → bbot-2.5.0.6765rc0}/bbot/test/test_step_2/module_tests/test_module_fingerprintx.py +0 -0
  360. {bbot-2.5.0.6742rc0 → bbot-2.5.0.6765rc0}/bbot/test/test_step_2/module_tests/test_module_fullhunt.py +0 -0
  361. {bbot-2.5.0.6742rc0 → bbot-2.5.0.6765rc0}/bbot/test/test_step_2/module_tests/test_module_generic_ssrf.py +0 -0
  362. {bbot-2.5.0.6742rc0 → bbot-2.5.0.6765rc0}/bbot/test/test_step_2/module_tests/test_module_git.py +0 -0
  363. {bbot-2.5.0.6742rc0 → bbot-2.5.0.6765rc0}/bbot/test/test_step_2/module_tests/test_module_git_clone.py +0 -0
  364. {bbot-2.5.0.6742rc0 → bbot-2.5.0.6765rc0}/bbot/test/test_step_2/module_tests/test_module_gitdumper.py +0 -0
  365. {bbot-2.5.0.6742rc0 → bbot-2.5.0.6765rc0}/bbot/test/test_step_2/module_tests/test_module_github_codesearch.py +0 -0
  366. {bbot-2.5.0.6742rc0 → bbot-2.5.0.6765rc0}/bbot/test/test_step_2/module_tests/test_module_github_org.py +0 -0
  367. {bbot-2.5.0.6742rc0 → bbot-2.5.0.6765rc0}/bbot/test/test_step_2/module_tests/test_module_github_usersearch.py +0 -0
  368. {bbot-2.5.0.6742rc0 → bbot-2.5.0.6765rc0}/bbot/test/test_step_2/module_tests/test_module_github_workflows.py +0 -0
  369. {bbot-2.5.0.6742rc0 → bbot-2.5.0.6765rc0}/bbot/test/test_step_2/module_tests/test_module_gitlab.py +0 -0
  370. {bbot-2.5.0.6742rc0 → bbot-2.5.0.6765rc0}/bbot/test/test_step_2/module_tests/test_module_google_playstore.py +0 -0
  371. {bbot-2.5.0.6742rc0 → bbot-2.5.0.6765rc0}/bbot/test/test_step_2/module_tests/test_module_gowitness.py +0 -0
  372. {bbot-2.5.0.6742rc0 → bbot-2.5.0.6765rc0}/bbot/test/test_step_2/module_tests/test_module_hackertarget.py +0 -0
  373. {bbot-2.5.0.6742rc0 → bbot-2.5.0.6765rc0}/bbot/test/test_step_2/module_tests/test_module_host_header.py +0 -0
  374. {bbot-2.5.0.6742rc0 → bbot-2.5.0.6765rc0}/bbot/test/test_step_2/module_tests/test_module_http.py +0 -0
  375. {bbot-2.5.0.6742rc0 → bbot-2.5.0.6765rc0}/bbot/test/test_step_2/module_tests/test_module_httpx.py +0 -0
  376. {bbot-2.5.0.6742rc0 → bbot-2.5.0.6765rc0}/bbot/test/test_step_2/module_tests/test_module_hunt.py +0 -0
  377. {bbot-2.5.0.6742rc0 → bbot-2.5.0.6765rc0}/bbot/test/test_step_2/module_tests/test_module_hunterio.py +0 -0
  378. {bbot-2.5.0.6742rc0 → bbot-2.5.0.6765rc0}/bbot/test/test_step_2/module_tests/test_module_ip2location.py +0 -0
  379. {bbot-2.5.0.6742rc0 → bbot-2.5.0.6765rc0}/bbot/test/test_step_2/module_tests/test_module_ipneighbor.py +0 -0
  380. {bbot-2.5.0.6742rc0 → bbot-2.5.0.6765rc0}/bbot/test/test_step_2/module_tests/test_module_ipstack.py +0 -0
  381. {bbot-2.5.0.6742rc0 → bbot-2.5.0.6765rc0}/bbot/test/test_step_2/module_tests/test_module_jadx.py +0 -0
  382. {bbot-2.5.0.6742rc0 → bbot-2.5.0.6765rc0}/bbot/test/test_step_2/module_tests/test_module_json.py +0 -0
  383. {bbot-2.5.0.6742rc0 → bbot-2.5.0.6765rc0}/bbot/test/test_step_2/module_tests/test_module_leakix.py +0 -0
  384. {bbot-2.5.0.6742rc0 → bbot-2.5.0.6765rc0}/bbot/test/test_step_2/module_tests/test_module_lightfuzz.py +0 -0
  385. {bbot-2.5.0.6742rc0 → bbot-2.5.0.6765rc0}/bbot/test/test_step_2/module_tests/test_module_medusa.py +0 -0
  386. {bbot-2.5.0.6742rc0 → bbot-2.5.0.6765rc0}/bbot/test/test_step_2/module_tests/test_module_mysql.py +0 -0
  387. {bbot-2.5.0.6742rc0 → bbot-2.5.0.6765rc0}/bbot/test/test_step_2/module_tests/test_module_myssl.py +0 -0
  388. {bbot-2.5.0.6742rc0 → bbot-2.5.0.6765rc0}/bbot/test/test_step_2/module_tests/test_module_neo4j.py +0 -0
  389. {bbot-2.5.0.6742rc0 → bbot-2.5.0.6765rc0}/bbot/test/test_step_2/module_tests/test_module_newsletters.py +0 -0
  390. {bbot-2.5.0.6742rc0 → bbot-2.5.0.6765rc0}/bbot/test/test_step_2/module_tests/test_module_nmap_xml.py +0 -0
  391. {bbot-2.5.0.6742rc0 → bbot-2.5.0.6765rc0}/bbot/test/test_step_2/module_tests/test_module_ntlm.py +0 -0
  392. {bbot-2.5.0.6742rc0 → bbot-2.5.0.6765rc0}/bbot/test/test_step_2/module_tests/test_module_nuclei.py +0 -0
  393. {bbot-2.5.0.6742rc0 → bbot-2.5.0.6765rc0}/bbot/test/test_step_2/module_tests/test_module_oauth.py +0 -0
  394. {bbot-2.5.0.6742rc0 → bbot-2.5.0.6765rc0}/bbot/test/test_step_2/module_tests/test_module_otx.py +0 -0
  395. {bbot-2.5.0.6742rc0 → bbot-2.5.0.6765rc0}/bbot/test/test_step_2/module_tests/test_module_paramminer_cookies.py +0 -0
  396. {bbot-2.5.0.6742rc0 → bbot-2.5.0.6765rc0}/bbot/test/test_step_2/module_tests/test_module_paramminer_getparams.py +0 -0
  397. {bbot-2.5.0.6742rc0 → bbot-2.5.0.6765rc0}/bbot/test/test_step_2/module_tests/test_module_paramminer_headers.py +0 -0
  398. {bbot-2.5.0.6742rc0 → bbot-2.5.0.6765rc0}/bbot/test/test_step_2/module_tests/test_module_passivetotal.py +0 -0
  399. {bbot-2.5.0.6742rc0 → bbot-2.5.0.6765rc0}/bbot/test/test_step_2/module_tests/test_module_pgp.py +0 -0
  400. {bbot-2.5.0.6742rc0 → bbot-2.5.0.6765rc0}/bbot/test/test_step_2/module_tests/test_module_portfilter.py +0 -0
  401. {bbot-2.5.0.6742rc0 → bbot-2.5.0.6765rc0}/bbot/test/test_step_2/module_tests/test_module_portscan.py +0 -0
  402. {bbot-2.5.0.6742rc0 → bbot-2.5.0.6765rc0}/bbot/test/test_step_2/module_tests/test_module_postgres.py +0 -0
  403. {bbot-2.5.0.6742rc0 → bbot-2.5.0.6765rc0}/bbot/test/test_step_2/module_tests/test_module_postman.py +0 -0
  404. {bbot-2.5.0.6742rc0 → bbot-2.5.0.6765rc0}/bbot/test/test_step_2/module_tests/test_module_postman_download.py +0 -0
  405. {bbot-2.5.0.6742rc0 → bbot-2.5.0.6765rc0}/bbot/test/test_step_2/module_tests/test_module_python.py +0 -0
  406. {bbot-2.5.0.6742rc0 → bbot-2.5.0.6765rc0}/bbot/test/test_step_2/module_tests/test_module_rapiddns.py +0 -0
  407. {bbot-2.5.0.6742rc0 → bbot-2.5.0.6765rc0}/bbot/test/test_step_2/module_tests/test_module_reflected_parameters.py +0 -0
  408. {bbot-2.5.0.6742rc0 → bbot-2.5.0.6765rc0}/bbot/test/test_step_2/module_tests/test_module_robots.py +0 -0
  409. {bbot-2.5.0.6742rc0 → bbot-2.5.0.6765rc0}/bbot/test/test_step_2/module_tests/test_module_securitytrails.py +0 -0
  410. {bbot-2.5.0.6742rc0 → bbot-2.5.0.6765rc0}/bbot/test/test_step_2/module_tests/test_module_securitytxt.py +0 -0
  411. {bbot-2.5.0.6742rc0 → bbot-2.5.0.6765rc0}/bbot/test/test_step_2/module_tests/test_module_shodan_dns.py +0 -0
  412. {bbot-2.5.0.6742rc0 → bbot-2.5.0.6765rc0}/bbot/test/test_step_2/module_tests/test_module_shodan_idb.py +0 -0
  413. {bbot-2.5.0.6742rc0 → bbot-2.5.0.6765rc0}/bbot/test/test_step_2/module_tests/test_module_sitedossier.py +0 -0
  414. {bbot-2.5.0.6742rc0 → bbot-2.5.0.6765rc0}/bbot/test/test_step_2/module_tests/test_module_skymem.py +0 -0
  415. {bbot-2.5.0.6742rc0 → bbot-2.5.0.6765rc0}/bbot/test/test_step_2/module_tests/test_module_slack.py +0 -0
  416. {bbot-2.5.0.6742rc0 → bbot-2.5.0.6765rc0}/bbot/test/test_step_2/module_tests/test_module_smuggler.py +0 -0
  417. {bbot-2.5.0.6742rc0 → bbot-2.5.0.6765rc0}/bbot/test/test_step_2/module_tests/test_module_social.py +0 -0
  418. {bbot-2.5.0.6742rc0 → bbot-2.5.0.6765rc0}/bbot/test/test_step_2/module_tests/test_module_speculate.py +0 -0
  419. {bbot-2.5.0.6742rc0 → bbot-2.5.0.6765rc0}/bbot/test/test_step_2/module_tests/test_module_splunk.py +0 -0
  420. {bbot-2.5.0.6742rc0 → bbot-2.5.0.6765rc0}/bbot/test/test_step_2/module_tests/test_module_sqlite.py +0 -0
  421. {bbot-2.5.0.6742rc0 → bbot-2.5.0.6765rc0}/bbot/test/test_step_2/module_tests/test_module_sslcert.py +0 -0
  422. {bbot-2.5.0.6742rc0 → bbot-2.5.0.6765rc0}/bbot/test/test_step_2/module_tests/test_module_stdout.py +0 -0
  423. {bbot-2.5.0.6742rc0 → bbot-2.5.0.6765rc0}/bbot/test/test_step_2/module_tests/test_module_subdomaincenter.py +0 -0
  424. {bbot-2.5.0.6742rc0 → bbot-2.5.0.6765rc0}/bbot/test/test_step_2/module_tests/test_module_subdomainradar.py +0 -0
  425. {bbot-2.5.0.6742rc0 → bbot-2.5.0.6765rc0}/bbot/test/test_step_2/module_tests/test_module_subdomains.py +0 -0
  426. {bbot-2.5.0.6742rc0 → bbot-2.5.0.6765rc0}/bbot/test/test_step_2/module_tests/test_module_teams.py +0 -0
  427. {bbot-2.5.0.6742rc0 → bbot-2.5.0.6765rc0}/bbot/test/test_step_2/module_tests/test_module_telerik.py +0 -0
  428. {bbot-2.5.0.6742rc0 → bbot-2.5.0.6765rc0}/bbot/test/test_step_2/module_tests/test_module_trickest.py +0 -0
  429. {bbot-2.5.0.6742rc0 → bbot-2.5.0.6765rc0}/bbot/test/test_step_2/module_tests/test_module_trufflehog.py +0 -0
  430. {bbot-2.5.0.6742rc0 → bbot-2.5.0.6765rc0}/bbot/test/test_step_2/module_tests/test_module_txt.py +0 -0
  431. {bbot-2.5.0.6742rc0 → bbot-2.5.0.6765rc0}/bbot/test/test_step_2/module_tests/test_module_unarchive.py +0 -0
  432. {bbot-2.5.0.6742rc0 → bbot-2.5.0.6765rc0}/bbot/test/test_step_2/module_tests/test_module_url_manipulation.py +0 -0
  433. {bbot-2.5.0.6742rc0 → bbot-2.5.0.6765rc0}/bbot/test/test_step_2/module_tests/test_module_urlscan.py +0 -0
  434. {bbot-2.5.0.6742rc0 → bbot-2.5.0.6765rc0}/bbot/test/test_step_2/module_tests/test_module_vhost.py +0 -0
  435. {bbot-2.5.0.6742rc0 → bbot-2.5.0.6765rc0}/bbot/test/test_step_2/module_tests/test_module_viewdns.py +0 -0
  436. {bbot-2.5.0.6742rc0 → bbot-2.5.0.6765rc0}/bbot/test/test_step_2/module_tests/test_module_virustotal.py +0 -0
  437. {bbot-2.5.0.6742rc0 → bbot-2.5.0.6765rc0}/bbot/test/test_step_2/module_tests/test_module_wafw00f.py +0 -0
  438. {bbot-2.5.0.6742rc0 → bbot-2.5.0.6765rc0}/bbot/test/test_step_2/module_tests/test_module_wappalyzer.py +0 -0
  439. {bbot-2.5.0.6742rc0 → bbot-2.5.0.6765rc0}/bbot/test/test_step_2/module_tests/test_module_wayback.py +0 -0
  440. {bbot-2.5.0.6742rc0 → bbot-2.5.0.6765rc0}/bbot/test/test_step_2/module_tests/test_module_web_parameters.py +0 -0
  441. {bbot-2.5.0.6742rc0 → bbot-2.5.0.6765rc0}/bbot/test/test_step_2/module_tests/test_module_web_report.py +0 -0
  442. {bbot-2.5.0.6742rc0 → bbot-2.5.0.6765rc0}/bbot/test/test_step_2/module_tests/test_module_websocket.py +0 -0
  443. {bbot-2.5.0.6742rc0 → bbot-2.5.0.6765rc0}/bbot/test/test_step_2/module_tests/test_module_wpscan.py +0 -0
  444. {bbot-2.5.0.6742rc0 → bbot-2.5.0.6765rc0}/bbot/test/test_step_2/module_tests/test_module_zoomeye.py +0 -0
  445. {bbot-2.5.0.6742rc0 → bbot-2.5.0.6765rc0}/bbot/test/test_step_2/template_tests/__init__.py +0 -0
  446. {bbot-2.5.0.6742rc0 → bbot-2.5.0.6765rc0}/bbot/test/test_step_2/template_tests/test_template_subdomain_enum.py +0 -0
  447. {bbot-2.5.0.6742rc0 → bbot-2.5.0.6765rc0}/bbot/test/testsslcert.pem +0 -0
  448. {bbot-2.5.0.6742rc0 → bbot-2.5.0.6765rc0}/bbot/test/testsslkey.pem +0 -0
  449. {bbot-2.5.0.6742rc0 → bbot-2.5.0.6765rc0}/bbot/wordlists/devops_mutations.txt +0 -0
  450. {bbot-2.5.0.6742rc0 → bbot-2.5.0.6765rc0}/bbot/wordlists/ms_on_prem_subdomains.txt +0 -0
  451. {bbot-2.5.0.6742rc0 → bbot-2.5.0.6765rc0}/bbot/wordlists/nameservers.txt +0 -0
  452. {bbot-2.5.0.6742rc0 → bbot-2.5.0.6765rc0}/bbot/wordlists/paramminer_headers.txt +0 -0
  453. {bbot-2.5.0.6742rc0 → bbot-2.5.0.6765rc0}/bbot/wordlists/paramminer_parameters.txt +0 -0
  454. {bbot-2.5.0.6742rc0 → bbot-2.5.0.6765rc0}/bbot/wordlists/raft-small-extensions-lowercase_CLEANED.txt +0 -0
  455. {bbot-2.5.0.6742rc0 → bbot-2.5.0.6765rc0}/bbot/wordlists/top_open_ports_nmap.txt +0 -0
  456. {bbot-2.5.0.6742rc0 → bbot-2.5.0.6765rc0}/bbot/wordlists/valid_url_schemes.txt +0 -0
  457. {bbot-2.5.0.6742rc0 → bbot-2.5.0.6765rc0}/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.5.0.6742rc0
3
+ Version: 2.5.0.6765rc0
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
@@ -1,5 +1,5 @@
1
1
  # version placeholder (replaced by poetry-dynamic-versioning)
2
- __version__ = "v2.5.0.6742rc"
2
+ __version__ = "v2.5.0.6765rc"
3
3
 
4
4
  from .scanner import Scanner, Preset
5
5
 
@@ -173,6 +173,7 @@ adjectives = [
173
173
  "pasty",
174
174
  "peckish",
175
175
  "pedantic",
176
+ "pensive",
176
177
  "pernicious",
177
178
  "perturbed",
178
179
  "perverted",
@@ -671,6 +672,7 @@ names = [
671
672
  "tracy",
672
673
  "travis",
673
674
  "treebeard",
675
+ "trent",
674
676
  "triss",
675
677
  "tyler",
676
678
  "tyrell",
@@ -0,0 +1,80 @@
1
+ from bbot.modules.base import BaseModule
2
+
3
+
4
+ class aspnet_bin_exposure(BaseModule):
5
+ watched_events = ["URL"]
6
+ produced_events = ["VULNERABILITY"]
7
+ flags = ["active", "safe", "web-thorough"]
8
+ meta = {
9
+ "description": "Check for ASP.NET Security Feature Bypasses (CVE-2023-36899 and CVE-2023-36560)",
10
+ "created_date": "2025-01-28",
11
+ "author": "@liquidsec",
12
+ }
13
+
14
+ in_scope_only = True
15
+ test_dlls = [
16
+ "Telerik.Web.UI.dll",
17
+ "Newtonsoft.Json.dll",
18
+ "System.Net.Http.dll",
19
+ "EntityFramework.dll",
20
+ "AjaxControlToolkit.dll",
21
+ ]
22
+
23
+ @staticmethod
24
+ def normalize_url(url):
25
+ return str(url.rstrip("/") + "/").lower()
26
+
27
+ def _incoming_dedup_hash(self, event):
28
+ return hash(self.normalize_url(event.data))
29
+
30
+ async def handle_event(self, event):
31
+ normalized_url = self.normalize_url(event.data)
32
+ for test_dll in self.test_dlls:
33
+ for technique in ["b/(S(X))in/###DLL_PLACEHOLDER###/(S(X))/", "(S(X))/b/(S(X))in/###DLL_PLACEHOLDER###"]:
34
+ test_url = f"{normalized_url}{technique.replace('###DLL_PLACEHOLDER###', test_dll)}"
35
+ self.debug(f"Sending test URL: [{test_url}]")
36
+ kwargs = {"method": "GET", "allow_redirects": False, "timeout": 10}
37
+ test_result = await self.helpers.request(test_url, **kwargs)
38
+ if test_result:
39
+ if test_result.status_code == 200 and (
40
+ "content-type" in test_result.headers
41
+ and "application/x-msdownload" in test_result.headers["content-type"]
42
+ ):
43
+ self.debug(
44
+ f"Got positive result for probe with test url: [{test_url}]. Status Code: [{test_result.status_code}] Content Length: [{len(test_result.content)}]"
45
+ )
46
+
47
+ if test_result.status_code == 200 and (
48
+ "content-type" in test_result.headers
49
+ and "application/x-msdownload" in test_result.headers["content-type"]
50
+ ):
51
+ confirm_url = (
52
+ f"{normalized_url}{technique.replace('###DLL_PLACEHOLDER###', 'oopsnotarealdll.dll')}"
53
+ )
54
+ confirm_result = await self.helpers.request(confirm_url, **kwargs)
55
+
56
+ if confirm_result and (
57
+ confirm_result.status_code != 200
58
+ or not (
59
+ "content-type" in confirm_result.headers
60
+ and "application/x-msdownload" in confirm_result.headers["content-type"]
61
+ )
62
+ ):
63
+ description = f"IIS Bin Directory DLL Exposure. Detection Url: [{test_url}]"
64
+ await self.emit_event(
65
+ {
66
+ "severity": "HIGH",
67
+ "host": str(event.host),
68
+ "url": normalized_url,
69
+ "description": description,
70
+ },
71
+ "VULNERABILITY",
72
+ event,
73
+ context="{module} detected IIS Bin Directory DLL Exposure vulnerability",
74
+ )
75
+ return True
76
+
77
+ async def filter_event(self, event):
78
+ if "dir" in event.tags:
79
+ return True
80
+ return False
@@ -50,7 +50,16 @@ hunt_param_dict = {
50
50
  "cfg",
51
51
  "config",
52
52
  ],
53
- "Directory Traversal": ["entry", "download", "attachment", "basepath", "path", "file", "source", "dest"],
53
+ "Directory Traversal": [
54
+ "entry",
55
+ "download",
56
+ "attachment",
57
+ "basepath",
58
+ "path",
59
+ "file",
60
+ "source",
61
+ "dest",
62
+ ],
54
63
  "Local File Include": [
55
64
  "file",
56
65
  "document",
@@ -279,8 +288,6 @@ class hunt(BaseModule):
279
288
  "author": "@liquidsec",
280
289
  "created_date": "2022-07-20",
281
290
  }
282
- # accept all events regardless of scope distance
283
- scope_distance_modifier = None
284
291
 
285
292
  async def handle_event(self, event):
286
293
  p = event.data["name"]
@@ -166,6 +166,10 @@ class iis_shortnames(BaseModule):
166
166
 
167
167
  cl = ext_char_list if extension_mode is True else char_list
168
168
 
169
+ self.debug(
170
+ f"Solving shortname recursive for {target} with prefix {prefix} and extension mode {extension_mode}"
171
+ )
172
+
169
173
  urls_and_kwargs = []
170
174
 
171
175
  for c in cl:
@@ -334,6 +338,18 @@ class iis_shortnames(BaseModule):
334
338
  for url_hint in url_hint_list:
335
339
  if "." in url_hint:
336
340
  hint_type = "shortname-endpoint"
341
+ # Check if it's a ZIP file
342
+ if url_hint.lower().endswith(".zip"):
343
+ await self.emit_event(
344
+ {
345
+ "host": str(event.host),
346
+ "url": event.data,
347
+ "description": f"Possible backup file (zip) in web root: {normalized_url}{url_hint}",
348
+ },
349
+ "FINDING",
350
+ event,
351
+ context=f"{{module}} discovered possible backup file in web root: {url_hint}",
352
+ )
337
353
  else:
338
354
  hint_type = "shortname-directory"
339
355
 
@@ -12,6 +12,7 @@ modules:
12
12
  - telerik
13
13
  - ajaxpro
14
14
  - dotnetnuke
15
+ - aspnet_bin_exposure
15
16
 
16
17
  config:
17
18
  modules:
@@ -0,0 +1,73 @@
1
+ from .base import ModuleTestBase
2
+ import re
3
+
4
+
5
+ class TestAspnetBinExposure(ModuleTestBase):
6
+ targets = ["http://127.0.0.1:8888"]
7
+ modules_overrides = ["httpx", "aspnet_bin_exposure"]
8
+ config_overrides = {
9
+ "modules": {
10
+ "aspnet_bin_exposure": {
11
+ "test_dlls": [
12
+ "Newtonsoft.Json.dll",
13
+ ]
14
+ }
15
+ }
16
+ }
17
+
18
+ async def setup_before_prep(self, module_test):
19
+ # Simulate successful DLL exposure
20
+ expect_args = {
21
+ "method": "GET",
22
+ "uri": "/b/(S(X))in/Newtonsoft.Json.dll/(S(X))/",
23
+ }
24
+ respond_args = {
25
+ "status": 200,
26
+ "headers": {"content-type": "application/x-msdownload"},
27
+ "response_data": b"MZ\x90\x00\x03\x00\x00\x00",
28
+ }
29
+ module_test.set_expect_requests(expect_args=expect_args, respond_args=respond_args)
30
+
31
+ # Simulate failed DLL exposure (confirmation test)
32
+ expect_args = {
33
+ "method": "GET",
34
+ "uri": "/b/(S(X))in/oopsnotarealdll.dll/(S(X))/",
35
+ }
36
+ respond_args = {"status": 404}
37
+ module_test.set_expect_requests(expect_args=expect_args, respond_args=respond_args)
38
+
39
+ # Simulate alternative technique
40
+ expect_args = {
41
+ "method": "GET",
42
+ "uri": "/(S(X))/b/(S(X))in/Newtonsoft.Json.dll",
43
+ }
44
+ respond_args = {
45
+ "status": 200,
46
+ "headers": {"content-type": "application/x-msdownload"},
47
+ "response_data": b"MZ\x90\x00\x03\x00\x00\x00",
48
+ }
49
+ module_test.set_expect_requests(expect_args=expect_args, respond_args=respond_args)
50
+
51
+ # Simulate failed alternative technique (confirmation test)
52
+ expect_args = {
53
+ "method": "GET",
54
+ "uri": "/(S(X))/b/(S(X))in/oopsnotarealdll.dll",
55
+ }
56
+ respond_args = {"status": 404}
57
+ module_test.set_expect_requests(expect_args=expect_args, respond_args=respond_args)
58
+
59
+ # Fallback for any other requests
60
+ expect_args = {"uri": re.compile(r"^/.*$")}
61
+ respond_args = {"status": 404}
62
+ module_test.set_expect_requests(expect_args=expect_args, respond_args=respond_args)
63
+
64
+ def check(self, module_test, events):
65
+ vulnerability_found = False
66
+ for e in events:
67
+ if e.type == "VULNERABILITY" and "IIS Bin Directory DLL Exposure" in e.data["description"]:
68
+ vulnerability_found = True
69
+ assert e.data["severity"] == "HIGH", "Vulnerability severity should be HIGH"
70
+ assert "Detection Url" in e.data["description"], "Description should include detection URL"
71
+ break
72
+
73
+ assert vulnerability_found, "No vulnerability event was found"
@@ -43,19 +43,64 @@ class TestIIS_Shortnames(ModuleTestBase):
43
43
  respond_args = {"response_data": "", "status": 400}
44
44
  module_test.set_expect_requests(expect_args=expect_args, respond_args=respond_args)
45
45
 
46
- for char in "BLSHAX":
46
+ expect_args = {"method": "GET", "uri": re.compile(r"\/BA\*~1\*.*$")}
47
+ respond_args = {"response_data": "", "status": 400}
48
+ module_test.set_expect_requests(expect_args=expect_args, respond_args=respond_args)
49
+
50
+ expect_args = {"method": "GET", "uri": re.compile(r"\/BAC\*~1\*.*$")}
51
+ respond_args = {"response_data": "", "status": 400}
52
+ module_test.set_expect_requests(expect_args=expect_args, respond_args=respond_args)
53
+
54
+ expect_args = {"method": "GET", "uri": re.compile(r"\/BACK\*~1\*.*$")}
55
+ respond_args = {"response_data": "", "status": 400}
56
+ module_test.set_expect_requests(expect_args=expect_args, respond_args=respond_args)
57
+
58
+ expect_args = {"method": "GET", "uri": re.compile(r"\/BACKU\*~1\*.*$")}
59
+ respond_args = {"response_data": "", "status": 400}
60
+ module_test.set_expect_requests(expect_args=expect_args, respond_args=respond_args)
61
+
62
+ expect_args = {"method": "GET", "uri": re.compile(r"\/BACKUP\*~1\*/a.aspx$")}
63
+ respond_args = {"response_data": "", "status": 400}
64
+ module_test.set_expect_requests(expect_args=expect_args, respond_args=respond_args)
65
+
66
+ expect_args = {"method": "GET", "uri": re.compile(r"\/BACKUP~1\*$")}
67
+ respond_args = {"response_data": "", "status": 400}
68
+ module_test.set_expect_requests(expect_args=expect_args, respond_args=respond_args)
69
+
70
+ expect_args = {"method": "GET", "uri": re.compile(r"\/BACKUP~1\.Z\*/a.aspx$")}
71
+ respond_args = {"response_data": "", "status": 400}
72
+ module_test.set_expect_requests(expect_args=expect_args, respond_args=respond_args)
73
+
74
+ expect_args = {"method": "GET", "uri": re.compile(r"\/BACKUP~1\.ZI\*/a.aspx$")}
75
+ respond_args = {"response_data": "", "status": 400}
76
+ module_test.set_expect_requests(expect_args=expect_args, respond_args=respond_args)
77
+
78
+ expect_args = {"method": "GET", "uri": re.compile(r"\/BACKUP~1\.ZIP\*/a.aspx$")}
79
+ respond_args = {"response_data": "", "status": 400}
80
+ module_test.set_expect_requests(expect_args=expect_args, respond_args=respond_args)
81
+
82
+ for char in "BLSHAXCKUP":
47
83
  expect_args = {"method": "GET", "uri": re.compile(rf"\/\*{char}\*~1\*.*$")}
48
84
  respond_args = {"response_data": "", "status": 400}
49
85
  module_test.set_expect_requests(expect_args=expect_args, respond_args=respond_args)
50
86
 
87
+ for char in "ZIP":
88
+ expect_args = {"method": "GET", "uri": re.compile(rf"\/\*~1\*{char}\*.*$")}
89
+ respond_args = {"response_data": "", "status": 400}
90
+ module_test.set_expect_requests(expect_args=expect_args, respond_args=respond_args)
91
+
51
92
  def check(self, module_test, events):
52
93
  vulnerabilityEmitted = False
53
94
  url_hintEmitted = False
95
+ zip_findingEmitted = False
54
96
  for e in events:
55
97
  if e.type == "VULNERABILITY" and "iis-magic-url" not in e.tags:
56
98
  vulnerabilityEmitted = True
57
99
  if e.type == "URL_HINT" and e.data == "http://127.0.0.1:8888/BLSHAX~1":
58
100
  url_hintEmitted = True
101
+ if e.type == "FINDING" and "Possible backup file (zip) in web root" in e.data["description"]:
102
+ zip_findingEmitted = True
59
103
 
60
104
  assert vulnerabilityEmitted
61
105
  assert url_hintEmitted
106
+ assert zip_findingEmitted
@@ -1,6 +1,6 @@
1
1
  [tool.poetry]
2
2
  name = "bbot"
3
- version = "v2.5.0.6742rc"
3
+ version = "v2.5.0.6765rc"
4
4
  description = "OSINT automation for hackers."
5
5
  authors = [
6
6
  "TheTechromancer",
File without changes
File without changes
File without changes