Skip to content

chore: add MIT license; remove duplicate dependabot-auto-merge schedule#186

Merged
docdyhr merged 1 commit into
mainfrom
chore/tier2-standard
Jun 10, 2026
Merged

chore: add MIT license; remove duplicate dependabot-auto-merge schedule#186
docdyhr merged 1 commit into
mainfrom
chore/tier2-standard

Conversation

@docdyhr

@docdyhr docdyhr commented Jun 10, 2026

Copy link
Copy Markdown
Owner

Tier 2 sweep — two changes:\n\n1. MIT LICENSE (copyright 2022 Thomas Juul Dyhr) — brings versiontracker up to the docdyhr standard.\n2. Remove schedule: from dependabot-auto-merge.yml — same fix applied to httpcheck/malwarespotter/pigame in item 22. The cross-repo orchestrator in docdyhr/.github owns the Sunday 06:00 schedule; per-repo trigger causes duplicate API spend.\n\n🤖 Generated with Claude Code

Summary by Sourcery

Add repository licensing and adjust Dependabot auto-merge workflow triggering to rely on the shared cross-repo schedule.

CI:

  • Remove the per-repository cron schedule from the Dependabot auto-merge workflow so it is only triggered by the shared orchestrator.

Chores:

  • Add an MIT license file to align repository licensing with the docdyhr standard.

…o-merge

Orchestrator in docdyhr/.github owns the Sunday 06:00 schedule.
Per-repo schedule: trigger causes duplicate API spend each week.
@sourcery-ai

sourcery-ai Bot commented Jun 10, 2026

Copy link
Copy Markdown
Contributor
Reviewer's guide (collapsed on small PRs)

Reviewer's Guide

Adds an MIT license file to align the repository with the docdyhr standard and updates the Dependabot auto-merge workflow to rely on the central cross-repo schedule instead of a local cron trigger, preventing duplicate runs and API usage.

File-Level Changes

Change Details Files
Add MIT LICENSE file to formalize project licensing under MIT and align with org-wide standard.
  • Introduce MIT LICENSE file with copyright attribution to Thomas Juul Dyhr (2022).
  • Ensure repository now clearly declares MIT licensing, consistent with other docdyhr projects.
LICENSE
Update Dependabot auto-merge workflow to remove local cron schedule and rely on centralized orchestration.
  • Delete the per-repository schedule cron trigger from the Dependabot auto-merge workflow on: block.
  • Add a clarifying comment that scheduling is owned by the cross-repo orchestrator in docdyhr/.github.
  • Keep workflow_dispatch as the remaining trigger so the workflow can still be run manually.
.github/workflows/dependabot-auto-merge.yml

Tips and commands

Interacting with Sourcery

  • Trigger a new review: Comment @sourcery-ai review on the pull request.
  • Continue discussions: Reply directly to Sourcery's review comments.
  • Generate a GitHub issue from a review comment: Ask Sourcery to create an
    issue from a review comment by replying to it. You can also reply to a
    review comment with @sourcery-ai issue to create an issue from it.
  • Generate a pull request title: Write @sourcery-ai anywhere in the pull
    request title to generate a title at any time. You can also comment
    @sourcery-ai title on the pull request to (re-)generate the title at any time.
  • Generate a pull request summary: Write @sourcery-ai summary anywhere in
    the pull request body to generate a PR summary at any time exactly where you
    want it. You can also comment @sourcery-ai summary on the pull request to
    (re-)generate the summary at any time.
  • Generate reviewer's guide: Comment @sourcery-ai guide on the pull
    request to (re-)generate the reviewer's guide at any time.
  • Resolve all Sourcery comments: Comment @sourcery-ai resolve on the
    pull request to resolve all Sourcery comments. Useful if you've already
    addressed all the comments and don't want to see them anymore.
  • Dismiss all Sourcery reviews: Comment @sourcery-ai dismiss on the pull
    request to dismiss all existing Sourcery reviews. Especially useful if you
    want to start fresh with a new review - don't forget to comment
    @sourcery-ai review to trigger a new review!

Customizing Your Experience

Access your dashboard to:

  • Enable or disable review features such as the Sourcery-generated pull request
    summary, the reviewer's guide, and others.
  • Change the review language.
  • Add, remove or edit custom review instructions.
  • Adjust other review settings.

Getting Help

@sourcery-ai sourcery-ai Bot left a comment

Copy link
Copy Markdown
Contributor

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Hey - I've left some high level feedback:

  • Consider adding a brief pointer (e.g. a URL or repo path) to the cross‑repo orchestrator in the workflow comment so future maintainers immediately know where the schedule is defined.
Prompt for AI Agents
Please address the comments from this code review:

## Overall Comments
- Consider adding a brief pointer (e.g. a URL or repo path) to the cross‑repo orchestrator in the workflow comment so future maintainers immediately know where the schedule is defined.

Sourcery is free for open source - if you like our reviews please consider sharing them ✨
Help me be more useful! Please click 👍 or 👎 on each comment and I'll use the feedback to improve your reviews.

@github-actions

Copy link
Copy Markdown

🔒 Security Analysis Report

Security Analysis Report

Generated: Wed Jun 10 12:09:16 UTC 2026
Repository: docdyhr/versiontracker
Commit: afb5547

Bandit Security Scan

�[?25l
�[2KWorking... �[90m━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━�[0m �[35m  0%�[0m �[36m-:--:--�[0m
�[2KWorking... �[90m━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━�[0m �[35m  0%�[0m �[36m-:--:--�[0m
�[2KWorking... �[91m━━━━�[0m�[90m╺�[0m�[90m━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━�[0m �[35m 11%�[0m �[36m-:--:--�[0m
�[2KWorking... �[91m━━━━━━━━━━━━�[0m�[91m╸�[0m�[90m━━━━━━━━━━━━━━━━━━━━━━━━━━━�[0m �[35m 31%�[0m �[36m0:00:01�[0m
�[2KWorking... �[91m━━━━━━━━━━━━━━━━━━�[0m�[91m╸�[0m�[90m━━━━━━━━━━━━━━━━━━━━━�[0m �[35m 46%�[0m �[36m0:00:01�[0m
�[2KWorking... �[91m━━━━━━━━━━━━━━━━━━━━━━━━━━━�[0m�[90m╺�[0m�[90m━━━━━━━━━━━━�[0m �[35m 69%�[0m �[36m0:00:01�[0m
�[2KWorking... �[91m━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━�[0m�[91m╸�[0m�[90m━━━━━━━━�[0m �[35m 80%�[0m �[36m0:00:01�[0m
�[2KWorking... �[90m━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━�[0m �[35m100%�[0m �[33m0:00:00�[0m
�[2KWorking... �[90m━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━�[0m �[35m100%�[0m �[33m0:00:00�[0m
�[?25hRun started:2026-06-10 12:09:17.101808+00:00

Test results:
>> Issue: [B608:hardcoded_sql_expressions] Possible SQL injection vector through string-based query construction.
   Severity: Medium   Confidence: Low
   CWE: CWE-89 (https://cwe.mitre.org/data/definitions/89.html)
   More Info: https://bandit.readthedocs.io/en/1.9.4/plugins/b608_hardcoded_sql_expressions.html
   Location: versiontracker/advanced_cache.py:610:24
609	                # Use f-string for better readability
610	                msg = f"Failed to delete from cache {key}: {e}"
611	                raise CacheError(msg) from e

--------------------------------------------------
>> Issue: [B404:blacklist] Consider possible security implications associated with the subprocess module.
   Severity: Low   Confidence: High
   CWE: CWE-78 (https://cwe.mitre.org/data/definitions/78.html)
   More Info: https://bandit.readthedocs.io/en/1.9.4/blacklists/blacklist_imports.html#b404-import-subprocess
   Location: versiontracker/config.py:174:16
173	                cmd = f"{path} --version"
174	                import subprocess
175	

--------------------------------------------------
>> Issue: [B603:subprocess_without_shell_equals_true] subprocess call - check for execution of untrusted input.
   Severity: Low   Confidence: High
   CWE: CWE-78 (https://cwe.mitre.org/data/definitions/78.html)
   More Info: https://bandit.readthedocs.io/en/1.9.4/plugins/b603_subprocess_without_shell_equals_true.html
   Location: versiontracker/config.py:177:29
176	                try:
177	                    result = subprocess.run(cmd.split(), capture_output=True, timeout=2, check=False)
178	                    returncode = result.returncode

--------------------------------------------------
>> Issue: [B110:try_except_pass] Try, Except, Pass detected.
   Severity: Low   Confidence: High
   CWE: CWE-703 (https://cwe.mitre.org/data/definitions/703.html)
   More Info: https://bandit.readthedocs.io/en/1.9.4/plugins/b110_try_except_pass.html
   Location: versiontracker/experimental/analytics.py:645:16
644	                    self.peak_cpu = max(self.peak_cpu, cpu_percent)
645	                except Exception:
646	                    pass
647	                time.sleep(0.05)

--------------------------------------------------
>> Issue: [B101:assert_used] Use of assert detected. The enclosed code will be removed when compiling to optimised byte code.
   Severity: Low   Confidence: High
   CWE: CWE-703 (https://cwe.mitre.org/data/definitions/703.html)
   More Info: https://bandit.readthedocs.io/en/1.9.4/plugins/b101_assert_used.html
   Location: versiontracker/handlers/outdated_handlers.py:493:8
492	        # Type assertion: apps and brews cannot be None here due to exit_code checks above
493	        assert apps is not None
494	        assert brews is not None

--------------------------------------------------
>> Issue: [B101:assert_used] Use of assert detected. The enclosed code will be removed when compiling to optimised byte code.
   Severity: Low   Confidence: High
   CWE: CWE-703 (https://cwe.mitre.org/data/definitions/703.html)
   More Info: https://bandit.readthedocs.io/en/1.9.4/plugins/b101_assert_used.html
   Location: versiontracker/handlers/outdated_handlers.py:494:8
493	        assert apps is not None
494	        assert brews is not None
495	        apps = _filter_applications(apps, brews, include_brews)

--------------------------------------------------
>> Issue: [B101:assert_used] Use of assert detected. The enclosed code will be removed when compiling to optimised byte code.
   Severity: Low   Confidence: High
   CWE: CWE-703 (https://cwe.mitre.org/data/definitions/703.html)
   More Info: https://bandit.readthedocs.io/en/1.9.4/plugins/b101_assert_used.html
   Location: versiontracker/handlers/outdated_handlers.py:511:8
510	        # Type assertion: outdated_info cannot be None here due to exit_code check
511	        assert outdated_info is not None
512	        # Type cast: outdated_info cannot be None here due to exit_code check above

--------------------------------------------------
>> Issue: [B404:blacklist] Consider possible security implications associated with the subprocess module.
   Severity: Low   Confidence: High
   CWE: CWE-78 (https://cwe.mitre.org/data/definitions/78.html)
   More Info: https://bandit.readthedocs.io/en/1.9.4/blacklists/blacklist_imports.html#b404-import-subprocess
   Location: versiontracker/homebrew.py:12:0
11	import re
12	import subprocess
13	import time

--------------------------------------------------
>> Issue: [B404:blacklist] Consider possible security implications associated with the subprocess module.
   Severity: Low   Confidence: High
   CWE: CWE-78 (https://cwe.mitre.org/data/definitions/78.html)
   More Info: https://bandit.readthedocs.io/en/1.9.4/blacklists/blacklist_imports.html#b404-import-subprocess
   Location: versiontracker/macos_integration.py:11:0
10	import os
11	import subprocess
12	from pathlib import Path

--------------------------------------------------
>> Issue: [B603:subprocess_without_shell_equals_true] subprocess call - check for execution of untrusted input.
   Severity: Low   Confidence: High
   CWE: CWE-78 (https://cwe.mitre.org/data/definitions/78.html)
   More Info: https://bandit.readthedocs.io/en/1.9.4/plugins/b603_subprocess_without_shell_equals_true.html
   Location: versiontracker/macos_integration.py:250:21
249	            # nosec B603 - osascript with controlled arguments
250	            result = subprocess.run(cmd, capture_output=True, text=True)
251	

--------------------------------------------------
>> Issue: [B404:blacklist] Consider possible security implications associated with the subprocess module.
   Severity: Low   Confidence: High
   CWE: CWE-78 (https://cwe.mitre.org/data/definitions/78.html)
   More Info: https://bandit.readthedocs.io/en/1.9.4/blacklists/blacklist_imports.html#b404-import-subprocess
   Location: versiontracker/menubar_app.py:8:0
7	import logging
8	import subprocess
9	import sys

--------------------------------------------------
>> Issue: [B404:blacklist] Consider possible security implications associated with the subprocess module.
   Severity: Low   Confidence: High
   CWE: CWE-78 (https://cwe.mitre.org/data/definitions/78.html)
   More Info: https://bandit.readthedocs.io/en/1.9.4/blacklists/blacklist_imports.html#b404-import-subprocess
   Location: versiontracker/plugins/example_plugins.py:322:16
321	            try:
322	                import subprocess
323	

--------------------------------------------------
>> Issue: [B607:start_process_with_partial_path] Starting a process with a partial executable path
   Severity: Low   Confidence: High
   CWE: CWE-78 (https://cwe.mitre.org/data/definitions/78.html)
   More Info: https://bandit.readthedocs.io/en/1.9.4/plugins/b607_start_process_with_partial_path.html
   Location: versiontracker/plugins/example_plugins.py:324:25
323	
324	                result = subprocess.run(["brew", "--version"], capture_output=True, text=True, timeout=5)
325	                if result.returncode == 0:

--------------------------------------------------
>> Issue: [B603:subprocess_without_shell_equals_true] subprocess call - check for execution of untrusted input.
   Severity: Low   Confidence: High
   CWE: CWE-78 (https://cwe.mitre.org/data/definitions/78.html)
   More Info: https://bandit.readthedocs.io/en/1.9.4/plugins/b603_subprocess_without_shell_equals_true.html
   Location: versiontracker/plugins/example_plugins.py:324:25
323	
324	                result = subprocess.run(["brew", "--version"], capture_output=True, text=True, timeout=5)
325	                if result.returncode == 0:

--------------------------------------------------
>> Issue: [B404:blacklist] Consider possible security implications associated with the subprocess module.
   Severity: Low   Confidence: High
   CWE: CWE-78 (https://cwe.mitre.org/data/definitions/78.html)
   More Info: https://bandit.readthedocs.io/en/1.9.4/blacklists/blacklist_imports.html#b404-import-subprocess
   Location: versiontracker/utils.py:15:0
14	import shutil
15	import subprocess
16	import sys

--------------------------------------------------
>> Issue: [B607:start_process_with_partial_path] Starting a process with a partial executable path
   Severity: Low   Confidence: High
   CWE: CWE-78 (https://cwe.mitre.org/data/definitions/78.html)
   More Info: https://bandit.readthedocs.io/en/1.9.4/plugins/b607_start_process_with_partial_path.html
   Location: versiontracker/utils.py:784:17
783	    try:
784	        result = subprocess.run(["which", "brew"], capture_output=True, text=True, timeout=5)
785	        return result.returncode == 0

--------------------------------------------------
>> Issue: [B603:subprocess_without_shell_equals_true] subprocess call - check for execution of untrusted input.
   Severity: Low   Confidence: High
   CWE: CWE-78 (https://cwe.mitre.org/data/definitions/78.html)
   More Info: https://bandit.readthedocs.io/en/1.9.4/plugins/b603_subprocess_without_shell_equals_true.html
   Location: versiontracker/utils.py:784:17
783	    try:
784	        result = subprocess.run(["which", "brew"], capture_output=True, text=True, timeout=5)
785	        return result.returncode == 0

--------------------------------------------------
>> Issue: [B607:start_process_with_partial_path] Starting a process with a partial executable path
   Severity: Low   Confidence: High
   CWE: CWE-78 (https://cwe.mitre.org/data/definitions/78.html)
   More Info: https://bandit.readthedocs.io/en/1.9.4/plugins/b607_start_process_with_partial_path.html
   Location: versiontracker/utils.py:800:17
799	    try:
800	        result = subprocess.run(["brew", "--prefix"], capture_output=True, text=True, timeout=5)
801	        if result.returncode == 0:

--------------------------------------------------
>> Issue: [B603:subprocess_without_shell_equals_true] subprocess call - check for execution of untrusted input.
   Severity: Low   Confidence: High
   CWE: CWE-78 (https://cwe.mitre.org/data/definitions/78.html)
   More Info: https://bandit.readthedocs.io/en/1.9.4/plugins/b603_subprocess_without_shell_equals_true.html
   Location: versiontracker/utils.py:800:17
799	    try:
800	        result = subprocess.run(["brew", "--prefix"], capture_output=True, text=True, timeout=5)
801	        if result.returncode == 0:

--------------------------------------------------
>> Issue: [B603:subprocess_without_shell_equals_true] subprocess call - check for execution of untrusted input.
   Severity: Low   Confidence: High
   CWE: CWE-78 (https://cwe.mitre.org/data/definitions/78.html)
   More Info: https://bandit.readthedocs.io/en/1.9.4/plugins/b603_subprocess_without_shell_equals_true.html
   Location: versiontracker/utils.py:833:15
832	    try:
833	        return subprocess.run(command, capture_output=True, text=True, timeout=timeout, check=check)
834	    except subprocess.TimeoutExpired as e:

--------------------------------------------------
>> Issue: [B404:blacklist] Consider possible security implications associated with the subprocess module.
   Severity: Low   Confidence: High
   CWE: CWE-78 (https://cwe.mitre.org/data/definitions/78.html)
   More Info: https://bandit.readthedocs.io/en/1.9.4/blacklists/blacklist_imports.html#b404-import-subprocess
   Location: versiontracker/version/batch.py:11:0
10	import logging
11	import subprocess
12	from concurrent.futures import ThreadPoolExecutor

--------------------------------------------------
>> Issue: [B404:blacklist] Consider possible security implications associated with the subprocess module.
   Severity: Low   Confidence: High
   CWE: CWE-78 (https://cwe.mitre.org/data/definitions/78.html)
   More Info: https://bandit.readthedocs.io/en/1.9.4/blacklists/blacklist_imports.html#b404-import-subprocess
   Location: versiontracker/version/homebrew.py:18:0
17	import logging
18	import subprocess
19	

--------------------------------------------------

Code scanned:
	Total lines of code: 15030
	Total lines skipped (#nosec): 0
	Total potential issues skipped due to specifically being disabled (e.g., #nosec BXXX): 33

Run metrics:
	Total issues (by severity):
		Undefined: 0
		Low: 21
		Medium: 1
		High: 0
	Total issues (by confidence):
		Undefined: 0
		Low: 1
		Medium: 0
		High: 21
Files skipped (0):

Safety Check Results



�[33m�[1m+===========================================================================================================================================================================================+�[0m


�[31m�[1mDEPRECATED: �[0m�[33m�[1mthis command (`check`) has been DEPRECATED, and will be unsupported beyond 01 June 2024.�[0m


�[32mWe highly encourage switching to the new �[0m�[32m�[1m`scan`�[0m�[32m command which is easier to use, more powerful, and can be set up to mimic the deprecated command if required.�[0m


�[33m�[1m+===========================================================================================================================================================================================+�[0m


+==============================================================================+

                               /$$$$$$            /$$
                              /$$__  $$          | $$
           /$$$$$$$  /$$$$$$ | $$  \__//$$$$$$  /$$$$$$   /$$   /$$
          /$$_____/ |____  $$| $$$$   /$$__  $$|_  $$_/  | $$  | $$
         |  $$$$$$   /$$$$$$$| $$_/  | $$$$$$$$  | $$    | $$  | $$
          \____  $$ /$$__  $$| $$    | $$_____/  | $$ /$$| $$  | $$
          /$$$$$$$/|  $$$$$$$| $$    |  $$$$$$$  |  $$$$/|  $$$$$$$
         |_______/  \_______/|__/     \_______/   \___/   \____  $$
                                                          /$$  | $$
                                                         |  $$$$$$/
  by safetycli.com                                        \______/

+==============================================================================+

 �[1mREPORT�[0m 

  Safety �[1mv3.8.1�[0m is scanning for �[1mVulnerabilities�[0m�[1m...�[0m
�[1m  Scanning dependencies�[0m in your �[1menvironment:�[0m

  -> /opt/hostedtoolcache/Python/3.13.13/x64/lib/python3.13/site-packages

  Using �[1mopen-source vulnerability database�[0m
�[1m  Found and scanned 110 packages�[0m
  Timestamp �[1m2026-06-10 12:09:17�[0m
�[1m  0�[0m�[1m vulnerabilities reported�[0m
�[1m  0�[0m�[1m vulnerabilities ignored�[0m
+==============================================================================+

 �[32m�[1mNo known security vulnerabilities reported.�[0m 

+==============================================================================+�[0m


�[33m�[1m+===========================================================================================================================================================================================+�[0m


�[31m�[1mDEPRECATED: �[0m�[33m�[1mthis command (`check`) has been DEPRECATED, and will be unsupported beyond 01 June 2024.�[0m


�[32mWe highly encourage switching to the new �[0m�[32m�[1m`scan`�[0m�[32m command which is easier to use, more powerful, and can be set up to mimic the deprecated command if required.�[0m


�[33m�[1m+===========================================================================================================================================================================================+�[0m


Pip-Audit Results

�[?25l�[32m-�[0m Collecting inputs
�[2K�[32m-�[0m Collecting inputs
�[2K�[32m-�[0m Collecting inputs
�[2K�[32m-�[0m Collecting inputs
�[2K�[32m\�[0m Collecting inputs
�[2K�[32m\�[0m Collecting aiohappyeyeballs (2.6.2)
�[2K�[32m\�[0m Auditing aiohappyeyeballs (2.6.2)
�[2K�[32m\�[0m Collecting aiohttp (3.14.1)
�[2K�[32m\�[0m Auditing aiohttp (3.14.1)
�[2K�[32m\�[0m Collecting aiosignal (1.4.0)
�[2K�[32m\�[0m Auditing aiosignal (1.4.0)
�[2K�[32m\�[0m Collecting annotated-doc (0.0.4)
�[2K�[32m\�[0m Auditing annotated-doc (0.0.4)
�[2K�[32m\�[0m Collecting annotated-types (0.7.0)
�[2K�[32m\�[0m Auditing annotated-types (0.7.0)
�[2K�[32m\�[0m Collecting anyio (4.13.0)
�[2K�[32m\�[0m Auditing anyio (4.13.0)
�[2K�[32m\�[0m Collecting ast_serialize (0.5.0)
�[2K�[32m\�[0m Auditing ast_serialize (0.5.0)
�[2K�[32m\�[0m Collecting attrs (26.1.0)
�[2K�[32m\�[0m Auditing attrs (26.1.0)
�[2K�[32m\�[0m Collecting Authlib (1.7.2)
�[2K�[32m\�[0m Auditing Authlib (1.7.2)
�[2K�[32m\�[0m Collecting bandit (1.9.4)
�[2K�[32m\�[0m Auditing bandit (1.9.4)
�[2K�[32m\�[0m Collecting black (26.5.1)
�[2K�[32m\�[0m Auditing black (26.5.1)
�[2K�[32m\�[0m Collecting boolean.py (5.0)
�[2K�[32m\�[0m Auditing boolean.py (5.0)
�[2K�[32m\�[0m Collecting build (1.5.0)
�[2K�[32m\�[0m Auditing build (1.5.0)
�[2K�[32m\�[0m Collecting CacheControl (0.14.4)
�[2K�[32m\�[0m Auditing CacheControl (0.14.4)
�[2K�[32m\�[0m Collecting certifi (2026.5.20)
�[2K�[32m\�[0m Auditing certifi (2026.5.20)
�[2K�[32m\�[0m Collecting cffi (2.0.0)
�[2K�[32m\�[0m Auditing cffi (2.0.0)
�[2K�[32m\�[0m Collecting charset-normalizer (3.4.7)
�[2K�[32m\�[0m Auditing charset-normalizer (3.4.7)
�[2K�[32m\�[0m Collecting click (8.4.1)
�[2K�[32m\�[0m Auditing click (8.4.1)
�[2K�[32m\�[0m Collecting coverage (7.14.1)
�[2K�[32m\�[0m Auditing coverage (7.14.1)
�[2K�[32m\�[0m Collecting cryptography (48.0.1)
�[2K�[32m\�[0m Auditing cryptography (48.0.1)
�[2K�[32m\�[0m Collecting cyclonedx-python-lib (11.9.0)
�[2K�[32m\�[0m Auditing cyclonedx-python-lib (11.9.0)
�[2K�[32m\�[0m Collecting defusedxml (0.7.1)
�[2K�[32m\�[0m Auditing defusedxml (0.7.1)
�[2K�[32m\�[0m Collecting docutils (0.23)
�[2K�[32m\�[0m Auditing docutils (0.23)
�[2K�[32m\�[0m Collecting dparse (0.6.4)
�[2K�[32m\�[0m Auditing dparse (0.6.4)
�[2K�[32m\�[0m Collecting filelock (3.29.1)
�[2K�[32m\�[0m Collecting filelock (3.29.1)
�[2K�[32m\�[0m Auditing filelock (3.29.1)
�[2K�[32m\�[0m Collecting frozenlist (1.8.0)
�[2K�[32m\�[0m Auditing frozenlist (1.8.0)
�[2K�[32m\�[0m Collecting h11 (0.16.0)
�[2K�[32m\�[0m Auditing h11 (0.16.0)
�[2K�[32m\�[0m Collecting httpcore (1.0.9)
�[2K�[32m\�[0m Auditing httpcore (1.0.9)
�[2K�[32m\�[0m Collecting httpx (0.28.1)
�[2K�[32m\�[0m Auditing httpx (0.28.1)
�[2K�[32m\�[0m Collecting id (1.6.1)
�[2K�[32m\�[0m Auditing id (1.6.1)
�[2K�[32m\�[0m Collecting idna (3.18)
�[2K�[32m\�[0m Auditing idna (3.18)
�[2K�[32m\�[0m Collecting iniconfig (2.3.0)
�[2K�[32m\�[0m Auditing iniconfig (2.3.0)
�[2K�[32m\�[0m Collecting jaraco.classes (3.4.0)
�[2K�[32m\�[0m Auditing jaraco.classes (3.4.0)
�[2K�[32m\�[0m Collecting jaraco.context (6.1.2)
�[2K�[32m\�[0m Auditing jaraco.context (6.1.2)
�[2K�[32m\�[0m Collecting jaraco.functools (4.5.0)
�[2K�[32m\�[0m Auditing jaraco.functools (4.5.0)
�[2K�[32m\�[0m Collecting jeepney (0.9.0)
�[2K�[32m\�[0m Auditing jeepney (0.9.0)
�[2K�[32m\�[0m Collecting Jinja2 (3.1.6)
�[2K�[32m\�[0m Auditing Jinja2 (3.1.6)
�[2K�[32m\�[0m Collecting joblib (1.5.3)
�[2K�[32m\�[0m Auditing joblib (1.5.3)
�[2K�[32m\�[0m Collecting joserfc (1.7.1)
�[2K�[32m\�[0m Auditing joserfc (1.7.1)
�[2K�[32m\�[0m Collecting keyring (25.7.0)
�[2K�[32m\�[0m Auditing keyring (25.7.0)
�[2K�[32m\�[0m Collecting librt (0.11.0)
�[2K�[32m\�[0m Auditing librt (0.11.0)
�[2K�[32m\�[0m Collecting license-expression (30.4.4)
�[2K�[32m\�[0m Auditing license-expression (30.4.4)
�[2K�[32m\�[0m Collecting macversiontracker (1.0.1)
�[2K�[32m\�[0m Auditing macversiontracker (1.0.1)
�[2K�[32m\�[0m Collecting markdown-it-py (4.2.0)
�[2K�[32m\�[0m Auditing markdown-it-py (4.2.0)
�[2K�[32m\�[0m Collecting MarkupSafe (3.0.3)
�[2K�[32m\�[0m Auditing MarkupSafe (3.0.3)
�[2K�[32m\�[0m Collecting marshmallow (4.3.0)
�[2K�[32m\�[0m Auditing marshmallow (4.3.0)
�[2K�[32m\�[0m Collecting mdurl (0.1.2)
�[2K�[32m\�[0m Auditing mdurl (0.1.2)
�[2K�[32m\�[0m Collecting more-itertools (11.1.0)
�[2K�[32m\�[0m Auditing more-itertools (11.1.0)
�[2K�[32m\�[0m Collecting msgpack (1.1.2)
�[2K�[32m\�[0m Auditing msgpack (1.1.2)
�[2K�[32m\�[0m Collecting multidict (6.7.1)
�[2K�[32m\�[0m Auditing multidict (6.7.1)
�[2K�[32m\�[0m Collecting mypy (2.1.0)
�[2K�[32m\�[0m Auditing mypy (2.1.0)
�[2K�[32m\�[0m Collecting mypy_extensions (1.1.0)
�[2K�[32m\�[0m Auditing mypy_extensions (1.1.0)
�[2K�[32m\�[0m Collecting nh3 (0.3.5)
�[2K�[32m\�[0m Auditing nh3 (0.3.5)
�[2K�[32m\�[0m Collecting nltk (3.9.4)
�[2K�[32m\�[0m Auditing nltk (3.9.4)
�[2K�[32m\�[0m Collecting packageurl-python (0.17.6)
�[2K�[32m\�[0m Auditing packageurl-python (0.17.6)
�[2K�[32m\�[0m Collecting packaging (26.2)
�[2K�[32m\�[0m Auditing packaging (26.2)
�[2K�[32m\�[0m Collecting pathspec (1.1.1)
�[2K�[32m\�[0m Auditing pathspec (1.1.1)
�[2K�[32m\�[0m Collecting pip (26.1.2)
�[2K�[32m\�[0m Auditing pip (26.1.2)
�[2K�[32m\�[0m Collecting pip-api (0.0.34)
�[2K�[32m\�[0m Auditing pip-api (0.0.34)
�[2K�[32m\�[0m Collecting pip_audit (2.10.0)
�[2K�[32m\�[0m Auditing pip_audit (2.10.0)
�[2K�[32m\�[0m Collecting pip-requirements-parser (32.0.1)
�[2K�[32m\�[0m Auditing pip-requirements-parser (32.0.1)
�[2K�[32m\�[0m Collecting platformdirs (4.10.0)
�[2K�[32m\�[0m Auditing platformdirs (4.10.0)
�[2K�[32m\�[0m Collecting pluggy (1.6.0)
�[2K�[32m\�[0m Auditing pluggy (1.6.0)
�[2K�[32m\�[0m Collecting propcache (0.5.2)
�[2K�[32m\�[0m Auditing propcache (0.5.2)
�[2K�[32m\�[0m Collecting psutil (7.2.2)
�[2K�[32m\�[0m Auditing psutil (7.2.2)
�[2K�[32m\�[0m Collecting py-serializable (2.1.0)
�[2K�[32m\�[0m Auditing py-serializable (2.1.0)
�[2K�[32m\�[0m Collecting pycparser (3.0)
�[2K�[32m\�[0m Auditing pycparser (3.0)
�[2K�[32m\�[0m Collecting pydantic (2.13.4)
�[2K�[32m\�[0m Auditing pydantic (2.13.4)
�[2K�[32m\�[0m Collecting pydantic_core (2.46.4)
�[2K�[32m\�[0m Auditing pydantic_core (2.46.4)
�[2K�[32m\�[0m Collecting Pygments (2.20.0)
�[2K�[32m\�[0m Auditing Pygments (2.20.0)
�[2K�[32m\�[0m Collecting pyparsing (3.3.2)
�[2K�[32m\�[0m Auditing pyparsing (3.3.2)
�[2K�[32m\�[0m Collecting pyproject_hooks (1.2.0)
�[2K�[32m\�[0m Auditing pyproject_hooks (1.2.0)
�[2K�[32m\�[0m Collecting pytest (9.0.3)
�[2K�[32m\�[0m Auditing pytest (9.0.3)
�[2K�[32m\�[0m Collecting pytest-asyncio (1.4.0)
�[2K�[32m\�[0m Collecting pytest-asyncio (1.4.0)
�[2K�[32m\�[0m Auditing pytest-asyncio (1.4.0)
�[2K�[32m\�[0m Collecting pytest-cov (7.1.0)
�[2K�[32m\�[0m Auditing pytest-cov (7.1.0)
�[2K�[32m\�[0m Collecting pytest-mock (3.15.1)
�[2K�[32m\�[0m Auditing pytest-mock (3.15.1)
�[2K�[32m\�[0m Collecting pytest-timeout (2.4.0)
�[2K�[32m\�[0m Auditing pytest-timeout (2.4.0)
�[2K�[32m\�[0m Collecting pytokens (0.4.1)
�[2K�[32m\�[0m Auditing pytokens (0.4.1)
�[2K�[32m\�[0m Collecting PyYAML (6.0.3)
�[2K�[32m\�[0m Auditing PyYAML (6.0.3)
�[2K�[32m\�[0m Collecting readme_renderer (45.0)
�[2K�[32m\�[0m Auditing readme_renderer (45.0)
�[2K�[32m\�[0m Collecting regex (2026.5.9)
�[2K�[32m\�[0m Auditing regex (2026.5.9)
�[2K�[32m\�[0m Collecting requests (2.34.2)
�[2K�[32m\�[0m Auditing requests (2.34.2)
�[2K�[32m\�[0m Collecting requests-toolbelt (1.0.0)
�[2K�[32m\�[0m Auditing requests-toolbelt (1.0.0)
�[2K�[32m\�[0m Collecting rfc3986 (2.0.0)
�[2K�[32m\�[0m Auditing rfc3986 (2.0.0)
�[2K�[32m\�[0m Collecting rich (15.0.0)
�[2K�[32m\�[0m Auditing rich (15.0.0)
�[2K�[32m\�[0m Collecting ruamel.yaml (0.19.1)
�[2K�[32m\�[0m Auditing ruamel.yaml (0.19.1)
�[2K�[32m\�[0m Collecting ruff (0.15.16)
�[2K�[32m\�[0m Auditing ruff (0.15.16)
�[2K�[32m\�[0m Collecting safety (3.8.1)
�[2K�[32m\�[0m Auditing safety (3.8.1)
�[2K�[32m\�[0m Collecting safety-schemas (0.0.16)
�[2K�[32m\�[0m Auditing safety-schemas (0.0.16)
�[2K�[32m\�[0m Collecting SecretStorage (3.5.0)
�[2K�[32m\�[0m Auditing SecretStorage (3.5.0)
�[2K�[32m\�[0m Collecting setuptools (82.0.1)
�[2K�[32m\�[0m Auditing setuptools (82.0.1)
�[2K�[32m\�[0m Collecting shellingham (1.5.4)
�[2K�[32m\�[0m Auditing shellingham (1.5.4)
�[2K�[32m\�[0m Collecting sortedcontainers (2.4.0)
�[2K�[32m\�[0m Auditing sortedcontainers (2.4.0)
�[2K�[32m\�[0m Collecting stevedore (5.8.0)
�[2K�[32m\�[0m Auditing stevedore (5.8.0)
�[2K�[32m\�[0m Collecting tabulate (0.10.0)
�[2K�[32m\�[0m Auditing tabulate (0.10.0)
�[2K�[32m\�[0m Collecting tenacity (9.1.4)
�[2K�[32m\�[0m Auditing tenacity (9.1.4)
�[2K�[32m\�[0m Collecting termcolor (3.3.0)
�[2K�[32m\�[0m Auditing termcolor (3.3.0)
�[2K�[32m\�[0m Collecting tomli (2.4.1)
�[2K�[32m\�[0m Auditing tomli (2.4.1)
�[2K�[32m\�[0m Collecting tomli_w (1.2.0)
�[2K�[32m\�[0m Auditing tomli_w (1.2.0)
�[2K�[32m\�[0m Collecting tomlkit (0.15.0)
�[2K�[32m\�[0m Auditing tomlkit (0.15.0)
�[2K�[32m\�[0m Collecting tqdm (4.68.2)
�[2K�[32m\�[0m Auditing tqdm (4.68.2)
�[2K�[32m\�[0m Collecting truststore (0.10.4)
�[2K�[32m\�[0m Auditing truststore (0.10.4)
�[2K�[32m\�[0m Collecting twine (6.2.0)
�[2K�[32m\�[0m Auditing twine (6.2.0)
�[2K�[32m\�[0m Collecting typer (0.25.1)
�[2K�[32m\�[0m Auditing typer (0.25.1)
�[2K�[32m\�[0m Collecting types-PyYAML (6.0.12.20260518)
�[2K�[32m\�[0m Auditing types-PyYAML (6.0.12.20260518)
�[2K�[32m\�[0m Collecting typing_extensions (4.15.0)
�[2K�[32m\�[0m Auditing typing_extensions (4.15.0)
�[2K�[32m\�[0m Collecting typing-inspection (0.4.2)
�[2K�[32m\�[0m Auditing typing-inspection (0.4.2)
�[2K�[32m\�[0m Collecting urllib3 (2.7.0)
�[2K�[32m\�[0m Auditing urllib3 (2.7.0)
�[2K�[32m\�[0m Collecting wheel (0.47.0)
�[2K�[32m\�[0m Auditing wheel (0.47.0)
�[2K�[32m\�[0m Collecting yarl (1.24.2)
�[2K�[32m\�[0m Auditing yarl (1.24.2)
�[2K�[32m\�[0m Auditing yarl (1.24.2)
�[?25h
�[1A�[2K```

@codecov

codecov Bot commented Jun 10, 2026

Copy link
Copy Markdown

Codecov Report

✅ All modified and coverable lines are covered by tests.

📢 Thoughts on this report? Let us know!

@docdyhr docdyhr merged commit c7a7635 into main Jun 10, 2026
24 checks passed
Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment

Labels

None yet

Projects

None yet

Development

Successfully merging this pull request may close these issues.

1 participant