Skip to content

Commit

Permalink
feature/add-branch-name (#641)
Browse files Browse the repository at this point in the history
  • Loading branch information
dylanpulver authored Dec 3, 2024
1 parent 223ad60 commit 4b18043
Show file tree
Hide file tree
Showing 2 changed files with 45 additions and 18 deletions.
22 changes: 20 additions & 2 deletions safety/cli_util.py
Original file line number Diff line number Diff line change
@@ -1,5 +1,6 @@
from collections import defaultdict
import logging
import subprocess
import sys
from typing import Any, DefaultDict, Dict, List, Optional, Tuple, Union
import click
Expand Down Expand Up @@ -373,7 +374,7 @@ def format_main_help(obj: Union[click.Command, click.Group],
from typer.rich_utils import highlighter, STYLE_USAGE_COMMAND, \
ARGUMENTS_PANEL_TITLE, OPTIONS_PANEL_TITLE, \
COMMANDS_PANEL_TITLE

from rich.align import Align
from rich.padding import Padding
from rich.console import Console
Expand Down Expand Up @@ -793,4 +794,21 @@ def inner(ctx, output: Optional[ScanOutput], *args, **kwargs):
exception = e if isinstance(e, SafetyException) else SafetyException(info=e)
output_exception(exception, exit_code_output=True)

return inner
return inner

def get_git_branch_name() -> Optional[str]:
"""
Retrieves the current Git branch name.
Returns:
str: The current Git branch name, or None if it cannot be determined.
"""
try:
branch_name = subprocess.check_output(
["git", "rev-parse", "--abbrev-ref", "HEAD"],
stderr=subprocess.DEVNULL,
text=True
).strip()
return branch_name if branch_name else None
except Exception:
return None
41 changes: 25 additions & 16 deletions safety/scan/command.py
Original file line number Diff line number Diff line change
@@ -1,6 +1,7 @@
from enum import Enum
import logging
from pathlib import Path

import sys
from typing import Any, Dict, List, Optional, Set, Tuple
from typing_extensions import Annotated
Expand All @@ -14,7 +15,7 @@
from rich.padding import Padding
import typer
from safety.auth.constants import SAFETY_PLATFORM_URL
from safety.cli_util import get_command_for
from safety.cli_util import get_command_for, get_git_branch_name
from rich.console import Console
from safety.errors import SafetyError

Expand Down Expand Up @@ -139,9 +140,17 @@ def process_report(
if obj.platform_enabled and report_url:
if report.metadata.scan_type is ScanType.scan:
project_url = f"{SAFETY_PLATFORM_URL}{obj.project.url_path}"
lines.append(f"Scan report: [link]{report_url}[/link]")
lines.append("Project dashboard: " \
f"[link]{project_url}[/link]")
# Get the current branch name
branch_name = get_git_branch_name()

# Append the branch name if available
if branch_name:
project_url_with_branch = f"{project_url}?branch={branch_name}"
else:
project_url_with_branch = project_url

lines.append(f"Project dashboard: [link]{project_url_with_branch}[/link]")

elif report.metadata.scan_type is ScanType.system_scan:
lines.append(f"System scan report: [link]{report_url}[/link]")

Expand Down Expand Up @@ -246,7 +255,7 @@ def scan(ctx: typer.Context,
"""
Scans a project (defaulted to the current directory) for supply-chain security and configuration issues
"""

if not ctx.obj.metadata.authenticated:
raise SafetyError("Authentication required. Please run 'safety auth login' to authenticate before using this command.")

Expand Down Expand Up @@ -371,7 +380,7 @@ def sort_vulns_by_score(vuln: Vulnerability) -> int:
detailed_output=detailed_output)

lines = []

if spec.remediation.recommended:
total_resolved_vulns += spec.remediation.vulnerabilities_found

Expand Down Expand Up @@ -441,18 +450,18 @@ def sort_vulns_by_score(vuln: Vulnerability) -> int:
telemetry=telemetry,
files=[],
projects=[ctx.obj.project])

total_issues_with_duplicates, total_ignored_issues = get_vulnerability_summary(report.as_v30())

print_summary(
console=console,
total_issues_with_duplicates=total_issues_with_duplicates,
console=console,
total_issues_with_duplicates=total_issues_with_duplicates,
total_ignored_issues=total_ignored_issues,
project=ctx.obj.project,
dependencies_count=count,
fixes_count=fixes_count,
resolved_vulns_per_fix=total_resolved_vulns,
is_detailed_output=detailed_output,
project=ctx.obj.project,
dependencies_count=count,
fixes_count=fixes_count,
resolved_vulns_per_fix=total_resolved_vulns,
is_detailed_output=detailed_output,
ignored_vulns_data=ignored_vulns_data
)

Expand Down Expand Up @@ -796,7 +805,7 @@ def get_vulnerability_summary(report: Dict[str, Any]) -> Tuple[int, int]:
Args:
report (ReportModel): The report containing vulnerability data.
Returns:
Tuple[int, int]: A tuple containing:
- Total number of issues (including duplicates)
Expand Down

0 comments on commit 4b18043

Please sign in to comment.