Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

Dev -> Stable 2.1.1 #1885

Merged
merged 97 commits into from
Oct 31, 2024
Merged
Show file tree
Hide file tree
Changes from 15 commits
Commits
Show all changes
97 commits
Select commit Hold shift + click to select a range
126c1c6
enable manual trigger
invalid-email-address Oct 18, 2024
f2b70ce
Update nuclei
blsaccess Oct 20, 2024
2c0ebb6
Bump pytest-asyncio from 0.23.8 to 0.24.0
dependabot[bot] Oct 21, 2024
f76e688
Bump mkdocs-material from 9.5.41 to 9.5.42
dependabot[bot] Oct 21, 2024
ec67fa4
Bump xmltojson from 2.0.2 to 2.0.3
dependabot[bot] Oct 21, 2024
6a5303d
Bump mkdocstrings-python from 1.12.1 to 1.12.2
dependabot[bot] Oct 21, 2024
1b03b70
Merge pull request #1878 from blacklanternsecurity/dependabot/pip/dev…
TheTechromancer Oct 21, 2024
a4b9824
Merge pull request #1882 from blacklanternsecurity/dependabot/pip/dev…
TheTechromancer Oct 21, 2024
ba10b9e
Merge pull request #1881 from blacklanternsecurity/dependabot/pip/dev…
TheTechromancer Oct 21, 2024
6250877
Merge pull request #1880 from blacklanternsecurity/dependabot/pip/dev…
TheTechromancer Oct 21, 2024
9dc05bb
Bump psutil from 5.9.8 to 6.1.0
dependabot[bot] Oct 21, 2024
20aaf68
resolve conflicts
invalid-email-address Oct 18, 2024
f55c004
resolve conflicts
invalid-email-address Oct 18, 2024
6be3f23
simplified run_tests.sh
TheTechromancer Jun 18, 2024
c08648e
resolve conflicts
invalid-email-address Oct 18, 2024
c2e69e8
runs-on --> container: image
invalid-email-address Oct 18, 2024
6875793
fix python setup
invalid-email-address Oct 18, 2024
047b9ff
no sudo
invalid-email-address Oct 21, 2024
3c6728c
python things
invalid-email-address Oct 21, 2024
0572ce6
quotes
invalid-email-address Oct 21, 2024
5a6e68e
testing stuff
invalid-email-address Oct 21, 2024
ffe8ae1
pipx
invalid-email-address Oct 21, 2024
46f65a4
onwards
invalid-email-address Oct 21, 2024
50969eb
distro stuff
invalid-email-address Oct 21, 2024
b30cbaf
more
invalid-email-address Oct 21, 2024
262d5d7
just ubuntu things
invalid-email-address Oct 21, 2024
cc296b7
tests
invalid-email-address Oct 21, 2024
97ce06b
iterating
invalid-email-address Oct 21, 2024
3036629
bash oopsie
invalid-email-address Oct 21, 2024
687d247
distrosgit diff
invalid-email-address Oct 21, 2024
c763c1e
alpine
invalid-email-address Oct 21, 2024
16f204c
ubuntu things
invalid-email-address Oct 21, 2024
10627df
more ubuntu things
invalid-email-address Oct 21, 2024
e594c3f
Merge pull request #1879 from blacklanternsecurity/dependabot/pip/dev…
TheTechromancer Oct 21, 2024
f2cdcb8
Merge pull request #1877 from blacklanternsecurity/update-nuclei
TheTechromancer Oct 21, 2024
f3b90e5
better debian
invalid-email-address Oct 21, 2024
0a6e78b
ubuntu why?
invalid-email-address Oct 21, 2024
838c781
ubuntu why?
invalid-email-address Oct 21, 2024
782a68d
ubuntu why?
invalid-email-address Oct 21, 2024
8f3ba61
ubuntu why?
invalid-email-address Oct 21, 2024
cdfbe7e
skip dastardly
invalid-email-address Oct 21, 2024
ce31264
pyenv
invalid-email-address Oct 21, 2024
1eedaf5
pyenv
invalid-email-address Oct 21, 2024
bb451fd
curl
invalid-email-address Oct 21, 2024
60a418e
git
invalid-email-address Oct 21, 2024
32abe3b
bash
invalid-email-address Oct 21, 2024
b9d40bf
dev
invalid-email-address Oct 21, 2024
51fd792
path
invalid-email-address Oct 21, 2024
f788dad
pyenv things
invalid-email-address Oct 21, 2024
73b00f4
alpine
invalid-email-address Oct 21, 2024
cda7d50
Merge pull request #1476 from blacklanternsecurity/multi-distro-tests
TheTechromancer Oct 22, 2024
51e745a
bufferover.run module
invalid-email-address Oct 23, 2024
6821a1e
add test
invalid-email-address Oct 23, 2024
ee078b3
update docs workflow
invalid-email-address Oct 23, 2024
84cc1a2
Merge pull request #1888 from blacklanternsecurity/bufferoverrun
TheTechromancer Oct 24, 2024
e08e385
bump versions
invalid-email-address Oct 24, 2024
17160e7
continue on error
invalid-email-address Oct 24, 2024
30320b6
don't continue on error
invalid-email-address Oct 24, 2024
07a0713
silence stderr in tests
invalid-email-address Oct 26, 2024
dd7884e
upload debug logs
invalid-email-address Oct 26, 2024
7da0c63
troubleshooting ubuntu 20.04 test
invalid-email-address Oct 27, 2024
9e90572
test things
invalid-email-address Oct 27, 2024
0441155
ruby things
invalid-email-address Oct 27, 2024
5eded28
more test things
invalid-email-address Oct 27, 2024
95187e8
ansible things
invalid-email-address Oct 27, 2024
614dcd5
ubuntu why
invalid-email-address Oct 27, 2024
cfbd211
alpine
invalid-email-address Oct 27, 2024
991b531
bye ubuntu
invalid-email-address Oct 27, 2024
f44983f
all tests
invalid-email-address Oct 27, 2024
1f71c58
fix chrome in fedora
invalid-email-address Oct 27, 2024
f4bbd88
goodbye gentoo, goodbye alpine
invalid-email-address Oct 27, 2024
8a8d33e
flaked
invalid-email-address Oct 27, 2024
5360050
Merge pull request #1892 from blacklanternsecurity/better-logging
TheTechromancer Oct 28, 2024
32c4f7e
fixing pytest summary
liquidsec Oct 28, 2024
24676a6
showcapture no
invalid-email-address Oct 28, 2024
d348d96
silence live logging
invalid-email-address Oct 28, 2024
905cc04
blacked
invalid-email-address Oct 28, 2024
3f3c43b
test tests
invalid-email-address Oct 28, 2024
ffb8c09
remove thing
invalid-email-address Oct 28, 2024
38d3f49
flaked
invalid-email-address Oct 28, 2024
16e82e8
done
invalid-email-address Oct 28, 2024
dc54677
Merge pull request #1894 from blacklanternsecurity/logging-restore-su…
TheTechromancer Oct 28, 2024
0207fd0
stop logger on exit
invalid-email-address Oct 28, 2024
ad88024
better log cleanup
invalid-email-address Oct 28, 2024
d83dba4
Merge pull request #1891 from blacklanternsecurity/stable-update
TheTechromancer Oct 28, 2024
60ab921
rename tests
invalid-email-address Oct 28, 2024
e8c27f4
don't skip dastardly tests
invalid-email-address Oct 28, 2024
1837f0a
unskip dastardly tests
invalid-email-address Oct 28, 2024
52242dd
Merge branch 'dev' into excavate-intercept
TheTechromancer Oct 29, 2024
de740f6
Merge pull request #1896 from blacklanternsecurity/test-cleanup
TheTechromancer Oct 29, 2024
ae55da4
Merge pull request #1873 from blacklanternsecurity/excavate-intercept
TheTechromancer Oct 29, 2024
88a9cf9
Update trufflehog
blsaccess Oct 30, 2024
9e53c38
Merge pull request #1883 from blacklanternsecurity/update-trufflehog
TheTechromancer Oct 30, 2024
b0639ef
Update trufflehog
blsaccess Oct 31, 2024
18a70ca
asyncify sqlite
invalid-email-address Oct 31, 2024
a12a00b
Merge pull request #1900 from blacklanternsecurity/update-trufflehog
TheTechromancer Oct 31, 2024
a367758
Merge pull request #1901 from blacklanternsecurity/asyncify-gowitness
TheTechromancer Oct 31, 2024
File filter

Filter by extension

Filter by extension


Conversations
Failed to load comments.
Loading
Jump to
Jump to file
Failed to load files.
Loading
Diff view
Diff view
7 changes: 4 additions & 3 deletions .github/workflows/distro_tests.yml
Original file line number Diff line number Diff line change
Expand Up @@ -14,7 +14,7 @@ jobs:
strategy:
fail-fast: false
matrix:
os: ["ubuntu:20.04", "ubuntu:22.04", "ubuntu:24.04", "debian", "archlinux", "fedora", "gentoo/python", "python:3.10-alpine", "kalilinux/kali-rolling", "parrotsec/security"]
os: ["ubuntu:22.04", "ubuntu:24.04", "debian", "archlinux", "fedora", "kalilinux/kali-rolling", "parrotsec/security"]
steps:
- uses: actions/checkout@v4
- name: Install Python and Poetry
Expand All @@ -32,8 +32,9 @@ jobs:
elif [ "$ID" = "fedora" ]; then
dnf install -y curl git bash gcc make openssl-devel bzip2-devel libffi-devel zlib-devel xz-devel tk-devel gdbm-devel readline-devel sqlite-devel
elif [ "$ID" = "gentoo" ]; then
echo "media-libs/libglvnd X" >> /etc/portage/package.use/libglvnd
emerge-webrsync
emerge --update --newuse dev-vcs/git curl bash
emerge --update --newuse dev-vcs/git media-libs/mesa curl bash
fi
fi

Expand All @@ -60,4 +61,4 @@ jobs:
export BBOT_DISTRO_TESTS=true
poetry env use python3.11
poetry install
poetry run pytest --reruns 2 -o timeout_func_only=true --timeout 1200 --disable-warnings --log-cli-level=DEBUG .
poetry run pytest --reruns 2 -o timeout_func_only=true --timeout 1200 --disable-warnings --log-cli-level=INFO .
5 changes: 5 additions & 0 deletions .github/workflows/tests.yml
Original file line number Diff line number Diff line change
Expand Up @@ -49,6 +49,11 @@ jobs:
- name: Run tests
run: |
poetry run pytest --exitfirst --reruns 2 -o timeout_func_only=true --timeout 1200 --disable-warnings --log-cli-level=INFO --cov-config=bbot/test/coverage.cfg --cov-report xml:cov.xml --cov=bbot .
- name: Upload Debug Logs
uses: actions/upload-artifact@v3
with:
name: pytest-debug-logs
path: pytest_debug.log
- name: Upload Code Coverage
uses: codecov/codecov-action@v3
with:
Expand Down
2 changes: 0 additions & 2 deletions bbot/core/config/logger.py
Original file line number Diff line number Diff line change
@@ -1,5 +1,4 @@
import sys
import atexit
import logging
from copy import copy
import multiprocessing
Expand Down Expand Up @@ -71,7 +70,6 @@ def __init__(self, core):
# Start the QueueListener
self.listener = logging.handlers.QueueListener(self.queue, *self.log_handlers.values())
self.listener.start()
atexit.register(self.listener.stop)

self.log_level = logging.INFO

Expand Down
10 changes: 9 additions & 1 deletion bbot/core/helpers/depsinstaller/installer.py
Original file line number Diff line number Diff line change
Expand Up @@ -342,7 +342,15 @@ def install_core_deps(self):
# ensure tldextract data is cached
self.parent_helper.tldextract("evilcorp.co.uk")
# command: package_name
core_deps = {"unzip": "unzip", "curl": "curl"}
core_deps = {
"unzip": "unzip",
"zipinfo": "unzip",
"curl": "curl",
"git": "git",
"make": "make",
"gcc": "gcc",
"bash": "bash",
}
for command, package_name in core_deps.items():
if not self.parent_helper.which(command):
to_install.add(package_name)
Expand Down
2 changes: 1 addition & 1 deletion bbot/modules/gowitness.py
Original file line number Diff line number Diff line change
Expand Up @@ -72,7 +72,7 @@ async def setup(self):

# make sure we have a working chrome install
chrome_test_pass = False
for binary in ("chrome", "chromium", custom_chrome_path):
for binary in ("chrome", "chromium", "chromium-browser", custom_chrome_path):
binary_path = self.helpers.which(binary)
if binary_path and Path(binary_path).is_file():
chrome_test_proc = await self.run_process([binary_path, "--version"])
Expand Down
10 changes: 8 additions & 2 deletions bbot/modules/wpscan.py
Original file line number Diff line number Diff line change
Expand Up @@ -33,7 +33,7 @@ class wpscan(BaseModule):
deps_apt = ["curl", "make", "gcc"]
deps_ansible = [
{
"name": "Install Ruby Deps (Debian/Ubuntu)",
"name": "Install Ruby Deps (Debian)",
"package": {"name": ["ruby-rubygems", "ruby-dev"], "state": "present"},
"become": True,
"when": "ansible_facts['os_family'] == 'Debian'",
Expand All @@ -48,7 +48,13 @@ class wpscan(BaseModule):
"name": "Install Ruby Deps (Fedora)",
"package": {"name": ["rubygems", "ruby-devel"], "state": "present"},
"become": True,
"when": "ansible_facts['os_family'] == 'Fedora'",
"when": "ansible_facts['os_family'] == 'RedHat'",
},
{
"name": "Install Ruby Deps (Alpine)",
"package": {"name": ["ruby-dev", "ruby-bundler"], "state": "present"},
"become": True,
"when": "ansible_facts['os_family'] == 'Alpine'",
},
{
"name": "Install wpscan gem",
Expand Down
32 changes: 23 additions & 9 deletions bbot/test/conftest.py
Original file line number Diff line number Diff line change
Expand Up @@ -13,17 +13,31 @@
from bbot.core.helpers.misc import execute_sync_or_async
from bbot.core.helpers.interactsh import server_list as interactsh_servers

# silence stdout + trace
root_logger = logging.getLogger()
pytest_debug_file = Path(__file__).parent.parent.parent / "pytest_debug.log"
print(f"pytest_debug_file: {pytest_debug_file}")
debug_handler = logging.FileHandler(pytest_debug_file)
debug_handler.setLevel(logging.DEBUG)
debug_format = logging.Formatter("%(asctime)s [%(levelname)s] %(name)s %(filename)s:%(lineno)s %(message)s")
debug_handler.setFormatter(debug_format)
root_logger.addHandler(debug_handler)

test_config = OmegaConf.load(Path(__file__).parent / "test.conf")
if test_config.get("debug", False):
os.environ["BBOT_DEBUG"] = "True"
logging.getLogger("bbot").setLevel(logging.DEBUG)
CORE.logger.log_level = logging.DEBUG
else:
# silence stdout + trace
root_logger = logging.getLogger()
for h in root_logger.handlers:
h.addFilter(lambda x: x.levelname not in ("STDOUT", "TRACE"))

os.environ["BBOT_DEBUG"] = "True"
CORE.logger.log_level = logging.DEBUG

# silence all stderr output:
stderr_handler = CORE.logger.log_handlers["stderr"]
stderr_handler.setLevel(logging.CRITICAL)
handlers = list(CORE.logger.listener.handlers)
handlers.remove(stderr_handler)
CORE.logger.listener.handlers = tuple(handlers)

for h in root_logger.handlers:
h.addFilter(lambda x: x.levelname not in ("STDOUT", "TRACE"))


CORE.merge_default(test_config)

Expand Down
Loading