MCP server for multi-language code analysis with structure extraction, metadata parsing, and search capabilities across Python, JavaScript, TypeScript, Rust, Go, C/C++, Java, PHP, C#, Ruby, Markdown, plain text, and images
Project description
░░░░░░░░░░░░░░░░░░░░░░░░░░░░░░░░░░░░░░░░░░░░░░░░░░░░░░░░░░░░░░░░░░░░░░░░░░░░
░ ░
░ ███████╗ ██████╗ █████╗ ███╗ ██╗████████╗ ██████╗ ██████╗ ██╗ ░
░ ██╔════╝██╔════╝██╔══██╗████╗ ██║╚══██╔══╝██╔═══██╗██╔═══██╗██║ ░
░ ███████╗██║ ███████║██╔██╗ ██║ ██║ ██║ ██║██║ ██║██║ ░
░ ╚════██║██║ ██╔══██║██║╚██╗██║ ██║ ██║ ██║██║ ██║██║ ░
░ ███████║╚██████╗██║ ██║██║ ╚████║ ██║ ╚██████╔╝╚██████╔╝███████╗ ░
░ ╚══════╝ ╚═════╝╚═╝ ╚═╝╚═╝ ╚═══╝ ╚═╝ ╚═════╝ ╚═════╝ ╚══════╝ ░
░ ░
░░░░░░░░░░░░░░░░░░░░░░░░░░░░░░░░░░░░░░░░░░░░░░░░░░░░░░░░░░░░░░░░░░░░░░░░░░░░
▓▓▓▓▓▓▓▓▓▓▓▓▓▓▓▓▓▓▓▓▓▓▓▓▓▓▓▓▓▓▓▓▓▓▓▓▓▓▓▓▓▓▓▓▓
╔═══════════════════════════════════════════╗
║ ▶ [▓▓▓▓▓▓▓▓▓░░] Scanning codebase... ║
║ ║
║ ╭───────────────────────────────────╮ ║
║ │ ✓ Classes ▓▓▓▓▓▓▓▓▓▓ 100% │ ║
║ │ ✓ Functions ▓▓▓▓▓▓▓▓▓▓ 100% │ ║
║ │ ✓ Metadata ▓▓▓▓▓▓▓▓▓▓ 100% │ ║
║ ╰───────────────────────────────────╯ ║
║ ║
║ tree-sitter powered • MCP ready ║
╚═══════════════════════════════════════════╝
▀▀▀▀▀▀▀▀▀▀▀▀▀▀▀▀▀▀▀▀▀▀▀▀▀▀▀▀▀▀▀▀▀▀▀▀▀▀▀▀▀▀▀▀▀
Scantool - File Scanner MCP
MCP server for analyzing source code structure across multiple languages. Extracts classes, functions, methods, and metadata (signatures, decorators, docstrings) with precise line numbers. Includes search and filtering capabilities for large codebases.
Quick Look
Get a compact codebase overview with scan_directory()
See your entire codebase structure at a glance with inline class/function names:
src/ (22 files, 15 classes, 127 functions, 89 methods)
├─ scanners/
│ ├─ python_scanner.py (1-329) [11.9KB, 2 hours ago] - PythonScanner
│ ├─ typescript_scanner.py (1-505) [18.9KB, 1 day ago] - TypeScriptScanner
│ └─ rust_scanner.py (1-481) [17.6KB, 3 days ago] - RustScanner
├─ scanner.py (1-232) [8.8KB, 5 mins ago] - FileScanner
├─ formatter.py (1-153) [5.7KB, 10 mins ago] - TreeFormatter
└─ server.py (1-353) [12.2KB, just now] - scan_file, scan_directory, search_structures, _filter_structures, _structures_to_json, ... (6 total)
Dive into detailed structure with scan_file()
Full hierarchical tree with methods, signatures, decorators, and docstrings:
example.py (1-57)
├─ file-info: 1.4KB modified: 2025-10-17 14:30
├─ imports: import statements (3-5)
├─ class: DatabaseManager (8-26)
│ "Manages database connections and queries."
│ ├─ method: __init__ (self, connection_string: str) (11-13)
│ ├─ method: connect (self) (15-17)
│ │ "Establish database connection."
│ ├─ method: disconnect (self) (19-22)
│ │ "Close database connection."
│ └─ method: query (self, sql: str) -> list (24-26)
│ "Execute a SQL query."
├─ class: UserService (29-45)
│ "Handles user-related operations."
│ ├─ method: __init__ (self, db: DatabaseManager) (32-33)
│ ├─ method: create_user (self, username: str, email: str) -> int (35-37)
│ │ "Create a new user."
│ ├─ method: get_user (self, user_id: int) -> Optional[dict] (39-41)
│ │ "Retrieve user by ID."
│ └─ method: delete_user (self, user_id: int) -> bool (43-45)
│ "Delete a user."
├─ function: validate_email (email: str) -> bool (48-50)
│ "Validate email format."
└─ function: main () (53-57)
"Main entry point."
Features
Core Capabilities
- Multi-language support: Python, JavaScript, TypeScript, Rust, Go, C/C++, Java, PHP, C#, Ruby, SQL (PostgreSQL, MySQL, SQLite), Markdown, Plain Text, Images
- Structure extraction: Classes, methods, functions, imports, headings, sections, paragraphs
- Metadata parsing: Function signatures with types, decorators, docstrings, modifiers (async, static, etc.)
- File metadata: Size, timestamps, permissions automatically included for all files
- Image analysis: Dimensions, format, colors, content type inference, optimization hints
- Precise line numbers: Every element includes (from-to) line ranges for safe file partitioning
- Error handling: Handles malformed files without crashing, with regex fallback parsing
Output Options
- Tree format: Hierarchical display with box-drawing characters (├─, └─, │)
- JSON format: Structured data output for programmatic use
- Configurable display: Toggle signatures, decorators, docstrings, complexity metrics
Tools
- preview_directory: Lightning-fast overview of directory structure (no code parsing, <0.5s even for huge repos)
- scan_file: Analyze a single file with full metadata extraction
- scan_file_content: Analyze file content directly (useful for remote files, GitHub, APIs)
- scan_directory: Hierarchical directory tree with integrated code structures and statistics
- search_structures: Find and filter structures by type, name pattern, decorator, or complexity
Installation
Install with uvx (Recommended)
# From GitHub
uvx --from git+https://github.com/mariusei/file-scanner-mcp scantool
# Or from PyPI
uvx scantool
Or from Smithery
https://smithery.ai/server/@mariusei/file-scanner-mcp
Install from Source
git clone https://github.com/mariusei/file-scanner-mcp.git
cd file-scanner-mcp
uv sync
uv run scantool
Configuration
Add to your Claude Desktop config (~/Library/Application Support/Claude/claude_desktop_config.json on macOS):
{
"mcpServers": {
"scantool": {
"command": "uvx",
"args": ["scantool"]
}
}
}
Or if installed from source:
{
"mcpServers": {
"scantool": {
"command": "uv",
"args": ["run", "--directory", "/path/to/file-scanner-mcp", "scantool"]
}
}
}
Usage
The server provides five MCP tools for code exploration:
Typical workflow:
-
Preview structure:
preview_directory()shows file counts and types without parsing- Returns in <0.5s for most repos
- Includes recommendations for next steps
-
Scan directories:
scan_directory()parses code and shows structures- Use preview recommendations to limit scope
- Respects .gitignore by default
-
Examine files:
scan_file()shows full method-level detail- Includes signatures, decorators, docstrings
- Returns precise line ranges
-
Search structures:
search_structures()filters by type, name, or decorator -
Read code: Use line ranges from previous steps
0. preview_directory - Quick metadata scan
Scans file system metadata without parsing code. Returns directory structure, file counts, and type distribution.
preview_directory(
directory=".",
max_depth=3, # Traversal depth (default: 3)
max_files_hint=100000, # Abort threshold (default: 100k)
show_top_n=8, # Directories to show (default: 8)
respect_gitignore=True # Honor .gitignore (default: True)
)
Example output:
/project (12.5k files, 2.3GB) scanned in 0.3s
Top dirs: files types size
src/ 2.8k py:2.5k md:50 180MB
├─ api/ 850 py 65MB
├─ services/ 420 py 28MB
└─ frontend/ 1.2k ts:900 tsx:300 82MB
tests/ 1.5k py 45MB
vendor/ 8k js:7k ts:800 2.0GB ⚠️ 3rd-party
Ignored: node_modules/ (45k files), .venv/ (12k)
💡 Quick start:
scan_directory("src/api", "**/*.py") → 850 files
scan_directory("src/services", "**/*.py") → 420 files
preview_directory("src/frontend") → deep dive
Use this before scan_directory() to scope your search in large codebases.
1. scan_file - Analyze a single file
scan_file(
file_path="path/to/your/file.py",
show_signatures=True, # Include function signatures with types
show_decorators=True, # Include @decorator annotations
show_docstrings=True, # Include first line of docstrings
show_complexity=False, # Show complexity metrics (lines, depth, branches)
output_format="tree" # "tree" or "json"
)
2. scan_file_content - Analyze content directly
Scan file content without requiring a local file path. Perfect for analyzing remote files from GitHub, APIs, or any content source.
scan_file_content(
content="def hello(): pass\n\nclass MyClass:\n pass",
filename="example.py", # Filename determines the parser (extension matters!)
show_signatures=True, # Include function signatures with types
show_decorators=True, # Include @decorator annotations
show_docstrings=True, # Include first line of docstrings
show_complexity=False, # Show complexity metrics
output_format="tree" # "tree" or "json"
)
Use cases:
- Analyzing files from GitHub without downloading
- Processing content from APIs or web requests
- Scanning dynamically generated code
- Working with content in memory
3. scan_directory - Compact codebase overview
Shows directory tree with inline class/function names for each file.
scan_directory(
directory="./src",
pattern="**/*", # Glob pattern (default: "**/*" = all files)
# "**/*.py" = all Python files
# "*/*" = 1 level deep only
# "src/**/*.{py,ts}" = Python/TypeScript in src/
max_files=None, # Limit number of files (default: None)
respect_gitignore=True, # Respect .gitignore (default: True)
exclude_patterns=None, # Additional exclusions (gitignore syntax)
output_format="tree" # "tree" or "json"
)
Output format (compact inline):
src/ (22 files, 15 classes, 127 functions, 89 methods)
├─ scanners/
│ ├─ python_scanner.py (1-329) [11.9KB, 2 hours ago] - PythonScanner
│ ├─ typescript_scanner.py (1-505) [18.9KB, 1 day ago] - TypeScriptScanner
│ └─ rust_scanner.py (1-481) [17.6KB, 3 days ago] - RustScanner
├─ scanner.py (1-232) [8.8KB, 5 mins ago] - FileScanner
├─ formatter.py (1-153) [5.7KB, 10 mins ago] - TreeFormatter
└─ server.py (1-353) [12.2KB, just now] - scan_file, scan_directory, search_structures, _filter_structures, _structures_to_json, ... (6 total)
Controlling scope:
# Specific file types
scan_directory("./src", pattern="**/*.py")
# Multiple types (brace expansion)
scan_directory("./src", pattern="**/*.{py,ts,js}")
# Shallow scan (1 level deep)
scan_directory(".", pattern="*/*")
# Exclude directories (respects .gitignore by default)
scan_directory(".", exclude_patterns=["tests/**", "docs/**"])
# Scan everything (ignores .gitignore)
scan_directory(".", respect_gitignore=False)
4. search_structures - Find and filter structures
# Find all test functions
search_structures(
directory="./tests",
type_filter="function",
name_pattern="^test_"
)
# Find all classes ending in "Manager"
search_structures(
directory="./src",
type_filter="class",
name_pattern=".*Manager$"
)
# Find functions with @staticmethod decorator
search_structures(
directory="./src",
has_decorator="@staticmethod"
)
# Find complex functions (>100 lines)
search_structures(
directory="./src",
type_filter="function",
min_complexity=100
)
Example Output
scan_file() - Detailed structure
Full hierarchical tree with methods, signatures, and metadata:
Python File
example.py (1-57)
├─ file-info: 1.4KB modified: 2 hours ago
├─ imports: import statements (3-5)
├─ class: DatabaseManager (8-26)
│ "Manages database connections and queries."
│ ├─ method: __init__ (self, connection_string: str) (11-13)
│ ├─ method: connect (self) (15-17)
│ │ "Establish database connection."
│ ├─ method: disconnect (self) (19-22)
│ │ "Close database connection."
│ └─ method: query (self, sql: str) -> list (24-26)
│ "Execute a SQL query."
├─ class: UserService (29-45)
│ "Handles user-related operations."
│ ├─ method: __init__ (self, db: DatabaseManager) (32-33)
│ ├─ method: create_user (self, username: str, email: str) -> int (35-37)
│ │ "Create a new user."
│ ├─ method: get_user (self, user_id: int) -> Optional[dict] (39-41)
│ │ "Retrieve user by ID."
│ └─ method: delete_user (self, user_id: int) -> bool (43-45)
│ "Delete a user."
├─ function: validate_email (email: str) -> bool (48-50)
│ "Validate email format."
└─ function: main () (53-57)
"Main entry point."
TypeScript File
example.ts (1-114)
├─ file-info: 2.2KB modified: 1 day ago
├─ imports: import statements (5-6)
├─ interface: Config (11-14)
│ "Configuration interface for authentication service."
├─ class: AuthService (19-52)
│ "Service for handling user authentication and authorization."
│ ├─ method: constructor (config: Config) (26-29)
│ │ "Constructs a new AuthService instance."
│ ├─ method: login (username: string, password: string) : Promise<User | null> (34-37) [async]
│ │ "Authenticates a user with username and password."
│ ├─ method: logout (userId: string) : Promise<void> (42-44) [async]
│ │ "Logs out a user by their ID."
│ └─ method: validateToken (token: string) : boolean (49-51)
│ "Validates an authentication token."
├─ class: UserManager (57-90)
│ "Manager class for user CRUD operations."
│ ├─ method: constructor (database: Database) (60-62)
│ ├─ method: createUser (username: string, email: string) : Promise<User> (67-75) [async]
│ │ "Creates a new user in the system."
│ ├─ method: getUser (id: string) : Promise<User | null> (80-82) [async]
│ │ "Retrieves a user by their ID."
│ └─ method: updateUser (id: string, data: Partial<User>) : Promise<User> (87-89) [async]
│ "Updates a user's information."
├─ function: generateId () : string (95-97)
│ "Generates a random unique identifier."
├─ function: validateEmail (email: string) : boolean (102-104)
│ "Validates an email address format."
└─ function: calculateStats (users: User[]) : { total: number; active: number } (109-114)
"Arrow function to calculate statistics."
SQL File
database.sql (1-43)
├─ file-info: 1.2KB modified: 3 hours ago
├─ table: auth_users (4-11)
│ "User authentication table"
│ ├─ column: id BIGINT PRIMARY KEY AUTO_INCREMENT (5-5)
│ ├─ column: username VARCHAR(50) NOT NULL UNIQUE (6-6)
│ ├─ column: email VARCHAR(100) NOT NULL UNIQUE (7-7)
│ ├─ column: password_hash VARCHAR(255) NOT NULL (8-8)
│ ├─ column: created_at TIMESTAMP DEFAULT (9-9)
│ └─ column: last_login TIMESTAMP (10-10)
├─ table: orders (15-21)
│ ├─ column: order_id INT PRIMARY KEY (16-16)
│ ├─ column: user_id BIGINT NOT NULL (17-17)
│ ├─ column: total_amount DECIMAL(12,2) (18-18)
│ └─ column: status VARCHAR(20) (19-19)
├─ view: recent_orders SELECT o.order_id, u.username, o.total... (24-32)
│ "View for recent orders"
├─ function: calculate_total_with_tax (subtotal DECIMAL, tax_rate DECIMAL) -> DECIMAL (35-37)
│ "Calculate order total with tax"
├─ index: idx_username ON auth_users (username) (40-40)
└─ index: idx_order_status_date ON orders (status, created_at DESC) (43-43)
"Composite index for order queries"
PostgreSQL Support: Fully parses PL/pgSQL including DO blocks, partitioning, and PostgreSQL-specific syntax.
Markdown File
example.md (1-119)
├─ file-info: 1.6KB modified: 3 hours ago
├─ heading-1: Project Documentation (1-98)
│ ├─ heading-2: Installation (5-23)
│ │ ├─ code-block: code block (bash) bash (9-12)
│ │ └─ heading-3: Quick Start (13-23)
│ │ └─ code-block: code block (python) python (17-23)
│ ├─ heading-2: Features (24-47)
│ │ ├─ code-block: code block (typescript) typescript (28-34)
│ │ └─ heading-3: Advanced Usage (35-47)
│ │ └─ code-block: code block (python) python (39-47)
│ ├─ heading-2: Configuration (48-60)
│ │ └─ heading-3: Environment Variables (52-60)
│ │ └─ code-block: code block (bash) bash (56-60)
│ └─ heading-2: API Reference (61-76)
│ ├─ heading-3: FileScanner Class (65-68)
│ └─ heading-3: TreeFormatter Class (69-76)
│ └─ heading-4: Options (73-76)
Plain Text File
example.txt (1-77)
├─ file-info: 2.5KB modified: 5 mins ago
├─ section: PROJECT OVERVIEW (1-6)
│ └─ paragraph: paragraph (4-5) (4-5)
├─ section: INTRODUCTION (7-12)
│ └─ paragraph: paragraph (9-11) (9-11)
├─ section: Features and Capabilities (13-23)
│ ├─ paragraph: paragraph (16-16) (16-16)
│ ├─ paragraph: paragraph (18-19) (18-19)
│ └─ paragraph: paragraph (21-22) (21-22)
├─ section: TECHNICAL DETAILS (24-33)
│ ├─ paragraph: paragraph (26-29) (26-29)
│ └─ paragraph: paragraph (31-32) (31-32)
└─ section: CONCLUSION (67-77)
├─ paragraph: paragraph (70-71) (70-71)
└─ paragraph: paragraph (73-74) (73-74)
Image File
logo.png (1-1)
├─ file-info: 45KB modified: 2025-10-15
├─ format: PNG - RGBA (1-1)
│ "Format: PNG, Color mode: RGBA"
├─ dimensions: 512×512 (1-1)
│ "Aspect ratio: 1:1 (square)"
├─ content-type: logo (1-1)
│ "Inferred based on size and format"
├─ colors: palette (1-1)
│ ├─ color: #ff5733 (1-1)
│ ├─ color: #33ff57 (1-1)
│ └─ color: #3357ff (1-1)
└─ transparency: has alpha channel (1-1)
JSON Output Format
Use output_format="json" for structured data:
{
"file": "example.py",
"structures": [
{
"type": "class",
"name": "DatabaseManager",
"start_line": 8,
"end_line": 26,
"docstring": "Manages database connections and queries.",
"children": [
{
"type": "method",
"name": "__init__",
"start_line": 11,
"end_line": 13,
"signature": "(self, connection_string: str)",
"children": []
},
{
"type": "method",
"name": "query",
"start_line": 24,
"end_line": 26,
"signature": "(self, sql: str) -> list",
"docstring": "Execute a SQL query.",
"modifiers": ["async"],
"children": []
}
]
}
]
}
Supported File Types
| Extension | Language | Extracted Elements |
|---|---|---|
.py, .pyw |
Python | classes, methods, functions, imports, decorators, docstrings |
.js, .jsx, .mjs, .cjs |
JavaScript | classes, methods, functions, imports, JSDoc comments |
.ts, .tsx, .mts, .cts |
TypeScript | classes, methods, functions, imports, type annotations, JSDoc |
.rs |
Rust | structs, enums, traits, impl blocks, functions, use statements, attributes |
.go |
Go | types, structs, interfaces, functions, methods, imports |
.c, .h |
C | functions, structs, enums, includes, comments |
.cpp, .hpp, .cc, .hh, .cxx, .hxx |
C++ | classes, functions, namespaces, templates, includes |
.java |
Java | classes, methods, interfaces, enums, annotations, imports |
.php, .phtml |
PHP | classes, methods, functions, traits, interfaces, namespaces, attributes |
.cs, .csx |
C# | classes, methods, properties, structs, enums, namespaces, attributes |
.rb, .rake, .gemspec |
Ruby | modules, classes, methods, singleton methods, comments |
.sql |
SQL | tables, views, functions, procedures, indexes, columns, DO blocks (PostgreSQL) |
.md |
Markdown | headings (h1-h6), code blocks with hierarchy |
.txt |
Plain Text | sections (all-caps, underlined), paragraphs |
.png, .jpg, .jpeg, .gif, .webp, .bmp, .ico |
Images | format, dimensions, colors, content type, optimization hints |
Note: All files automatically include file metadata (size, modified date, permissions) as the first structure node.
Use Cases
Code Navigation & Understanding
- Get structural overview of unfamiliar codebases
- Understand file organization before reading code
- Navigate large files using precise line ranges
Refactoring & Reorganization
- Identify class and function boundaries for safe splitting
- Find all implementations of specific patterns (e.g., all Manager classes)
- Locate functions above complexity thresholds for refactoring
Code Review & Analysis
- Generate structural diffs between versions
- Find all functions with specific decorators
- Identify test coverage gaps by searching test_ patterns
Documentation & Tooling
- Auto-generate table of contents with line numbers
- Extract API signatures for documentation
- Feed structured data to other analysis tools (JSON output)
AI Code Assistance
- Primary exploration tool: Prefer scantool over Glob/Grep/Read for initial codebase exploration
- Partition large files intelligently for LLM context windows
- Extract relevant code sections with exact boundaries
- Search for specific patterns across entire codebases
- Reduce token usage by getting structure first, reading content only when needed
Image & Asset Analysis
- Quick asset inventory: Scan image directories to understand formats and sizes
- Optimization opportunities: Find oversized images, unused alpha channels, inefficient formats
- Color palette extraction: Discover dominant colors for branding and design consistency
- Content categorization: Auto-detect icons, logos, photos, screenshots by size/format
- Format recommendations: Get suggestions for WebP conversion, JPEG vs PNG optimization
Architecture
scantool/
├── scanner.py # Core scanning logic using tree-sitter
├── formatter.py # Pretty tree formatting with box-drawing characters
├── server.py # FastMCP server implementation
└── tests/ # Test suite organized by language
├── python/
├── typescript/
├── text/
├── test_integration.py
└── conftest.py
Testing
Run tests using pytest:
# Run all tests
uv run pytest
# Run specific language tests
uv run pytest tests/python/
uv run pytest tests/typescript/
uv run pytest tests/text/
# Run with coverage
uv run pytest --cov=src/scantool
# Run with verbose output
uv run pytest -v
Tests are organized by language in tests/python/, tests/typescript/, and tests/text/ directories.
Contributing
See CONTRIBUTING.md for details on adding language support.
License
MIT License - see LICENSE file for details.
Dependencies
- FastMCP - MCP server framework
- tree-sitter - Parsing library
- uv - Python package installer
Known Limitations
MCP Tool Response Size Limit
Claude Desktop enforces a 25,000 token limit on MCP tool responses.
Built-in mitigations:
scan_directory()uses compact inline format (not full tree expansion)- Respects
.gitignoreby default (excludes node_modules, .venv, etc.) - Shows file metadata with relative timestamps (e.g., "2 hours ago")
Manual controls:
- Use
patternto limit scope:"**/*.py"vs"*/*"(shallow) - Use
max_filesto cap number of files processed - Use
exclude_patternsfor additional exclusions - Scan specific subdirectories instead of entire codebase
For large codebases:
# Scan specific areas
scan_directory("./src", pattern="**/*.py")
scan_directory("./tests", pattern="**/*.py")
Agent Delegation
When using Claude Code, asking to "explore the codebase" may delegate to the Explore agent which doesn't have access to MCP tools. Be explicit: "use scantool to scan the codebase" to ensure the MCP tool is used directly.
Support
Project details
Release history Release notifications | RSS feed
Download files
Download the file for your platform. If you're not sure which to choose, learn more about installing packages.
Source Distribution
Built Distribution
Filter files by name, interpreter, ABI, and platform.
If you're not sure about the file name format, learn more about wheel file names.
Copy a direct link to the current filters
File details
Details for the file scantool-0.9.8.tar.gz.
File metadata
- Download URL: scantool-0.9.8.tar.gz
- Upload date:
- Size: 9.2 MB
- Tags: Source
- Uploaded using Trusted Publishing? Yes
- Uploaded via: twine/6.1.0 CPython/3.13.7
File hashes
| Algorithm | Hash digest | |
|---|---|---|
| SHA256 |
ba3d887fd5c2df816102b6ab0feb1bbe5ee1ea0935c387a422fc1b6bebe20629
|
|
| MD5 |
4ceec3c385e96003478b373b12574a70
|
|
| BLAKE2b-256 |
648aef6ef254b1c64a823b2c9c9db4e624e09eebd0d5d4505170a057cdbbeff0
|
Provenance
The following attestation bundles were made for scantool-0.9.8.tar.gz:
Publisher:
publish.yml on mariusei/file-scanner-mcp
-
Statement:
-
Statement type:
https://in-toto.io/Statement/v1 -
Predicate type:
https://docs.pypi.org/attestations/publish/v1 -
Subject name:
scantool-0.9.8.tar.gz -
Subject digest:
ba3d887fd5c2df816102b6ab0feb1bbe5ee1ea0935c387a422fc1b6bebe20629 - Sigstore transparency entry: 661426120
- Sigstore integration time:
-
Permalink:
mariusei/file-scanner-mcp@afd5333634d798ece61290c18037b690d73b5887 -
Branch / Tag:
refs/tags/v0.9.8 - Owner: https://github.com/mariusei
-
Access:
public
-
Token Issuer:
https://token.actions.githubusercontent.com -
Runner Environment:
github-hosted -
Publication workflow:
publish.yml@afd5333634d798ece61290c18037b690d73b5887 -
Trigger Event:
release
-
Statement type:
File details
Details for the file scantool-0.9.8-py3-none-any.whl.
File metadata
- Download URL: scantool-0.9.8-py3-none-any.whl
- Upload date:
- Size: 85.3 kB
- Tags: Python 3
- Uploaded using Trusted Publishing? Yes
- Uploaded via: twine/6.1.0 CPython/3.13.7
File hashes
| Algorithm | Hash digest | |
|---|---|---|
| SHA256 |
4ad2fe0f2b457c03fea004f1d4b4f6bcef9dfc0c10f0952dbec55495f170a8a2
|
|
| MD5 |
567b1fb980d5b665dee20c1a089afa0c
|
|
| BLAKE2b-256 |
79e77ee332ab36925220327ea48814d33c56cfb8904fb2f574a41555d28314c8
|
Provenance
The following attestation bundles were made for scantool-0.9.8-py3-none-any.whl:
Publisher:
publish.yml on mariusei/file-scanner-mcp
-
Statement:
-
Statement type:
https://in-toto.io/Statement/v1 -
Predicate type:
https://docs.pypi.org/attestations/publish/v1 -
Subject name:
scantool-0.9.8-py3-none-any.whl -
Subject digest:
4ad2fe0f2b457c03fea004f1d4b4f6bcef9dfc0c10f0952dbec55495f170a8a2 - Sigstore transparency entry: 661426128
- Sigstore integration time:
-
Permalink:
mariusei/file-scanner-mcp@afd5333634d798ece61290c18037b690d73b5887 -
Branch / Tag:
refs/tags/v0.9.8 - Owner: https://github.com/mariusei
-
Access:
public
-
Token Issuer:
https://token.actions.githubusercontent.com -
Runner Environment:
github-hosted -
Publication workflow:
publish.yml@afd5333634d798ece61290c18037b690d73b5887 -
Trigger Event:
release
-
Statement type: