bbot 2.3.2.5850rc0__tar.gz → 2.3.2.5874rc0__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 (429) hide show
  1. {bbot-2.3.2.5850rc0 → bbot-2.3.2.5874rc0}/PKG-INFO +1 -1
  2. {bbot-2.3.2.5850rc0 → bbot-2.3.2.5874rc0}/bbot/__init__.py +1 -1
  3. {bbot-2.3.2.5850rc0 → bbot-2.3.2.5874rc0}/bbot/modules/generic_ssrf.py +24 -11
  4. {bbot-2.3.2.5850rc0 → bbot-2.3.2.5874rc0}/bbot/test/conftest.py +25 -20
  5. {bbot-2.3.2.5850rc0 → bbot-2.3.2.5874rc0}/bbot/test/test_step_2/module_tests/test_module_dotnetnuke.py +1 -2
  6. {bbot-2.3.2.5850rc0 → bbot-2.3.2.5874rc0}/bbot/test/test_step_2/module_tests/test_module_generic_ssrf.py +34 -3
  7. {bbot-2.3.2.5850rc0 → bbot-2.3.2.5874rc0}/bbot/test/test_step_2/module_tests/test_module_host_header.py +1 -0
  8. {bbot-2.3.2.5850rc0 → bbot-2.3.2.5874rc0}/pyproject.toml +1 -1
  9. {bbot-2.3.2.5850rc0 → bbot-2.3.2.5874rc0}/LICENSE +0 -0
  10. {bbot-2.3.2.5850rc0 → bbot-2.3.2.5874rc0}/README.md +0 -0
  11. {bbot-2.3.2.5850rc0 → bbot-2.3.2.5874rc0}/bbot/cli.py +0 -0
  12. {bbot-2.3.2.5850rc0 → bbot-2.3.2.5874rc0}/bbot/core/__init__.py +0 -0
  13. {bbot-2.3.2.5850rc0 → bbot-2.3.2.5874rc0}/bbot/core/config/__init__.py +0 -0
  14. {bbot-2.3.2.5850rc0 → bbot-2.3.2.5874rc0}/bbot/core/config/files.py +0 -0
  15. {bbot-2.3.2.5850rc0 → bbot-2.3.2.5874rc0}/bbot/core/config/logger.py +0 -0
  16. {bbot-2.3.2.5850rc0 → bbot-2.3.2.5874rc0}/bbot/core/core.py +0 -0
  17. {bbot-2.3.2.5850rc0 → bbot-2.3.2.5874rc0}/bbot/core/engine.py +0 -0
  18. {bbot-2.3.2.5850rc0 → bbot-2.3.2.5874rc0}/bbot/core/event/__init__.py +0 -0
  19. {bbot-2.3.2.5850rc0 → bbot-2.3.2.5874rc0}/bbot/core/event/base.py +0 -0
  20. {bbot-2.3.2.5850rc0 → bbot-2.3.2.5874rc0}/bbot/core/event/helpers.py +0 -0
  21. {bbot-2.3.2.5850rc0 → bbot-2.3.2.5874rc0}/bbot/core/flags.py +0 -0
  22. {bbot-2.3.2.5850rc0 → bbot-2.3.2.5874rc0}/bbot/core/helpers/__init__.py +0 -0
  23. {bbot-2.3.2.5850rc0 → bbot-2.3.2.5874rc0}/bbot/core/helpers/async_helpers.py +0 -0
  24. {bbot-2.3.2.5850rc0 → bbot-2.3.2.5874rc0}/bbot/core/helpers/bloom.py +0 -0
  25. {bbot-2.3.2.5850rc0 → bbot-2.3.2.5874rc0}/bbot/core/helpers/cache.py +0 -0
  26. {bbot-2.3.2.5850rc0 → bbot-2.3.2.5874rc0}/bbot/core/helpers/command.py +0 -0
  27. {bbot-2.3.2.5850rc0 → bbot-2.3.2.5874rc0}/bbot/core/helpers/depsinstaller/__init__.py +0 -0
  28. {bbot-2.3.2.5850rc0 → bbot-2.3.2.5874rc0}/bbot/core/helpers/depsinstaller/installer.py +0 -0
  29. {bbot-2.3.2.5850rc0 → bbot-2.3.2.5874rc0}/bbot/core/helpers/depsinstaller/sudo_askpass.py +0 -0
  30. {bbot-2.3.2.5850rc0 → bbot-2.3.2.5874rc0}/bbot/core/helpers/diff.py +0 -0
  31. {bbot-2.3.2.5850rc0 → bbot-2.3.2.5874rc0}/bbot/core/helpers/dns/__init__.py +0 -0
  32. {bbot-2.3.2.5850rc0 → bbot-2.3.2.5874rc0}/bbot/core/helpers/dns/brute.py +0 -0
  33. {bbot-2.3.2.5850rc0 → bbot-2.3.2.5874rc0}/bbot/core/helpers/dns/dns.py +0 -0
  34. {bbot-2.3.2.5850rc0 → bbot-2.3.2.5874rc0}/bbot/core/helpers/dns/engine.py +0 -0
  35. {bbot-2.3.2.5850rc0 → bbot-2.3.2.5874rc0}/bbot/core/helpers/dns/helpers.py +0 -0
  36. {bbot-2.3.2.5850rc0 → bbot-2.3.2.5874rc0}/bbot/core/helpers/dns/mock.py +0 -0
  37. {bbot-2.3.2.5850rc0 → bbot-2.3.2.5874rc0}/bbot/core/helpers/files.py +0 -0
  38. {bbot-2.3.2.5850rc0 → bbot-2.3.2.5874rc0}/bbot/core/helpers/helper.py +0 -0
  39. {bbot-2.3.2.5850rc0 → bbot-2.3.2.5874rc0}/bbot/core/helpers/interactsh.py +0 -0
  40. {bbot-2.3.2.5850rc0 → bbot-2.3.2.5874rc0}/bbot/core/helpers/libmagic.py +0 -0
  41. {bbot-2.3.2.5850rc0 → bbot-2.3.2.5874rc0}/bbot/core/helpers/misc.py +0 -0
  42. {bbot-2.3.2.5850rc0 → bbot-2.3.2.5874rc0}/bbot/core/helpers/names_generator.py +0 -0
  43. {bbot-2.3.2.5850rc0 → bbot-2.3.2.5874rc0}/bbot/core/helpers/ntlm.py +0 -0
  44. {bbot-2.3.2.5850rc0 → bbot-2.3.2.5874rc0}/bbot/core/helpers/process.py +0 -0
  45. {bbot-2.3.2.5850rc0 → bbot-2.3.2.5874rc0}/bbot/core/helpers/ratelimiter.py +0 -0
  46. {bbot-2.3.2.5850rc0 → bbot-2.3.2.5874rc0}/bbot/core/helpers/regex.py +0 -0
  47. {bbot-2.3.2.5850rc0 → bbot-2.3.2.5874rc0}/bbot/core/helpers/regexes.py +0 -0
  48. {bbot-2.3.2.5850rc0 → bbot-2.3.2.5874rc0}/bbot/core/helpers/url.py +0 -0
  49. {bbot-2.3.2.5850rc0 → bbot-2.3.2.5874rc0}/bbot/core/helpers/validators.py +0 -0
  50. {bbot-2.3.2.5850rc0 → bbot-2.3.2.5874rc0}/bbot/core/helpers/web/__init__.py +0 -0
  51. {bbot-2.3.2.5850rc0 → bbot-2.3.2.5874rc0}/bbot/core/helpers/web/client.py +0 -0
  52. {bbot-2.3.2.5850rc0 → bbot-2.3.2.5874rc0}/bbot/core/helpers/web/engine.py +0 -0
  53. {bbot-2.3.2.5850rc0 → bbot-2.3.2.5874rc0}/bbot/core/helpers/web/ssl_context.py +0 -0
  54. {bbot-2.3.2.5850rc0 → bbot-2.3.2.5874rc0}/bbot/core/helpers/web/web.py +0 -0
  55. {bbot-2.3.2.5850rc0 → bbot-2.3.2.5874rc0}/bbot/core/helpers/wordcloud.py +0 -0
  56. {bbot-2.3.2.5850rc0 → bbot-2.3.2.5874rc0}/bbot/core/modules.py +0 -0
  57. {bbot-2.3.2.5850rc0 → bbot-2.3.2.5874rc0}/bbot/core/multiprocess.py +0 -0
  58. {bbot-2.3.2.5850rc0 → bbot-2.3.2.5874rc0}/bbot/core/shared_deps.py +0 -0
  59. {bbot-2.3.2.5850rc0 → bbot-2.3.2.5874rc0}/bbot/db/sql/models.py +0 -0
  60. {bbot-2.3.2.5850rc0 → bbot-2.3.2.5874rc0}/bbot/defaults.yml +0 -0
  61. {bbot-2.3.2.5850rc0 → bbot-2.3.2.5874rc0}/bbot/errors.py +0 -0
  62. {bbot-2.3.2.5850rc0 → bbot-2.3.2.5874rc0}/bbot/logger.py +0 -0
  63. {bbot-2.3.2.5850rc0 → bbot-2.3.2.5874rc0}/bbot/modules/__init__.py +0 -0
  64. {bbot-2.3.2.5850rc0 → bbot-2.3.2.5874rc0}/bbot/modules/ajaxpro.py +0 -0
  65. {bbot-2.3.2.5850rc0 → bbot-2.3.2.5874rc0}/bbot/modules/anubisdb.py +0 -0
  66. {bbot-2.3.2.5850rc0 → bbot-2.3.2.5874rc0}/bbot/modules/apkpure.py +0 -0
  67. {bbot-2.3.2.5850rc0 → bbot-2.3.2.5874rc0}/bbot/modules/azure_realm.py +0 -0
  68. {bbot-2.3.2.5850rc0 → bbot-2.3.2.5874rc0}/bbot/modules/azure_tenant.py +0 -0
  69. {bbot-2.3.2.5850rc0 → bbot-2.3.2.5874rc0}/bbot/modules/baddns.py +0 -0
  70. {bbot-2.3.2.5850rc0 → bbot-2.3.2.5874rc0}/bbot/modules/baddns_direct.py +0 -0
  71. {bbot-2.3.2.5850rc0 → bbot-2.3.2.5874rc0}/bbot/modules/baddns_zone.py +0 -0
  72. {bbot-2.3.2.5850rc0 → bbot-2.3.2.5874rc0}/bbot/modules/badsecrets.py +0 -0
  73. {bbot-2.3.2.5850rc0 → bbot-2.3.2.5874rc0}/bbot/modules/base.py +0 -0
  74. {bbot-2.3.2.5850rc0 → bbot-2.3.2.5874rc0}/bbot/modules/bevigil.py +0 -0
  75. {bbot-2.3.2.5850rc0 → bbot-2.3.2.5874rc0}/bbot/modules/binaryedge.py +0 -0
  76. {bbot-2.3.2.5850rc0 → bbot-2.3.2.5874rc0}/bbot/modules/bucket_amazon.py +0 -0
  77. {bbot-2.3.2.5850rc0 → bbot-2.3.2.5874rc0}/bbot/modules/bucket_azure.py +0 -0
  78. {bbot-2.3.2.5850rc0 → bbot-2.3.2.5874rc0}/bbot/modules/bucket_digitalocean.py +0 -0
  79. {bbot-2.3.2.5850rc0 → bbot-2.3.2.5874rc0}/bbot/modules/bucket_file_enum.py +0 -0
  80. {bbot-2.3.2.5850rc0 → bbot-2.3.2.5874rc0}/bbot/modules/bucket_firebase.py +0 -0
  81. {bbot-2.3.2.5850rc0 → bbot-2.3.2.5874rc0}/bbot/modules/bucket_google.py +0 -0
  82. {bbot-2.3.2.5850rc0 → bbot-2.3.2.5874rc0}/bbot/modules/bufferoverrun.py +0 -0
  83. {bbot-2.3.2.5850rc0 → bbot-2.3.2.5874rc0}/bbot/modules/builtwith.py +0 -0
  84. {bbot-2.3.2.5850rc0 → bbot-2.3.2.5874rc0}/bbot/modules/bypass403.py +0 -0
  85. {bbot-2.3.2.5850rc0 → bbot-2.3.2.5874rc0}/bbot/modules/c99.py +0 -0
  86. {bbot-2.3.2.5850rc0 → bbot-2.3.2.5874rc0}/bbot/modules/censys.py +0 -0
  87. {bbot-2.3.2.5850rc0 → bbot-2.3.2.5874rc0}/bbot/modules/certspotter.py +0 -0
  88. {bbot-2.3.2.5850rc0 → bbot-2.3.2.5874rc0}/bbot/modules/chaos.py +0 -0
  89. {bbot-2.3.2.5850rc0 → bbot-2.3.2.5874rc0}/bbot/modules/code_repository.py +0 -0
  90. {bbot-2.3.2.5850rc0 → bbot-2.3.2.5874rc0}/bbot/modules/credshed.py +0 -0
  91. {bbot-2.3.2.5850rc0 → bbot-2.3.2.5874rc0}/bbot/modules/crt.py +0 -0
  92. {bbot-2.3.2.5850rc0 → bbot-2.3.2.5874rc0}/bbot/modules/deadly/dastardly.py +0 -0
  93. {bbot-2.3.2.5850rc0 → bbot-2.3.2.5874rc0}/bbot/modules/deadly/ffuf.py +0 -0
  94. {bbot-2.3.2.5850rc0 → bbot-2.3.2.5874rc0}/bbot/modules/deadly/nuclei.py +0 -0
  95. {bbot-2.3.2.5850rc0 → bbot-2.3.2.5874rc0}/bbot/modules/deadly/vhost.py +0 -0
  96. {bbot-2.3.2.5850rc0 → bbot-2.3.2.5874rc0}/bbot/modules/dehashed.py +0 -0
  97. {bbot-2.3.2.5850rc0 → bbot-2.3.2.5874rc0}/bbot/modules/digitorus.py +0 -0
  98. {bbot-2.3.2.5850rc0 → bbot-2.3.2.5874rc0}/bbot/modules/dnsbimi.py +0 -0
  99. {bbot-2.3.2.5850rc0 → bbot-2.3.2.5874rc0}/bbot/modules/dnsbrute.py +0 -0
  100. {bbot-2.3.2.5850rc0 → bbot-2.3.2.5874rc0}/bbot/modules/dnsbrute_mutations.py +0 -0
  101. {bbot-2.3.2.5850rc0 → bbot-2.3.2.5874rc0}/bbot/modules/dnscaa.py +0 -0
  102. {bbot-2.3.2.5850rc0 → bbot-2.3.2.5874rc0}/bbot/modules/dnscommonsrv.py +0 -0
  103. {bbot-2.3.2.5850rc0 → bbot-2.3.2.5874rc0}/bbot/modules/dnsdumpster.py +0 -0
  104. {bbot-2.3.2.5850rc0 → bbot-2.3.2.5874rc0}/bbot/modules/dnstlsrpt.py +0 -0
  105. {bbot-2.3.2.5850rc0 → bbot-2.3.2.5874rc0}/bbot/modules/docker_pull.py +0 -0
  106. {bbot-2.3.2.5850rc0 → bbot-2.3.2.5874rc0}/bbot/modules/dockerhub.py +0 -0
  107. {bbot-2.3.2.5850rc0 → bbot-2.3.2.5874rc0}/bbot/modules/dotnetnuke.py +0 -0
  108. {bbot-2.3.2.5850rc0 → bbot-2.3.2.5874rc0}/bbot/modules/emailformat.py +0 -0
  109. {bbot-2.3.2.5850rc0 → bbot-2.3.2.5874rc0}/bbot/modules/extractous.py +0 -0
  110. {bbot-2.3.2.5850rc0 → bbot-2.3.2.5874rc0}/bbot/modules/ffuf_shortnames.py +0 -0
  111. {bbot-2.3.2.5850rc0 → bbot-2.3.2.5874rc0}/bbot/modules/filedownload.py +0 -0
  112. {bbot-2.3.2.5850rc0 → bbot-2.3.2.5874rc0}/bbot/modules/fingerprintx.py +0 -0
  113. {bbot-2.3.2.5850rc0 → bbot-2.3.2.5874rc0}/bbot/modules/fullhunt.py +0 -0
  114. {bbot-2.3.2.5850rc0 → bbot-2.3.2.5874rc0}/bbot/modules/git.py +0 -0
  115. {bbot-2.3.2.5850rc0 → bbot-2.3.2.5874rc0}/bbot/modules/git_clone.py +0 -0
  116. {bbot-2.3.2.5850rc0 → bbot-2.3.2.5874rc0}/bbot/modules/github_codesearch.py +0 -0
  117. {bbot-2.3.2.5850rc0 → bbot-2.3.2.5874rc0}/bbot/modules/github_org.py +0 -0
  118. {bbot-2.3.2.5850rc0 → bbot-2.3.2.5874rc0}/bbot/modules/github_workflows.py +0 -0
  119. {bbot-2.3.2.5850rc0 → bbot-2.3.2.5874rc0}/bbot/modules/gitlab.py +0 -0
  120. {bbot-2.3.2.5850rc0 → bbot-2.3.2.5874rc0}/bbot/modules/google_playstore.py +0 -0
  121. {bbot-2.3.2.5850rc0 → bbot-2.3.2.5874rc0}/bbot/modules/gowitness.py +0 -0
  122. {bbot-2.3.2.5850rc0 → bbot-2.3.2.5874rc0}/bbot/modules/hackertarget.py +0 -0
  123. {bbot-2.3.2.5850rc0 → bbot-2.3.2.5874rc0}/bbot/modules/host_header.py +0 -0
  124. {bbot-2.3.2.5850rc0 → bbot-2.3.2.5874rc0}/bbot/modules/httpx.py +0 -0
  125. {bbot-2.3.2.5850rc0 → bbot-2.3.2.5874rc0}/bbot/modules/hunt.py +0 -0
  126. {bbot-2.3.2.5850rc0 → bbot-2.3.2.5874rc0}/bbot/modules/hunterio.py +0 -0
  127. {bbot-2.3.2.5850rc0 → bbot-2.3.2.5874rc0}/bbot/modules/iis_shortnames.py +0 -0
  128. {bbot-2.3.2.5850rc0 → bbot-2.3.2.5874rc0}/bbot/modules/internal/__init__.py +0 -0
  129. {bbot-2.3.2.5850rc0 → bbot-2.3.2.5874rc0}/bbot/modules/internal/aggregate.py +0 -0
  130. {bbot-2.3.2.5850rc0 → bbot-2.3.2.5874rc0}/bbot/modules/internal/base.py +0 -0
  131. {bbot-2.3.2.5850rc0 → bbot-2.3.2.5874rc0}/bbot/modules/internal/cloudcheck.py +0 -0
  132. {bbot-2.3.2.5850rc0 → bbot-2.3.2.5874rc0}/bbot/modules/internal/dnsresolve.py +0 -0
  133. {bbot-2.3.2.5850rc0 → bbot-2.3.2.5874rc0}/bbot/modules/internal/excavate.py +0 -0
  134. {bbot-2.3.2.5850rc0 → bbot-2.3.2.5874rc0}/bbot/modules/internal/speculate.py +0 -0
  135. {bbot-2.3.2.5850rc0 → bbot-2.3.2.5874rc0}/bbot/modules/internal/unarchive.py +0 -0
  136. {bbot-2.3.2.5850rc0 → bbot-2.3.2.5874rc0}/bbot/modules/internetdb.py +0 -0
  137. {bbot-2.3.2.5850rc0 → bbot-2.3.2.5874rc0}/bbot/modules/ip2location.py +0 -0
  138. {bbot-2.3.2.5850rc0 → bbot-2.3.2.5874rc0}/bbot/modules/ipneighbor.py +0 -0
  139. {bbot-2.3.2.5850rc0 → bbot-2.3.2.5874rc0}/bbot/modules/ipstack.py +0 -0
  140. {bbot-2.3.2.5850rc0 → bbot-2.3.2.5874rc0}/bbot/modules/jadx.py +0 -0
  141. {bbot-2.3.2.5850rc0 → bbot-2.3.2.5874rc0}/bbot/modules/leakix.py +0 -0
  142. {bbot-2.3.2.5850rc0 → bbot-2.3.2.5874rc0}/bbot/modules/myssl.py +0 -0
  143. {bbot-2.3.2.5850rc0 → bbot-2.3.2.5874rc0}/bbot/modules/newsletters.py +0 -0
  144. {bbot-2.3.2.5850rc0 → bbot-2.3.2.5874rc0}/bbot/modules/ntlm.py +0 -0
  145. {bbot-2.3.2.5850rc0 → bbot-2.3.2.5874rc0}/bbot/modules/oauth.py +0 -0
  146. {bbot-2.3.2.5850rc0 → bbot-2.3.2.5874rc0}/bbot/modules/otx.py +0 -0
  147. {bbot-2.3.2.5850rc0 → bbot-2.3.2.5874rc0}/bbot/modules/output/__init__.py +0 -0
  148. {bbot-2.3.2.5850rc0 → bbot-2.3.2.5874rc0}/bbot/modules/output/asset_inventory.py +0 -0
  149. {bbot-2.3.2.5850rc0 → bbot-2.3.2.5874rc0}/bbot/modules/output/base.py +0 -0
  150. {bbot-2.3.2.5850rc0 → bbot-2.3.2.5874rc0}/bbot/modules/output/csv.py +0 -0
  151. {bbot-2.3.2.5850rc0 → bbot-2.3.2.5874rc0}/bbot/modules/output/discord.py +0 -0
  152. {bbot-2.3.2.5850rc0 → bbot-2.3.2.5874rc0}/bbot/modules/output/emails.py +0 -0
  153. {bbot-2.3.2.5850rc0 → bbot-2.3.2.5874rc0}/bbot/modules/output/http.py +0 -0
  154. {bbot-2.3.2.5850rc0 → bbot-2.3.2.5874rc0}/bbot/modules/output/json.py +0 -0
  155. {bbot-2.3.2.5850rc0 → bbot-2.3.2.5874rc0}/bbot/modules/output/mysql.py +0 -0
  156. {bbot-2.3.2.5850rc0 → bbot-2.3.2.5874rc0}/bbot/modules/output/neo4j.py +0 -0
  157. {bbot-2.3.2.5850rc0 → bbot-2.3.2.5874rc0}/bbot/modules/output/nmap_xml.py +0 -0
  158. {bbot-2.3.2.5850rc0 → bbot-2.3.2.5874rc0}/bbot/modules/output/postgres.py +0 -0
  159. {bbot-2.3.2.5850rc0 → bbot-2.3.2.5874rc0}/bbot/modules/output/python.py +0 -0
  160. {bbot-2.3.2.5850rc0 → bbot-2.3.2.5874rc0}/bbot/modules/output/slack.py +0 -0
  161. {bbot-2.3.2.5850rc0 → bbot-2.3.2.5874rc0}/bbot/modules/output/splunk.py +0 -0
  162. {bbot-2.3.2.5850rc0 → bbot-2.3.2.5874rc0}/bbot/modules/output/sqlite.py +0 -0
  163. {bbot-2.3.2.5850rc0 → bbot-2.3.2.5874rc0}/bbot/modules/output/stdout.py +0 -0
  164. {bbot-2.3.2.5850rc0 → bbot-2.3.2.5874rc0}/bbot/modules/output/subdomains.py +0 -0
  165. {bbot-2.3.2.5850rc0 → bbot-2.3.2.5874rc0}/bbot/modules/output/teams.py +0 -0
  166. {bbot-2.3.2.5850rc0 → bbot-2.3.2.5874rc0}/bbot/modules/output/txt.py +0 -0
  167. {bbot-2.3.2.5850rc0 → bbot-2.3.2.5874rc0}/bbot/modules/output/web_parameters.py +0 -0
  168. {bbot-2.3.2.5850rc0 → bbot-2.3.2.5874rc0}/bbot/modules/output/web_report.py +0 -0
  169. {bbot-2.3.2.5850rc0 → bbot-2.3.2.5874rc0}/bbot/modules/output/websocket.py +0 -0
  170. {bbot-2.3.2.5850rc0 → bbot-2.3.2.5874rc0}/bbot/modules/paramminer_cookies.py +0 -0
  171. {bbot-2.3.2.5850rc0 → bbot-2.3.2.5874rc0}/bbot/modules/paramminer_getparams.py +0 -0
  172. {bbot-2.3.2.5850rc0 → bbot-2.3.2.5874rc0}/bbot/modules/paramminer_headers.py +0 -0
  173. {bbot-2.3.2.5850rc0 → bbot-2.3.2.5874rc0}/bbot/modules/passivetotal.py +0 -0
  174. {bbot-2.3.2.5850rc0 → bbot-2.3.2.5874rc0}/bbot/modules/pgp.py +0 -0
  175. {bbot-2.3.2.5850rc0 → bbot-2.3.2.5874rc0}/bbot/modules/portfilter.py +0 -0
  176. {bbot-2.3.2.5850rc0 → bbot-2.3.2.5874rc0}/bbot/modules/portscan.py +0 -0
  177. {bbot-2.3.2.5850rc0 → bbot-2.3.2.5874rc0}/bbot/modules/postman.py +0 -0
  178. {bbot-2.3.2.5850rc0 → bbot-2.3.2.5874rc0}/bbot/modules/postman_download.py +0 -0
  179. {bbot-2.3.2.5850rc0 → bbot-2.3.2.5874rc0}/bbot/modules/rapiddns.py +0 -0
  180. {bbot-2.3.2.5850rc0 → bbot-2.3.2.5874rc0}/bbot/modules/report/affiliates.py +0 -0
  181. {bbot-2.3.2.5850rc0 → bbot-2.3.2.5874rc0}/bbot/modules/report/asn.py +0 -0
  182. {bbot-2.3.2.5850rc0 → bbot-2.3.2.5874rc0}/bbot/modules/report/base.py +0 -0
  183. {bbot-2.3.2.5850rc0 → bbot-2.3.2.5874rc0}/bbot/modules/robots.py +0 -0
  184. {bbot-2.3.2.5850rc0 → bbot-2.3.2.5874rc0}/bbot/modules/securitytrails.py +0 -0
  185. {bbot-2.3.2.5850rc0 → bbot-2.3.2.5874rc0}/bbot/modules/securitytxt.py +0 -0
  186. {bbot-2.3.2.5850rc0 → bbot-2.3.2.5874rc0}/bbot/modules/shodan_dns.py +0 -0
  187. {bbot-2.3.2.5850rc0 → bbot-2.3.2.5874rc0}/bbot/modules/sitedossier.py +0 -0
  188. {bbot-2.3.2.5850rc0 → bbot-2.3.2.5874rc0}/bbot/modules/skymem.py +0 -0
  189. {bbot-2.3.2.5850rc0 → bbot-2.3.2.5874rc0}/bbot/modules/smuggler.py +0 -0
  190. {bbot-2.3.2.5850rc0 → bbot-2.3.2.5874rc0}/bbot/modules/social.py +0 -0
  191. {bbot-2.3.2.5850rc0 → bbot-2.3.2.5874rc0}/bbot/modules/sslcert.py +0 -0
  192. {bbot-2.3.2.5850rc0 → bbot-2.3.2.5874rc0}/bbot/modules/subdomaincenter.py +0 -0
  193. {bbot-2.3.2.5850rc0 → bbot-2.3.2.5874rc0}/bbot/modules/subdomainradar.py +0 -0
  194. {bbot-2.3.2.5850rc0 → bbot-2.3.2.5874rc0}/bbot/modules/telerik.py +0 -0
  195. {bbot-2.3.2.5850rc0 → bbot-2.3.2.5874rc0}/bbot/modules/templates/bucket.py +0 -0
  196. {bbot-2.3.2.5850rc0 → bbot-2.3.2.5874rc0}/bbot/modules/templates/github.py +0 -0
  197. {bbot-2.3.2.5850rc0 → bbot-2.3.2.5874rc0}/bbot/modules/templates/postman.py +0 -0
  198. {bbot-2.3.2.5850rc0 → bbot-2.3.2.5874rc0}/bbot/modules/templates/shodan.py +0 -0
  199. {bbot-2.3.2.5850rc0 → bbot-2.3.2.5874rc0}/bbot/modules/templates/sql.py +0 -0
  200. {bbot-2.3.2.5850rc0 → bbot-2.3.2.5874rc0}/bbot/modules/templates/subdomain_enum.py +0 -0
  201. {bbot-2.3.2.5850rc0 → bbot-2.3.2.5874rc0}/bbot/modules/templates/webhook.py +0 -0
  202. {bbot-2.3.2.5850rc0 → bbot-2.3.2.5874rc0}/bbot/modules/trickest.py +0 -0
  203. {bbot-2.3.2.5850rc0 → bbot-2.3.2.5874rc0}/bbot/modules/trufflehog.py +0 -0
  204. {bbot-2.3.2.5850rc0 → bbot-2.3.2.5874rc0}/bbot/modules/url_manipulation.py +0 -0
  205. {bbot-2.3.2.5850rc0 → bbot-2.3.2.5874rc0}/bbot/modules/urlscan.py +0 -0
  206. {bbot-2.3.2.5850rc0 → bbot-2.3.2.5874rc0}/bbot/modules/viewdns.py +0 -0
  207. {bbot-2.3.2.5850rc0 → bbot-2.3.2.5874rc0}/bbot/modules/virustotal.py +0 -0
  208. {bbot-2.3.2.5850rc0 → bbot-2.3.2.5874rc0}/bbot/modules/wafw00f.py +0 -0
  209. {bbot-2.3.2.5850rc0 → bbot-2.3.2.5874rc0}/bbot/modules/wappalyzer.py +0 -0
  210. {bbot-2.3.2.5850rc0 → bbot-2.3.2.5874rc0}/bbot/modules/wayback.py +0 -0
  211. {bbot-2.3.2.5850rc0 → bbot-2.3.2.5874rc0}/bbot/modules/wpscan.py +0 -0
  212. {bbot-2.3.2.5850rc0 → bbot-2.3.2.5874rc0}/bbot/modules/zoomeye.py +0 -0
  213. {bbot-2.3.2.5850rc0 → bbot-2.3.2.5874rc0}/bbot/presets/baddns-intense.yml +0 -0
  214. {bbot-2.3.2.5850rc0 → bbot-2.3.2.5874rc0}/bbot/presets/cloud-enum.yml +0 -0
  215. {bbot-2.3.2.5850rc0 → bbot-2.3.2.5874rc0}/bbot/presets/code-enum.yml +0 -0
  216. {bbot-2.3.2.5850rc0 → bbot-2.3.2.5874rc0}/bbot/presets/email-enum.yml +0 -0
  217. {bbot-2.3.2.5850rc0 → bbot-2.3.2.5874rc0}/bbot/presets/fast.yml +0 -0
  218. {bbot-2.3.2.5850rc0 → bbot-2.3.2.5874rc0}/bbot/presets/kitchen-sink.yml +0 -0
  219. {bbot-2.3.2.5850rc0 → bbot-2.3.2.5874rc0}/bbot/presets/nuclei/nuclei-budget.yml +0 -0
  220. {bbot-2.3.2.5850rc0 → bbot-2.3.2.5874rc0}/bbot/presets/nuclei/nuclei-intense.yml +0 -0
  221. {bbot-2.3.2.5850rc0 → bbot-2.3.2.5874rc0}/bbot/presets/nuclei/nuclei-technology.yml +0 -0
  222. {bbot-2.3.2.5850rc0 → bbot-2.3.2.5874rc0}/bbot/presets/nuclei/nuclei.yml +0 -0
  223. {bbot-2.3.2.5850rc0 → bbot-2.3.2.5874rc0}/bbot/presets/spider-intense.yml +0 -0
  224. {bbot-2.3.2.5850rc0 → bbot-2.3.2.5874rc0}/bbot/presets/spider.yml +0 -0
  225. {bbot-2.3.2.5850rc0 → bbot-2.3.2.5874rc0}/bbot/presets/subdomain-enum.yml +0 -0
  226. {bbot-2.3.2.5850rc0 → bbot-2.3.2.5874rc0}/bbot/presets/tech-detect.yml +0 -0
  227. {bbot-2.3.2.5850rc0 → bbot-2.3.2.5874rc0}/bbot/presets/web/dirbust-heavy.yml +0 -0
  228. {bbot-2.3.2.5850rc0 → bbot-2.3.2.5874rc0}/bbot/presets/web/dirbust-light.yml +0 -0
  229. {bbot-2.3.2.5850rc0 → bbot-2.3.2.5874rc0}/bbot/presets/web/dotnet-audit.yml +0 -0
  230. {bbot-2.3.2.5850rc0 → bbot-2.3.2.5874rc0}/bbot/presets/web/iis-shortnames.yml +0 -0
  231. {bbot-2.3.2.5850rc0 → bbot-2.3.2.5874rc0}/bbot/presets/web/paramminer.yml +0 -0
  232. {bbot-2.3.2.5850rc0 → bbot-2.3.2.5874rc0}/bbot/presets/web-basic.yml +0 -0
  233. {bbot-2.3.2.5850rc0 → bbot-2.3.2.5874rc0}/bbot/presets/web-screenshots.yml +0 -0
  234. {bbot-2.3.2.5850rc0 → bbot-2.3.2.5874rc0}/bbot/presets/web-thorough.yml +0 -0
  235. {bbot-2.3.2.5850rc0 → bbot-2.3.2.5874rc0}/bbot/scanner/__init__.py +0 -0
  236. {bbot-2.3.2.5850rc0 → bbot-2.3.2.5874rc0}/bbot/scanner/dispatcher.py +0 -0
  237. {bbot-2.3.2.5850rc0 → bbot-2.3.2.5874rc0}/bbot/scanner/manager.py +0 -0
  238. {bbot-2.3.2.5850rc0 → bbot-2.3.2.5874rc0}/bbot/scanner/preset/__init__.py +0 -0
  239. {bbot-2.3.2.5850rc0 → bbot-2.3.2.5874rc0}/bbot/scanner/preset/args.py +0 -0
  240. {bbot-2.3.2.5850rc0 → bbot-2.3.2.5874rc0}/bbot/scanner/preset/conditions.py +0 -0
  241. {bbot-2.3.2.5850rc0 → bbot-2.3.2.5874rc0}/bbot/scanner/preset/environ.py +0 -0
  242. {bbot-2.3.2.5850rc0 → bbot-2.3.2.5874rc0}/bbot/scanner/preset/path.py +0 -0
  243. {bbot-2.3.2.5850rc0 → bbot-2.3.2.5874rc0}/bbot/scanner/preset/preset.py +0 -0
  244. {bbot-2.3.2.5850rc0 → bbot-2.3.2.5874rc0}/bbot/scanner/scanner.py +0 -0
  245. {bbot-2.3.2.5850rc0 → bbot-2.3.2.5874rc0}/bbot/scanner/stats.py +0 -0
  246. {bbot-2.3.2.5850rc0 → bbot-2.3.2.5874rc0}/bbot/scanner/target.py +0 -0
  247. {bbot-2.3.2.5850rc0 → bbot-2.3.2.5874rc0}/bbot/scripts/docs.py +0 -0
  248. {bbot-2.3.2.5850rc0 → bbot-2.3.2.5874rc0}/bbot/test/__init__.py +0 -0
  249. {bbot-2.3.2.5850rc0 → bbot-2.3.2.5874rc0}/bbot/test/bbot_fixtures.py +0 -0
  250. {bbot-2.3.2.5850rc0 → bbot-2.3.2.5874rc0}/bbot/test/coverage.cfg +0 -0
  251. {bbot-2.3.2.5850rc0 → bbot-2.3.2.5874rc0}/bbot/test/fastapi_test.py +0 -0
  252. {bbot-2.3.2.5850rc0 → bbot-2.3.2.5874rc0}/bbot/test/owasp_mastg.apk +0 -0
  253. {bbot-2.3.2.5850rc0 → bbot-2.3.2.5874rc0}/bbot/test/run_tests.sh +0 -0
  254. {bbot-2.3.2.5850rc0 → bbot-2.3.2.5874rc0}/bbot/test/test.conf +0 -0
  255. {bbot-2.3.2.5850rc0 → bbot-2.3.2.5874rc0}/bbot/test/test_output.ndjson +0 -0
  256. {bbot-2.3.2.5850rc0 → bbot-2.3.2.5874rc0}/bbot/test/test_step_1/__init__.py +0 -0
  257. {bbot-2.3.2.5850rc0 → bbot-2.3.2.5874rc0}/bbot/test/test_step_1/test__module__tests.py +0 -0
  258. {bbot-2.3.2.5850rc0 → bbot-2.3.2.5874rc0}/bbot/test/test_step_1/test_bbot_fastapi.py +0 -0
  259. {bbot-2.3.2.5850rc0 → bbot-2.3.2.5874rc0}/bbot/test/test_step_1/test_bloom_filter.py +0 -0
  260. {bbot-2.3.2.5850rc0 → bbot-2.3.2.5874rc0}/bbot/test/test_step_1/test_cli.py +0 -0
  261. {bbot-2.3.2.5850rc0 → bbot-2.3.2.5874rc0}/bbot/test/test_step_1/test_command.py +0 -0
  262. {bbot-2.3.2.5850rc0 → bbot-2.3.2.5874rc0}/bbot/test/test_step_1/test_config.py +0 -0
  263. {bbot-2.3.2.5850rc0 → bbot-2.3.2.5874rc0}/bbot/test/test_step_1/test_depsinstaller.py +0 -0
  264. {bbot-2.3.2.5850rc0 → bbot-2.3.2.5874rc0}/bbot/test/test_step_1/test_dns.py +0 -0
  265. {bbot-2.3.2.5850rc0 → bbot-2.3.2.5874rc0}/bbot/test/test_step_1/test_docs.py +0 -0
  266. {bbot-2.3.2.5850rc0 → bbot-2.3.2.5874rc0}/bbot/test/test_step_1/test_engine.py +0 -0
  267. {bbot-2.3.2.5850rc0 → bbot-2.3.2.5874rc0}/bbot/test/test_step_1/test_events.py +0 -0
  268. {bbot-2.3.2.5850rc0 → bbot-2.3.2.5874rc0}/bbot/test/test_step_1/test_files.py +0 -0
  269. {bbot-2.3.2.5850rc0 → bbot-2.3.2.5874rc0}/bbot/test/test_step_1/test_helpers.py +0 -0
  270. {bbot-2.3.2.5850rc0 → bbot-2.3.2.5874rc0}/bbot/test/test_step_1/test_manager_deduplication.py +0 -0
  271. {bbot-2.3.2.5850rc0 → bbot-2.3.2.5874rc0}/bbot/test/test_step_1/test_manager_scope_accuracy.py +0 -0
  272. {bbot-2.3.2.5850rc0 → bbot-2.3.2.5874rc0}/bbot/test/test_step_1/test_modules_basic.py +0 -0
  273. {bbot-2.3.2.5850rc0 → bbot-2.3.2.5874rc0}/bbot/test/test_step_1/test_presets.py +0 -0
  274. {bbot-2.3.2.5850rc0 → bbot-2.3.2.5874rc0}/bbot/test/test_step_1/test_python_api.py +0 -0
  275. {bbot-2.3.2.5850rc0 → bbot-2.3.2.5874rc0}/bbot/test/test_step_1/test_regexes.py +0 -0
  276. {bbot-2.3.2.5850rc0 → bbot-2.3.2.5874rc0}/bbot/test/test_step_1/test_scan.py +0 -0
  277. {bbot-2.3.2.5850rc0 → bbot-2.3.2.5874rc0}/bbot/test/test_step_1/test_scope.py +0 -0
  278. {bbot-2.3.2.5850rc0 → bbot-2.3.2.5874rc0}/bbot/test/test_step_1/test_target.py +0 -0
  279. {bbot-2.3.2.5850rc0 → bbot-2.3.2.5874rc0}/bbot/test/test_step_1/test_web.py +0 -0
  280. {bbot-2.3.2.5850rc0 → bbot-2.3.2.5874rc0}/bbot/test/test_step_2/__init__.py +0 -0
  281. {bbot-2.3.2.5850rc0 → bbot-2.3.2.5874rc0}/bbot/test/test_step_2/module_tests/__init__.py +0 -0
  282. {bbot-2.3.2.5850rc0 → bbot-2.3.2.5874rc0}/bbot/test/test_step_2/module_tests/base.py +0 -0
  283. {bbot-2.3.2.5850rc0 → bbot-2.3.2.5874rc0}/bbot/test/test_step_2/module_tests/test_module_affiliates.py +0 -0
  284. {bbot-2.3.2.5850rc0 → bbot-2.3.2.5874rc0}/bbot/test/test_step_2/module_tests/test_module_aggregate.py +0 -0
  285. {bbot-2.3.2.5850rc0 → bbot-2.3.2.5874rc0}/bbot/test/test_step_2/module_tests/test_module_ajaxpro.py +0 -0
  286. {bbot-2.3.2.5850rc0 → bbot-2.3.2.5874rc0}/bbot/test/test_step_2/module_tests/test_module_anubisdb.py +0 -0
  287. {bbot-2.3.2.5850rc0 → bbot-2.3.2.5874rc0}/bbot/test/test_step_2/module_tests/test_module_apkpure.py +0 -0
  288. {bbot-2.3.2.5850rc0 → bbot-2.3.2.5874rc0}/bbot/test/test_step_2/module_tests/test_module_asn.py +0 -0
  289. {bbot-2.3.2.5850rc0 → bbot-2.3.2.5874rc0}/bbot/test/test_step_2/module_tests/test_module_asset_inventory.py +0 -0
  290. {bbot-2.3.2.5850rc0 → bbot-2.3.2.5874rc0}/bbot/test/test_step_2/module_tests/test_module_azure_realm.py +0 -0
  291. {bbot-2.3.2.5850rc0 → bbot-2.3.2.5874rc0}/bbot/test/test_step_2/module_tests/test_module_azure_tenant.py +0 -0
  292. {bbot-2.3.2.5850rc0 → bbot-2.3.2.5874rc0}/bbot/test/test_step_2/module_tests/test_module_baddns.py +0 -0
  293. {bbot-2.3.2.5850rc0 → bbot-2.3.2.5874rc0}/bbot/test/test_step_2/module_tests/test_module_baddns_direct.py +0 -0
  294. {bbot-2.3.2.5850rc0 → bbot-2.3.2.5874rc0}/bbot/test/test_step_2/module_tests/test_module_baddns_zone.py +0 -0
  295. {bbot-2.3.2.5850rc0 → bbot-2.3.2.5874rc0}/bbot/test/test_step_2/module_tests/test_module_badsecrets.py +0 -0
  296. {bbot-2.3.2.5850rc0 → bbot-2.3.2.5874rc0}/bbot/test/test_step_2/module_tests/test_module_bevigil.py +0 -0
  297. {bbot-2.3.2.5850rc0 → bbot-2.3.2.5874rc0}/bbot/test/test_step_2/module_tests/test_module_binaryedge.py +0 -0
  298. {bbot-2.3.2.5850rc0 → bbot-2.3.2.5874rc0}/bbot/test/test_step_2/module_tests/test_module_bucket_amazon.py +0 -0
  299. {bbot-2.3.2.5850rc0 → bbot-2.3.2.5874rc0}/bbot/test/test_step_2/module_tests/test_module_bucket_azure.py +0 -0
  300. {bbot-2.3.2.5850rc0 → bbot-2.3.2.5874rc0}/bbot/test/test_step_2/module_tests/test_module_bucket_digitalocean.py +0 -0
  301. {bbot-2.3.2.5850rc0 → bbot-2.3.2.5874rc0}/bbot/test/test_step_2/module_tests/test_module_bucket_file_enum.py +0 -0
  302. {bbot-2.3.2.5850rc0 → bbot-2.3.2.5874rc0}/bbot/test/test_step_2/module_tests/test_module_bucket_firebase.py +0 -0
  303. {bbot-2.3.2.5850rc0 → bbot-2.3.2.5874rc0}/bbot/test/test_step_2/module_tests/test_module_bucket_google.py +0 -0
  304. {bbot-2.3.2.5850rc0 → bbot-2.3.2.5874rc0}/bbot/test/test_step_2/module_tests/test_module_bufferoverrun.py +0 -0
  305. {bbot-2.3.2.5850rc0 → bbot-2.3.2.5874rc0}/bbot/test/test_step_2/module_tests/test_module_builtwith.py +0 -0
  306. {bbot-2.3.2.5850rc0 → bbot-2.3.2.5874rc0}/bbot/test/test_step_2/module_tests/test_module_bypass403.py +0 -0
  307. {bbot-2.3.2.5850rc0 → bbot-2.3.2.5874rc0}/bbot/test/test_step_2/module_tests/test_module_c99.py +0 -0
  308. {bbot-2.3.2.5850rc0 → bbot-2.3.2.5874rc0}/bbot/test/test_step_2/module_tests/test_module_censys.py +0 -0
  309. {bbot-2.3.2.5850rc0 → bbot-2.3.2.5874rc0}/bbot/test/test_step_2/module_tests/test_module_certspotter.py +0 -0
  310. {bbot-2.3.2.5850rc0 → bbot-2.3.2.5874rc0}/bbot/test/test_step_2/module_tests/test_module_chaos.py +0 -0
  311. {bbot-2.3.2.5850rc0 → bbot-2.3.2.5874rc0}/bbot/test/test_step_2/module_tests/test_module_cloudcheck.py +0 -0
  312. {bbot-2.3.2.5850rc0 → bbot-2.3.2.5874rc0}/bbot/test/test_step_2/module_tests/test_module_code_repository.py +0 -0
  313. {bbot-2.3.2.5850rc0 → bbot-2.3.2.5874rc0}/bbot/test/test_step_2/module_tests/test_module_credshed.py +0 -0
  314. {bbot-2.3.2.5850rc0 → bbot-2.3.2.5874rc0}/bbot/test/test_step_2/module_tests/test_module_crt.py +0 -0
  315. {bbot-2.3.2.5850rc0 → bbot-2.3.2.5874rc0}/bbot/test/test_step_2/module_tests/test_module_csv.py +0 -0
  316. {bbot-2.3.2.5850rc0 → bbot-2.3.2.5874rc0}/bbot/test/test_step_2/module_tests/test_module_dastardly.py +0 -0
  317. {bbot-2.3.2.5850rc0 → bbot-2.3.2.5874rc0}/bbot/test/test_step_2/module_tests/test_module_dehashed.py +0 -0
  318. {bbot-2.3.2.5850rc0 → bbot-2.3.2.5874rc0}/bbot/test/test_step_2/module_tests/test_module_digitorus.py +0 -0
  319. {bbot-2.3.2.5850rc0 → bbot-2.3.2.5874rc0}/bbot/test/test_step_2/module_tests/test_module_discord.py +0 -0
  320. {bbot-2.3.2.5850rc0 → bbot-2.3.2.5874rc0}/bbot/test/test_step_2/module_tests/test_module_dnsbimi.py +0 -0
  321. {bbot-2.3.2.5850rc0 → bbot-2.3.2.5874rc0}/bbot/test/test_step_2/module_tests/test_module_dnsbrute.py +0 -0
  322. {bbot-2.3.2.5850rc0 → bbot-2.3.2.5874rc0}/bbot/test/test_step_2/module_tests/test_module_dnsbrute_mutations.py +0 -0
  323. {bbot-2.3.2.5850rc0 → bbot-2.3.2.5874rc0}/bbot/test/test_step_2/module_tests/test_module_dnscaa.py +0 -0
  324. {bbot-2.3.2.5850rc0 → bbot-2.3.2.5874rc0}/bbot/test/test_step_2/module_tests/test_module_dnscommonsrv.py +0 -0
  325. {bbot-2.3.2.5850rc0 → bbot-2.3.2.5874rc0}/bbot/test/test_step_2/module_tests/test_module_dnsdumpster.py +0 -0
  326. {bbot-2.3.2.5850rc0 → bbot-2.3.2.5874rc0}/bbot/test/test_step_2/module_tests/test_module_dnsresolve.py +0 -0
  327. {bbot-2.3.2.5850rc0 → bbot-2.3.2.5874rc0}/bbot/test/test_step_2/module_tests/test_module_dnstlsrpt.py +0 -0
  328. {bbot-2.3.2.5850rc0 → bbot-2.3.2.5874rc0}/bbot/test/test_step_2/module_tests/test_module_docker_pull.py +0 -0
  329. {bbot-2.3.2.5850rc0 → bbot-2.3.2.5874rc0}/bbot/test/test_step_2/module_tests/test_module_dockerhub.py +0 -0
  330. {bbot-2.3.2.5850rc0 → bbot-2.3.2.5874rc0}/bbot/test/test_step_2/module_tests/test_module_emailformat.py +0 -0
  331. {bbot-2.3.2.5850rc0 → bbot-2.3.2.5874rc0}/bbot/test/test_step_2/module_tests/test_module_emails.py +0 -0
  332. {bbot-2.3.2.5850rc0 → bbot-2.3.2.5874rc0}/bbot/test/test_step_2/module_tests/test_module_excavate.py +0 -0
  333. {bbot-2.3.2.5850rc0 → bbot-2.3.2.5874rc0}/bbot/test/test_step_2/module_tests/test_module_extractous.py +0 -0
  334. {bbot-2.3.2.5850rc0 → bbot-2.3.2.5874rc0}/bbot/test/test_step_2/module_tests/test_module_ffuf.py +0 -0
  335. {bbot-2.3.2.5850rc0 → bbot-2.3.2.5874rc0}/bbot/test/test_step_2/module_tests/test_module_ffuf_shortnames.py +0 -0
  336. {bbot-2.3.2.5850rc0 → bbot-2.3.2.5874rc0}/bbot/test/test_step_2/module_tests/test_module_filedownload.py +0 -0
  337. {bbot-2.3.2.5850rc0 → bbot-2.3.2.5874rc0}/bbot/test/test_step_2/module_tests/test_module_fingerprintx.py +0 -0
  338. {bbot-2.3.2.5850rc0 → bbot-2.3.2.5874rc0}/bbot/test/test_step_2/module_tests/test_module_fullhunt.py +0 -0
  339. {bbot-2.3.2.5850rc0 → bbot-2.3.2.5874rc0}/bbot/test/test_step_2/module_tests/test_module_git.py +0 -0
  340. {bbot-2.3.2.5850rc0 → bbot-2.3.2.5874rc0}/bbot/test/test_step_2/module_tests/test_module_git_clone.py +0 -0
  341. {bbot-2.3.2.5850rc0 → bbot-2.3.2.5874rc0}/bbot/test/test_step_2/module_tests/test_module_github_codesearch.py +0 -0
  342. {bbot-2.3.2.5850rc0 → bbot-2.3.2.5874rc0}/bbot/test/test_step_2/module_tests/test_module_github_org.py +0 -0
  343. {bbot-2.3.2.5850rc0 → bbot-2.3.2.5874rc0}/bbot/test/test_step_2/module_tests/test_module_github_workflows.py +0 -0
  344. {bbot-2.3.2.5850rc0 → bbot-2.3.2.5874rc0}/bbot/test/test_step_2/module_tests/test_module_gitlab.py +0 -0
  345. {bbot-2.3.2.5850rc0 → bbot-2.3.2.5874rc0}/bbot/test/test_step_2/module_tests/test_module_google_playstore.py +0 -0
  346. {bbot-2.3.2.5850rc0 → bbot-2.3.2.5874rc0}/bbot/test/test_step_2/module_tests/test_module_gowitness.py +0 -0
  347. {bbot-2.3.2.5850rc0 → bbot-2.3.2.5874rc0}/bbot/test/test_step_2/module_tests/test_module_hackertarget.py +0 -0
  348. {bbot-2.3.2.5850rc0 → bbot-2.3.2.5874rc0}/bbot/test/test_step_2/module_tests/test_module_http.py +0 -0
  349. {bbot-2.3.2.5850rc0 → bbot-2.3.2.5874rc0}/bbot/test/test_step_2/module_tests/test_module_httpx.py +0 -0
  350. {bbot-2.3.2.5850rc0 → bbot-2.3.2.5874rc0}/bbot/test/test_step_2/module_tests/test_module_hunt.py +0 -0
  351. {bbot-2.3.2.5850rc0 → bbot-2.3.2.5874rc0}/bbot/test/test_step_2/module_tests/test_module_hunterio.py +0 -0
  352. {bbot-2.3.2.5850rc0 → bbot-2.3.2.5874rc0}/bbot/test/test_step_2/module_tests/test_module_iis_shortnames.py +0 -0
  353. {bbot-2.3.2.5850rc0 → bbot-2.3.2.5874rc0}/bbot/test/test_step_2/module_tests/test_module_internetdb.py +0 -0
  354. {bbot-2.3.2.5850rc0 → bbot-2.3.2.5874rc0}/bbot/test/test_step_2/module_tests/test_module_ip2location.py +0 -0
  355. {bbot-2.3.2.5850rc0 → bbot-2.3.2.5874rc0}/bbot/test/test_step_2/module_tests/test_module_ipneighbor.py +0 -0
  356. {bbot-2.3.2.5850rc0 → bbot-2.3.2.5874rc0}/bbot/test/test_step_2/module_tests/test_module_ipstack.py +0 -0
  357. {bbot-2.3.2.5850rc0 → bbot-2.3.2.5874rc0}/bbot/test/test_step_2/module_tests/test_module_jadx.py +0 -0
  358. {bbot-2.3.2.5850rc0 → bbot-2.3.2.5874rc0}/bbot/test/test_step_2/module_tests/test_module_json.py +0 -0
  359. {bbot-2.3.2.5850rc0 → bbot-2.3.2.5874rc0}/bbot/test/test_step_2/module_tests/test_module_leakix.py +0 -0
  360. {bbot-2.3.2.5850rc0 → bbot-2.3.2.5874rc0}/bbot/test/test_step_2/module_tests/test_module_mysql.py +0 -0
  361. {bbot-2.3.2.5850rc0 → bbot-2.3.2.5874rc0}/bbot/test/test_step_2/module_tests/test_module_myssl.py +0 -0
  362. {bbot-2.3.2.5850rc0 → bbot-2.3.2.5874rc0}/bbot/test/test_step_2/module_tests/test_module_neo4j.py +0 -0
  363. {bbot-2.3.2.5850rc0 → bbot-2.3.2.5874rc0}/bbot/test/test_step_2/module_tests/test_module_newsletters.py +0 -0
  364. {bbot-2.3.2.5850rc0 → bbot-2.3.2.5874rc0}/bbot/test/test_step_2/module_tests/test_module_nmap_xml.py +0 -0
  365. {bbot-2.3.2.5850rc0 → bbot-2.3.2.5874rc0}/bbot/test/test_step_2/module_tests/test_module_ntlm.py +0 -0
  366. {bbot-2.3.2.5850rc0 → bbot-2.3.2.5874rc0}/bbot/test/test_step_2/module_tests/test_module_nuclei.py +0 -0
  367. {bbot-2.3.2.5850rc0 → bbot-2.3.2.5874rc0}/bbot/test/test_step_2/module_tests/test_module_oauth.py +0 -0
  368. {bbot-2.3.2.5850rc0 → bbot-2.3.2.5874rc0}/bbot/test/test_step_2/module_tests/test_module_otx.py +0 -0
  369. {bbot-2.3.2.5850rc0 → bbot-2.3.2.5874rc0}/bbot/test/test_step_2/module_tests/test_module_paramminer_cookies.py +0 -0
  370. {bbot-2.3.2.5850rc0 → bbot-2.3.2.5874rc0}/bbot/test/test_step_2/module_tests/test_module_paramminer_getparams.py +0 -0
  371. {bbot-2.3.2.5850rc0 → bbot-2.3.2.5874rc0}/bbot/test/test_step_2/module_tests/test_module_paramminer_headers.py +0 -0
  372. {bbot-2.3.2.5850rc0 → bbot-2.3.2.5874rc0}/bbot/test/test_step_2/module_tests/test_module_passivetotal.py +0 -0
  373. {bbot-2.3.2.5850rc0 → bbot-2.3.2.5874rc0}/bbot/test/test_step_2/module_tests/test_module_pgp.py +0 -0
  374. {bbot-2.3.2.5850rc0 → bbot-2.3.2.5874rc0}/bbot/test/test_step_2/module_tests/test_module_portfilter.py +0 -0
  375. {bbot-2.3.2.5850rc0 → bbot-2.3.2.5874rc0}/bbot/test/test_step_2/module_tests/test_module_portscan.py +0 -0
  376. {bbot-2.3.2.5850rc0 → bbot-2.3.2.5874rc0}/bbot/test/test_step_2/module_tests/test_module_postgres.py +0 -0
  377. {bbot-2.3.2.5850rc0 → bbot-2.3.2.5874rc0}/bbot/test/test_step_2/module_tests/test_module_postman.py +0 -0
  378. {bbot-2.3.2.5850rc0 → bbot-2.3.2.5874rc0}/bbot/test/test_step_2/module_tests/test_module_postman_download.py +0 -0
  379. {bbot-2.3.2.5850rc0 → bbot-2.3.2.5874rc0}/bbot/test/test_step_2/module_tests/test_module_python.py +0 -0
  380. {bbot-2.3.2.5850rc0 → bbot-2.3.2.5874rc0}/bbot/test/test_step_2/module_tests/test_module_rapiddns.py +0 -0
  381. {bbot-2.3.2.5850rc0 → bbot-2.3.2.5874rc0}/bbot/test/test_step_2/module_tests/test_module_robots.py +0 -0
  382. {bbot-2.3.2.5850rc0 → bbot-2.3.2.5874rc0}/bbot/test/test_step_2/module_tests/test_module_securitytrails.py +0 -0
  383. {bbot-2.3.2.5850rc0 → bbot-2.3.2.5874rc0}/bbot/test/test_step_2/module_tests/test_module_securitytxt.py +0 -0
  384. {bbot-2.3.2.5850rc0 → bbot-2.3.2.5874rc0}/bbot/test/test_step_2/module_tests/test_module_shodan_dns.py +0 -0
  385. {bbot-2.3.2.5850rc0 → bbot-2.3.2.5874rc0}/bbot/test/test_step_2/module_tests/test_module_sitedossier.py +0 -0
  386. {bbot-2.3.2.5850rc0 → bbot-2.3.2.5874rc0}/bbot/test/test_step_2/module_tests/test_module_skymem.py +0 -0
  387. {bbot-2.3.2.5850rc0 → bbot-2.3.2.5874rc0}/bbot/test/test_step_2/module_tests/test_module_slack.py +0 -0
  388. {bbot-2.3.2.5850rc0 → bbot-2.3.2.5874rc0}/bbot/test/test_step_2/module_tests/test_module_smuggler.py +0 -0
  389. {bbot-2.3.2.5850rc0 → bbot-2.3.2.5874rc0}/bbot/test/test_step_2/module_tests/test_module_social.py +0 -0
  390. {bbot-2.3.2.5850rc0 → bbot-2.3.2.5874rc0}/bbot/test/test_step_2/module_tests/test_module_speculate.py +0 -0
  391. {bbot-2.3.2.5850rc0 → bbot-2.3.2.5874rc0}/bbot/test/test_step_2/module_tests/test_module_splunk.py +0 -0
  392. {bbot-2.3.2.5850rc0 → bbot-2.3.2.5874rc0}/bbot/test/test_step_2/module_tests/test_module_sqlite.py +0 -0
  393. {bbot-2.3.2.5850rc0 → bbot-2.3.2.5874rc0}/bbot/test/test_step_2/module_tests/test_module_sslcert.py +0 -0
  394. {bbot-2.3.2.5850rc0 → bbot-2.3.2.5874rc0}/bbot/test/test_step_2/module_tests/test_module_stdout.py +0 -0
  395. {bbot-2.3.2.5850rc0 → bbot-2.3.2.5874rc0}/bbot/test/test_step_2/module_tests/test_module_subdomaincenter.py +0 -0
  396. {bbot-2.3.2.5850rc0 → bbot-2.3.2.5874rc0}/bbot/test/test_step_2/module_tests/test_module_subdomainradar.py +0 -0
  397. {bbot-2.3.2.5850rc0 → bbot-2.3.2.5874rc0}/bbot/test/test_step_2/module_tests/test_module_subdomains.py +0 -0
  398. {bbot-2.3.2.5850rc0 → bbot-2.3.2.5874rc0}/bbot/test/test_step_2/module_tests/test_module_teams.py +0 -0
  399. {bbot-2.3.2.5850rc0 → bbot-2.3.2.5874rc0}/bbot/test/test_step_2/module_tests/test_module_telerik.py +0 -0
  400. {bbot-2.3.2.5850rc0 → bbot-2.3.2.5874rc0}/bbot/test/test_step_2/module_tests/test_module_trickest.py +0 -0
  401. {bbot-2.3.2.5850rc0 → bbot-2.3.2.5874rc0}/bbot/test/test_step_2/module_tests/test_module_trufflehog.py +0 -0
  402. {bbot-2.3.2.5850rc0 → bbot-2.3.2.5874rc0}/bbot/test/test_step_2/module_tests/test_module_txt.py +0 -0
  403. {bbot-2.3.2.5850rc0 → bbot-2.3.2.5874rc0}/bbot/test/test_step_2/module_tests/test_module_unarchive.py +0 -0
  404. {bbot-2.3.2.5850rc0 → bbot-2.3.2.5874rc0}/bbot/test/test_step_2/module_tests/test_module_url_manipulation.py +0 -0
  405. {bbot-2.3.2.5850rc0 → bbot-2.3.2.5874rc0}/bbot/test/test_step_2/module_tests/test_module_urlscan.py +0 -0
  406. {bbot-2.3.2.5850rc0 → bbot-2.3.2.5874rc0}/bbot/test/test_step_2/module_tests/test_module_vhost.py +0 -0
  407. {bbot-2.3.2.5850rc0 → bbot-2.3.2.5874rc0}/bbot/test/test_step_2/module_tests/test_module_viewdns.py +0 -0
  408. {bbot-2.3.2.5850rc0 → bbot-2.3.2.5874rc0}/bbot/test/test_step_2/module_tests/test_module_virustotal.py +0 -0
  409. {bbot-2.3.2.5850rc0 → bbot-2.3.2.5874rc0}/bbot/test/test_step_2/module_tests/test_module_wafw00f.py +0 -0
  410. {bbot-2.3.2.5850rc0 → bbot-2.3.2.5874rc0}/bbot/test/test_step_2/module_tests/test_module_wappalyzer.py +0 -0
  411. {bbot-2.3.2.5850rc0 → bbot-2.3.2.5874rc0}/bbot/test/test_step_2/module_tests/test_module_wayback.py +0 -0
  412. {bbot-2.3.2.5850rc0 → bbot-2.3.2.5874rc0}/bbot/test/test_step_2/module_tests/test_module_web_parameters.py +0 -0
  413. {bbot-2.3.2.5850rc0 → bbot-2.3.2.5874rc0}/bbot/test/test_step_2/module_tests/test_module_web_report.py +0 -0
  414. {bbot-2.3.2.5850rc0 → bbot-2.3.2.5874rc0}/bbot/test/test_step_2/module_tests/test_module_websocket.py +0 -0
  415. {bbot-2.3.2.5850rc0 → bbot-2.3.2.5874rc0}/bbot/test/test_step_2/module_tests/test_module_wpscan.py +0 -0
  416. {bbot-2.3.2.5850rc0 → bbot-2.3.2.5874rc0}/bbot/test/test_step_2/module_tests/test_module_zoomeye.py +0 -0
  417. {bbot-2.3.2.5850rc0 → bbot-2.3.2.5874rc0}/bbot/test/test_step_2/template_tests/__init__.py +0 -0
  418. {bbot-2.3.2.5850rc0 → bbot-2.3.2.5874rc0}/bbot/test/test_step_2/template_tests/test_template_subdomain_enum.py +0 -0
  419. {bbot-2.3.2.5850rc0 → bbot-2.3.2.5874rc0}/bbot/test/testsslcert.pem +0 -0
  420. {bbot-2.3.2.5850rc0 → bbot-2.3.2.5874rc0}/bbot/test/testsslkey.pem +0 -0
  421. {bbot-2.3.2.5850rc0 → bbot-2.3.2.5874rc0}/bbot/wordlists/devops_mutations.txt +0 -0
  422. {bbot-2.3.2.5850rc0 → bbot-2.3.2.5874rc0}/bbot/wordlists/ms_on_prem_subdomains.txt +0 -0
  423. {bbot-2.3.2.5850rc0 → bbot-2.3.2.5874rc0}/bbot/wordlists/nameservers.txt +0 -0
  424. {bbot-2.3.2.5850rc0 → bbot-2.3.2.5874rc0}/bbot/wordlists/paramminer_headers.txt +0 -0
  425. {bbot-2.3.2.5850rc0 → bbot-2.3.2.5874rc0}/bbot/wordlists/paramminer_parameters.txt +0 -0
  426. {bbot-2.3.2.5850rc0 → bbot-2.3.2.5874rc0}/bbot/wordlists/raft-small-extensions-lowercase_CLEANED.txt +0 -0
  427. {bbot-2.3.2.5850rc0 → bbot-2.3.2.5874rc0}/bbot/wordlists/top_open_ports_nmap.txt +0 -0
  428. {bbot-2.3.2.5850rc0 → bbot-2.3.2.5874rc0}/bbot/wordlists/valid_url_schemes.txt +0 -0
  429. {bbot-2.3.2.5850rc0 → bbot-2.3.2.5874rc0}/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.3.2.5850rc0
3
+ Version: 2.3.2.5874rc0
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,4 +1,4 @@
1
1
  # version placeholder (replaced by poetry-dynamic-versioning)
2
- __version__ = "v2.3.2.5850rc"
2
+ __version__ = "v2.3.2.5874rc"
3
3
 
4
4
  from .scanner import Scanner, Preset
@@ -154,6 +154,12 @@ class generic_ssrf(BaseModule):
154
154
  produced_events = ["VULNERABILITY"]
155
155
  flags = ["active", "aggressive", "web-thorough"]
156
156
  meta = {"description": "Check for generic SSRFs", "created_date": "2022-07-30", "author": "@liquidsec"}
157
+ options = {
158
+ "skip_dns_interaction": False,
159
+ }
160
+ options_desc = {
161
+ "skip_dns_interaction": "Do not report DNS interactions (only HTTP interaction)",
162
+ }
157
163
  in_scope_only = True
158
164
 
159
165
  deps_apt = ["curl"]
@@ -163,7 +169,7 @@ class generic_ssrf(BaseModule):
163
169
  self.interactsh_subdomain_tags = {}
164
170
  self.parameter_subdomain_tags_map = {}
165
171
  self.severity = None
166
- self.generic_only = self.config.get("generic_only", False)
172
+ self.skip_dns_interaction = self.config.get("skip_dns_interaction", False)
167
173
 
168
174
  if self.scan.config.get("interactsh_disable", False) is False:
169
175
  try:
@@ -191,6 +197,10 @@ class generic_ssrf(BaseModule):
191
197
  await s.test(event)
192
198
 
193
199
  async def interactsh_callback(self, r):
200
+ protocol = r.get("protocol").upper()
201
+ if protocol == "DNS" and self.skip_dns_interaction:
202
+ return
203
+
194
204
  full_id = r.get("full-id", None)
195
205
  subdomain_tag = full_id.split(".")[0]
196
206
 
@@ -204,24 +214,27 @@ class generic_ssrf(BaseModule):
204
214
  matched_severity = match[2]
205
215
  matched_echoed_response = str(match[3])
206
216
 
207
- # Check if any SSRF parameter is in the DNS request
208
217
  triggering_param = self.parameter_subdomain_tags_map.get(subdomain_tag, None)
209
218
  description = f"Out-of-band interaction: [{matched_technique}]"
210
219
  if triggering_param:
211
220
  self.debug(f"Found triggering parameter: {triggering_param}")
212
221
  description += f" [Triggering Parameter: {triggering_param}]"
213
- description += f" [{r.get('protocol').upper()}] Echoed Response: {matched_echoed_response}"
222
+ description += f" [{protocol}] Echoed Response: {matched_echoed_response}"
214
223
 
215
224
  self.debug(f"Emitting event with description: {description}") # Debug the final description
216
225
 
226
+ event_type = "VULNERABILITY" if protocol == "HTTP" else "FINDING"
227
+ event_data = {
228
+ "host": str(matched_event.host),
229
+ "url": matched_event.data,
230
+ "description": description,
231
+ }
232
+ if protocol == "HTTP":
233
+ event_data["severity"] = matched_severity
234
+
217
235
  await self.emit_event(
218
- {
219
- "severity": matched_severity,
220
- "host": str(matched_event.host),
221
- "url": matched_event.data,
222
- "description": description,
223
- },
224
- "VULNERABILITY",
236
+ event_data,
237
+ event_type,
225
238
  matched_event,
226
239
  context=f"{{module}} scanned {matched_event.data} and detected {{event.type}}: {matched_technique}",
227
240
  )
@@ -241,7 +254,7 @@ class generic_ssrf(BaseModule):
241
254
 
242
255
  async def finish(self):
243
256
  if self.scan.config.get("interactsh_disable", False) is False:
244
- await self.helpers.sleep(2)
257
+ await self.helpers.sleep(5)
245
258
  try:
246
259
  for r in await self.interactsh_instance.poll():
247
260
  await self.interactsh_callback(r)
@@ -8,6 +8,8 @@ from pathlib import Path
8
8
  from contextlib import suppress
9
9
  from omegaconf import OmegaConf
10
10
  from pytest_httpserver import HTTPServer
11
+ import time
12
+ import queue
11
13
 
12
14
  from bbot.core import CORE
13
15
  from bbot.core.helpers.misc import execute_sync_or_async
@@ -53,6 +55,12 @@ def silence_live_logging():
53
55
  handler.setLevel(logging.CRITICAL)
54
56
 
55
57
 
58
+ def stop_server(server):
59
+ server.stop()
60
+ while server.is_running():
61
+ time.sleep(0.1) # Wait a bit before checking again
62
+
63
+
56
64
  @pytest.fixture
57
65
  def bbot_httpserver():
58
66
  server = HTTPServer(host="127.0.0.1", port=8888, threaded=True)
@@ -61,11 +69,7 @@ def bbot_httpserver():
61
69
  yield server
62
70
 
63
71
  server.clear()
64
- if server.is_running():
65
- server.stop()
66
-
67
- # this is to check if the client has made any request where no
68
- # `assert_request` was called on it from the test
72
+ stop_server(server) # Ensure the server is fully stopped
69
73
 
70
74
  server.check_assertions()
71
75
  server.clear()
@@ -84,11 +88,7 @@ def bbot_httpserver_ssl():
84
88
  yield server
85
89
 
86
90
  server.clear()
87
- if server.is_running():
88
- server.stop()
89
-
90
- # this is to check if the client has made any request where no
91
- # `assert_request` was called on it from the test
91
+ stop_server(server) # Ensure the server is fully stopped
92
92
 
93
93
  server.check_assertions()
94
94
  server.clear()
@@ -129,7 +129,7 @@ class Interactsh_mock:
129
129
  def __init__(self, name):
130
130
  self.name = name
131
131
  self.log = logging.getLogger(f"bbot.interactsh.{self.name}")
132
- self.interactions = []
132
+ self.interactions = asyncio.Queue() # Use an asyncio queue for async access
133
133
  self.correlation_id = "deadbeef-dead-beef-dead-beefdeadbeef"
134
134
  self.stop = False
135
135
  self.poll_task = None
@@ -138,7 +138,7 @@ class Interactsh_mock:
138
138
  self.log.info(f"Mocking interaction to subdomain tag: {subdomain_tag}")
139
139
  if msg is not None:
140
140
  self.log.info(msg)
141
- self.interactions.append(subdomain_tag)
141
+ self.interactions.put_nowait(subdomain_tag) # Add to the thread-safe queue
142
142
 
143
143
  async def register(self, callback=None):
144
144
  if callable(callback):
@@ -146,27 +146,32 @@ class Interactsh_mock:
146
146
  return "fakedomain.fakeinteractsh.com"
147
147
 
148
148
  async def deregister(self, callback=None):
149
+ await asyncio.sleep(1)
149
150
  self.stop = True
150
151
  if self.poll_task is not None:
151
152
  self.poll_task.cancel()
152
- with suppress(BaseException):
153
+ with suppress(asyncio.CancelledError):
153
154
  await self.poll_task
154
155
 
155
156
  async def poll_loop(self, callback=None):
156
157
  while not self.stop:
157
158
  data_list = await self.poll(callback)
158
159
  if not data_list:
159
- await asyncio.sleep(1)
160
+ await asyncio.sleep(0.5)
160
161
  continue
162
+ await asyncio.sleep(1)
163
+ await self.poll(callback)
161
164
 
162
165
  async def poll(self, callback=None):
163
166
  poll_results = []
164
- for subdomain_tag in self.interactions:
165
- result = {"full-id": f"{subdomain_tag}.fakedomain.fakeinteractsh.com", "protocol": "HTTP"}
166
- poll_results.append(result)
167
- if callback is not None:
168
- await execute_sync_or_async(callback, result)
169
- self.interactions = []
167
+ while not self.interactions.empty():
168
+ subdomain_tag = await self.interactions.get() # Get the first element from the asyncio queue
169
+ for protocol in ["HTTP", "DNS"]:
170
+ result = {"full-id": f"{subdomain_tag}.fakedomain.fakeinteractsh.com", "protocol": protocol}
171
+ poll_results.append(result)
172
+ if callback is not None:
173
+ await execute_sync_or_async(callback, result)
174
+ await asyncio.sleep(0.1)
170
175
  return poll_results
171
176
 
172
177
 
@@ -1,3 +1,4 @@
1
+ import asyncio
1
2
  import re
2
3
  from .base import ModuleTestBase
3
4
  from werkzeug.wrappers import Response
@@ -171,7 +172,5 @@ class TestDotnetnuke_blindssrf(ModuleTestBase):
171
172
  if e.type == "VULNERABILITY" and "DotNetNuke Blind-SSRF (CVE 2017-0929)" in e.data["description"]:
172
173
  dnn_dnnimagehandler_blindssrf = True
173
174
 
174
- assert self.interactsh_mock_instance.interactions == []
175
-
176
175
  assert dnn_technology_detection, "DNN Technology Detection Failed"
177
176
  assert dnn_dnnimagehandler_blindssrf, "dnnimagehandler.ashx Blind SSRF Detection Failed"
@@ -1,4 +1,5 @@
1
1
  import re
2
+ import asyncio
2
3
  from werkzeug.wrappers import Response
3
4
 
4
5
  from .base import ModuleTestBase
@@ -23,15 +24,16 @@ class TestGeneric_SSRF(ModuleTestBase):
23
24
  elif request.method == "POST":
24
25
  subdomain_tag = extract_subdomain_tag(request.data.decode())
25
26
  if subdomain_tag:
26
- self.interactsh_mock_instance.mock_interaction(
27
- subdomain_tag, msg=f"{request.method}: {request.data.decode()}"
27
+ asyncio.run(
28
+ self.interactsh_mock_instance.mock_interaction(
29
+ subdomain_tag, msg=f"{request.method}: {request.data.decode()}"
30
+ )
28
31
  )
29
32
 
30
33
  return Response("alive", status=200)
31
34
 
32
35
  async def setup_before_prep(self, module_test):
33
36
  self.interactsh_mock_instance = module_test.mock_interactsh("generic_ssrf")
34
- self.interactsh_mock_instance.mock_interaction("asdf")
35
37
  module_test.monkeypatch.setattr(
36
38
  module_test.scan.helpers, "interactsh", lambda *args, **kwargs: self.interactsh_mock_instance
37
39
  )
@@ -41,6 +43,18 @@ class TestGeneric_SSRF(ModuleTestBase):
41
43
  module_test.set_expect_requests_handler(expect_args=expect_args, request_handler=self.request_handler)
42
44
 
43
45
  def check(self, module_test, events):
46
+ total_vulnerabilities = 0
47
+ total_findings = 0
48
+
49
+ for e in events:
50
+ if e.type == "VULNERABILITY":
51
+ total_vulnerabilities += 1
52
+ elif e.type == "FINDING":
53
+ total_findings += 1
54
+
55
+ assert total_vulnerabilities == 30, "Incorrect number of vulnerabilities detected"
56
+ assert total_findings == 30, "Incorrect number of findings detected"
57
+
44
58
  assert any(
45
59
  e.type == "VULNERABILITY"
46
60
  and "Out-of-band interaction: [Generic SSRF (GET)]"
@@ -55,3 +69,20 @@ class TestGeneric_SSRF(ModuleTestBase):
55
69
  e.type == "VULNERABILITY" and "Out-of-band interaction: [Generic XXE] [HTTP]" in e.data["description"]
56
70
  for e in events
57
71
  ), "Failed to detect Generic SSRF (XXE)"
72
+
73
+
74
+ class TestGeneric_SSRF_httponly(TestGeneric_SSRF):
75
+ config_overrides = {"modules": {"generic_ssrf": {"skip_dns_interaction": True}}}
76
+
77
+ def check(self, module_test, events):
78
+ total_vulnerabilities = 0
79
+ total_findings = 0
80
+
81
+ for e in events:
82
+ if e.type == "VULNERABILITY":
83
+ total_vulnerabilities += 1
84
+ elif e.type == "FINDING":
85
+ total_findings += 1
86
+
87
+ assert total_vulnerabilities == 30, "Incorrect number of vulnerabilities detected"
88
+ assert total_findings == 0, "Incorrect number of findings detected"
@@ -1,3 +1,4 @@
1
+ import asyncio
1
2
  import re
2
3
  from werkzeug.wrappers import Response
3
4
 
@@ -1,6 +1,6 @@
1
1
  [tool.poetry]
2
2
  name = "bbot"
3
- version = "v2.3.2.5850rc"
3
+ version = "v2.3.2.5874rc"
4
4
  description = "OSINT automation for hackers."
5
5
  authors = [
6
6
  "TheTechromancer",
File without changes
File without changes
File without changes