security-controls-mcp 0.3.5__tar.gz → 0.4.0__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.
- {security_controls_mcp-0.3.5 → security_controls_mcp-0.4.0}/CLAUDE.md +9 -6
- {security_controls_mcp-0.3.5 → security_controls_mcp-0.4.0}/PKG-INFO +38 -18
- {security_controls_mcp-0.3.5 → security_controls_mcp-0.4.0}/README.md +37 -17
- {security_controls_mcp-0.3.5 → security_controls_mcp-0.4.0}/pyproject.toml +6 -1
- {security_controls_mcp-0.3.5 → security_controls_mcp-0.4.0}/src/security_controls_mcp/__init__.py +1 -1
- security_controls_mcp-0.4.0/src/security_controls_mcp/data/framework-to-scf.json +130460 -0
- security_controls_mcp-0.4.0/src/security_controls_mcp/data/scf-controls.json +493687 -0
- security_controls_mcp-0.4.0/src/security_controls_mcp/data_loader.py +511 -0
- {security_controls_mcp-0.3.5 → security_controls_mcp-0.4.0}/src/security_controls_mcp.egg-info/PKG-INFO +38 -18
- {security_controls_mcp-0.3.5 → security_controls_mcp-0.4.0}/src/security_controls_mcp.egg-info/SOURCES.txt +1 -0
- security_controls_mcp-0.4.0/tests/test_ai_frameworks.py +126 -0
- {security_controls_mcp-0.3.5 → security_controls_mcp-0.4.0}/tests/test_data_loader.py +1 -1
- {security_controls_mcp-0.3.5 → security_controls_mcp-0.4.0}/tests/test_integration.py +1 -1
- {security_controls_mcp-0.3.5 → security_controls_mcp-0.4.0}/tests/test_smoke.py +3 -3
- security_controls_mcp-0.3.5/src/security_controls_mcp/data/framework-to-scf.json +0 -21404
- security_controls_mcp-0.3.5/src/security_controls_mcp/data/scf-controls.json +0 -73202
- security_controls_mcp-0.3.5/src/security_controls_mcp/data_loader.py +0 -197
- {security_controls_mcp-0.3.5 → security_controls_mcp-0.4.0}/.gitleaks.toml +0 -0
- {security_controls_mcp-0.3.5 → security_controls_mcp-0.4.0}/CHANGELOG.md +0 -0
- {security_controls_mcp-0.3.5 → security_controls_mcp-0.4.0}/Dockerfile +0 -0
- {security_controls_mcp-0.3.5 → security_controls_mcp-0.4.0}/LICENSE +0 -0
- {security_controls_mcp-0.3.5 → security_controls_mcp-0.4.0}/LICENSE-DATA.md +0 -0
- {security_controls_mcp-0.3.5 → security_controls_mcp-0.4.0}/MANIFEST.in +0 -0
- {security_controls_mcp-0.3.5 → security_controls_mcp-0.4.0}/PAID_STANDARDS_GUIDE.md +0 -0
- {security_controls_mcp-0.3.5 → security_controls_mcp-0.4.0}/SECURITY.md +0 -0
- {security_controls_mcp-0.3.5 → security_controls_mcp-0.4.0}/setup.cfg +0 -0
- {security_controls_mcp-0.3.5 → security_controls_mcp-0.4.0}/src/security_controls_mcp/__main__.py +0 -0
- {security_controls_mcp-0.3.5 → security_controls_mcp-0.4.0}/src/security_controls_mcp/cli.py +0 -0
- {security_controls_mcp-0.3.5 → security_controls_mcp-0.4.0}/src/security_controls_mcp/config.py +0 -0
- {security_controls_mcp-0.3.5 → security_controls_mcp-0.4.0}/src/security_controls_mcp/extractors/__init__.py +0 -0
- {security_controls_mcp-0.3.5 → security_controls_mcp-0.4.0}/src/security_controls_mcp/extractors/pdf_extractor.py +0 -0
- {security_controls_mcp-0.3.5 → security_controls_mcp-0.4.0}/src/security_controls_mcp/http_server.py +0 -0
- {security_controls_mcp-0.3.5 → security_controls_mcp-0.4.0}/src/security_controls_mcp/legal_notice.py +0 -0
- {security_controls_mcp-0.3.5 → security_controls_mcp-0.4.0}/src/security_controls_mcp/providers.py +0 -0
- {security_controls_mcp-0.3.5 → security_controls_mcp-0.4.0}/src/security_controls_mcp/registry.py +0 -0
- {security_controls_mcp-0.3.5 → security_controls_mcp-0.4.0}/src/security_controls_mcp/server.py +0 -0
- {security_controls_mcp-0.3.5 → security_controls_mcp-0.4.0}/src/security_controls_mcp.egg-info/dependency_links.txt +0 -0
- {security_controls_mcp-0.3.5 → security_controls_mcp-0.4.0}/src/security_controls_mcp.egg-info/entry_points.txt +0 -0
- {security_controls_mcp-0.3.5 → security_controls_mcp-0.4.0}/src/security_controls_mcp.egg-info/requires.txt +0 -0
- {security_controls_mcp-0.3.5 → security_controls_mcp-0.4.0}/src/security_controls_mcp.egg-info/top_level.txt +0 -0
- {security_controls_mcp-0.3.5 → security_controls_mcp-0.4.0}/tests/README.md +0 -0
- {security_controls_mcp-0.3.5 → security_controls_mcp-0.4.0}/tests/__init__.py +0 -0
- {security_controls_mcp-0.3.5 → security_controls_mcp-0.4.0}/tests/test_content_quality.py +0 -0
- {security_controls_mcp-0.3.5 → security_controls_mcp-0.4.0}/tests/test_paid_standards.py +0 -0
- {security_controls_mcp-0.3.5 → security_controls_mcp-0.4.0}/tests/test_security.py +0 -0
- {security_controls_mcp-0.3.5 → security_controls_mcp-0.4.0}/verify_production_ready.py +0 -0
|
@@ -4,11 +4,12 @@
|
|
|
4
4
|
|
|
5
5
|
## Project Overview
|
|
6
6
|
|
|
7
|
-
MCP server providing access to 1,451 security controls across
|
|
7
|
+
MCP server providing access to 1,451 security controls across **261 frameworks**. Uses SCF (Secure Controls Framework) as a rosetta stone for bidirectional framework mapping.
|
|
8
8
|
|
|
9
9
|
## Key Features
|
|
10
10
|
|
|
11
|
-
- **
|
|
11
|
+
- **261 Frameworks**: ISO 27001, NIST CSF, DORA, PCI DSS, SOC 2, CMMC, FedRAMP, and 254 more
|
|
12
|
+
- **AI Governance**: ISO 42001, NIST AI RMF, EU AI Act, Cyber Resilience Act
|
|
12
13
|
- **1,451 Controls**: Complete control catalog with descriptions
|
|
13
14
|
- **Bidirectional Mapping**: Map any framework to any other framework
|
|
14
15
|
- **Gap Analysis**: Compare control coverage between frameworks
|
|
@@ -157,14 +158,16 @@ poetry run pytest tests/test_map_frameworks.py -v
|
|
|
157
158
|
|
|
158
159
|
## Current Statistics
|
|
159
160
|
|
|
160
|
-
- **Frameworks**:
|
|
161
|
+
- **Frameworks**: 261 (expanded from 28 in v0.4.0)
|
|
161
162
|
- **Controls**: 1,451 unique controls
|
|
162
|
-
- **Mappings**:
|
|
163
|
-
- **Database Size**: ~
|
|
164
|
-
- **Tests**:
|
|
163
|
+
- **Mappings**: 50,000+ bidirectional relationships
|
|
164
|
+
- **Database Size**: ~7MB (JSON)
|
|
165
|
+
- **Tests**: 127 passing
|
|
165
166
|
|
|
166
167
|
## Version History
|
|
167
168
|
|
|
169
|
+
- **v0.4.0** (2026-02-05): Major framework expansion (28→261), AI governance support
|
|
170
|
+
- **v0.3.5** (2026-02-01): Entry point fix
|
|
168
171
|
- **v0.2.1** (2026-01-29): Framework expansion (16→28 frameworks)
|
|
169
172
|
- **v0.2.0**: Initial public release with 16 frameworks
|
|
170
173
|
- **v0.1.0**: Internal beta
|
|
@@ -1,6 +1,6 @@
|
|
|
1
1
|
Metadata-Version: 2.4
|
|
2
2
|
Name: security-controls-mcp
|
|
3
|
-
Version: 0.
|
|
3
|
+
Version: 0.4.0
|
|
4
4
|
Summary: MCP server for querying security framework controls (SCF) - map between ISO 27001, NIST CSF, DORA, PCI DSS, and more
|
|
5
5
|
Author-email: Ansvar Systems <hello@ansvar.eu>
|
|
6
6
|
License-Expression: Apache-2.0
|
|
@@ -42,13 +42,14 @@ Dynamic: license-file
|
|
|
42
42
|
|
|
43
43
|
## Overview
|
|
44
44
|
|
|
45
|
-
|
|
45
|
+
**THE definitive MCP server for security framework mapping.** Makes 1,451 security controls across **261 frameworks** searchable and AI-accessible through Claude, Cursor, or any MCP-compatible client.
|
|
46
46
|
|
|
47
47
|
Built on the [Secure Controls Framework (SCF)](https://securecontrolsframework.com/) by ComplianceForge.
|
|
48
48
|
|
|
49
49
|
**Key capabilities:**
|
|
50
50
|
- 1,451 security controls across governance, risk, compliance, and technical domains
|
|
51
|
-
-
|
|
51
|
+
- **261 frameworks** including ISO 27001, NIST CSF, DORA, PCI DSS, CMMC, and 256 more
|
|
52
|
+
- **AI Governance:** ISO 42001, NIST AI RMF, EU AI Act, Cyber Resilience Act
|
|
52
53
|
- Bidirectional mapping between frameworks via SCF rosetta stone
|
|
53
54
|
- Optional integration with purchased standards (ISO, NIST 800-53) for official text
|
|
54
55
|
- Full-text search across all control descriptions
|
|
@@ -119,27 +120,46 @@ Same configuration under `"mcp.servers"` in your settings.
|
|
|
119
120
|
- "List all controls needed for PCI DSS compliance"
|
|
120
121
|
- "Which DORA requirements does ISO 27001 A.5.15 satisfy?"
|
|
121
122
|
- "Show me all NIST CSF 2.0 controls related to incident response"
|
|
122
|
-
|
|
123
|
-
|
|
124
|
-
|
|
125
|
-
|
|
126
|
-
|
|
127
|
-
|
|
128
|
-
- **
|
|
129
|
-
- **
|
|
130
|
-
- **
|
|
131
|
-
- **
|
|
132
|
-
- **
|
|
133
|
-
|
|
123
|
+
- **NEW:** "What ISO 42001 controls map to NIST AI RMF?"
|
|
124
|
+
- **NEW:** "Show me EU AI Act requirements for high-risk AI systems"
|
|
125
|
+
|
|
126
|
+
## Available Frameworks (261)
|
|
127
|
+
|
|
128
|
+
### AI Governance (NEW in v0.4.0)
|
|
129
|
+
- **ISO 42001:2023** (149) - AI Management System
|
|
130
|
+
- **NIST AI RMF 1.0** (158) - AI Risk Management Framework
|
|
131
|
+
- **NIST AI 600-1** (139) - Generative AI Profile
|
|
132
|
+
- **EU AI Act** (119) - Regulation 2024/1689
|
|
133
|
+
- **EU Cyber Resilience Act** (18)
|
|
134
|
+
|
|
135
|
+
### Core Frameworks
|
|
136
|
+
- **US Government:** NIST 800-53 R5 (777), NIST CSF 2.0 (253), FedRAMP R5 (423), CMMC 2.0 (198/52)
|
|
137
|
+
- **International Standards:** ISO 27001 (51), ISO 27002 (316), ISO 27017 (119), ISO 27018 (70), ISO 27701 (187), ISO 22301 (52)
|
|
138
|
+
- **US Industry:** PCI DSS v4.0.1 (364), SOC 2 (412), HIPAA (136), SOX (2)
|
|
139
|
+
- **Financial:** SWIFT CSCF 2023 (127), FFIEC (231), GLBA (108), DORA (103)
|
|
140
|
+
- **Cloud:** CSA CCM v4 (334), Germany C5 (239)
|
|
141
|
+
|
|
142
|
+
### Regional Coverage (50+ countries)
|
|
143
|
+
- **APAC:** Australia ISM/Essential 8, Singapore MAS TRM, Japan ISMAP, China Cybersecurity Law, India DPDPA
|
|
144
|
+
- **EU:** GDPR (42), NIS2 (68), PSD2 (61), plus 20+ national frameworks
|
|
145
|
+
- **Americas:** US state laws (CA, NY, TX, etc.), Brazil LGPD, Canada PIPEDA
|
|
146
|
+
- **Middle East/Africa:** Saudi SAMA, UAE NIAF, South Africa POPIA
|
|
147
|
+
|
|
148
|
+
### Specialized
|
|
149
|
+
- **Industrial/OT:** IEC 62443 (197), NERC CIP (224), NIST 800-82
|
|
150
|
+
- **Automotive:** ISO/SAE 21434, TISAX, UN R155
|
|
151
|
+
- **Healthcare:** HIPAA, HITRUST, CMS MARS-E
|
|
152
|
+
|
|
153
|
+
See [docs/coverage.md](docs/coverage.md) for the complete list of 261 frameworks.
|
|
134
154
|
|
|
135
155
|
## Tools
|
|
136
156
|
|
|
137
157
|
### Core Tools
|
|
138
158
|
|
|
139
|
-
**`list_frameworks()`** - List all
|
|
159
|
+
**`list_frameworks()`** - List all 261 frameworks with control counts
|
|
140
160
|
|
|
141
161
|
**`get_control(control_id)`** - Get full details for a specific SCF control
|
|
142
|
-
- Returns description, domain, weight, PPTDF category, and mappings to all
|
|
162
|
+
- Returns description, domain, weight, PPTDF category, and mappings to all 261 frameworks
|
|
143
163
|
|
|
144
164
|
**`search_controls(query, frameworks=[], limit=10)`** - Search controls by keyword
|
|
145
165
|
- Optional framework filtering
|
|
@@ -207,7 +227,7 @@ SCF JSON → In-memory index → MCP tools → AI response
|
|
|
207
227
|
Based on **SCF 2025.4** (released December 29, 2025)
|
|
208
228
|
|
|
209
229
|
- 1,451 controls across all domains
|
|
210
|
-
-
|
|
230
|
+
- **261 frameworks** with full mapping coverage
|
|
211
231
|
- Licensed under Creative Commons (data)
|
|
212
232
|
- Source: [ComplianceForge SCF](https://securecontrolsframework.com/)
|
|
213
233
|
|
|
@@ -9,13 +9,14 @@
|
|
|
9
9
|
|
|
10
10
|
## Overview
|
|
11
11
|
|
|
12
|
-
|
|
12
|
+
**THE definitive MCP server for security framework mapping.** Makes 1,451 security controls across **261 frameworks** searchable and AI-accessible through Claude, Cursor, or any MCP-compatible client.
|
|
13
13
|
|
|
14
14
|
Built on the [Secure Controls Framework (SCF)](https://securecontrolsframework.com/) by ComplianceForge.
|
|
15
15
|
|
|
16
16
|
**Key capabilities:**
|
|
17
17
|
- 1,451 security controls across governance, risk, compliance, and technical domains
|
|
18
|
-
-
|
|
18
|
+
- **261 frameworks** including ISO 27001, NIST CSF, DORA, PCI DSS, CMMC, and 256 more
|
|
19
|
+
- **AI Governance:** ISO 42001, NIST AI RMF, EU AI Act, Cyber Resilience Act
|
|
19
20
|
- Bidirectional mapping between frameworks via SCF rosetta stone
|
|
20
21
|
- Optional integration with purchased standards (ISO, NIST 800-53) for official text
|
|
21
22
|
- Full-text search across all control descriptions
|
|
@@ -86,27 +87,46 @@ Same configuration under `"mcp.servers"` in your settings.
|
|
|
86
87
|
- "List all controls needed for PCI DSS compliance"
|
|
87
88
|
- "Which DORA requirements does ISO 27001 A.5.15 satisfy?"
|
|
88
89
|
- "Show me all NIST CSF 2.0 controls related to incident response"
|
|
89
|
-
|
|
90
|
-
|
|
91
|
-
|
|
92
|
-
|
|
93
|
-
|
|
94
|
-
|
|
95
|
-
- **
|
|
96
|
-
- **
|
|
97
|
-
- **
|
|
98
|
-
- **
|
|
99
|
-
- **
|
|
100
|
-
|
|
90
|
+
- **NEW:** "What ISO 42001 controls map to NIST AI RMF?"
|
|
91
|
+
- **NEW:** "Show me EU AI Act requirements for high-risk AI systems"
|
|
92
|
+
|
|
93
|
+
## Available Frameworks (261)
|
|
94
|
+
|
|
95
|
+
### AI Governance (NEW in v0.4.0)
|
|
96
|
+
- **ISO 42001:2023** (149) - AI Management System
|
|
97
|
+
- **NIST AI RMF 1.0** (158) - AI Risk Management Framework
|
|
98
|
+
- **NIST AI 600-1** (139) - Generative AI Profile
|
|
99
|
+
- **EU AI Act** (119) - Regulation 2024/1689
|
|
100
|
+
- **EU Cyber Resilience Act** (18)
|
|
101
|
+
|
|
102
|
+
### Core Frameworks
|
|
103
|
+
- **US Government:** NIST 800-53 R5 (777), NIST CSF 2.0 (253), FedRAMP R5 (423), CMMC 2.0 (198/52)
|
|
104
|
+
- **International Standards:** ISO 27001 (51), ISO 27002 (316), ISO 27017 (119), ISO 27018 (70), ISO 27701 (187), ISO 22301 (52)
|
|
105
|
+
- **US Industry:** PCI DSS v4.0.1 (364), SOC 2 (412), HIPAA (136), SOX (2)
|
|
106
|
+
- **Financial:** SWIFT CSCF 2023 (127), FFIEC (231), GLBA (108), DORA (103)
|
|
107
|
+
- **Cloud:** CSA CCM v4 (334), Germany C5 (239)
|
|
108
|
+
|
|
109
|
+
### Regional Coverage (50+ countries)
|
|
110
|
+
- **APAC:** Australia ISM/Essential 8, Singapore MAS TRM, Japan ISMAP, China Cybersecurity Law, India DPDPA
|
|
111
|
+
- **EU:** GDPR (42), NIS2 (68), PSD2 (61), plus 20+ national frameworks
|
|
112
|
+
- **Americas:** US state laws (CA, NY, TX, etc.), Brazil LGPD, Canada PIPEDA
|
|
113
|
+
- **Middle East/Africa:** Saudi SAMA, UAE NIAF, South Africa POPIA
|
|
114
|
+
|
|
115
|
+
### Specialized
|
|
116
|
+
- **Industrial/OT:** IEC 62443 (197), NERC CIP (224), NIST 800-82
|
|
117
|
+
- **Automotive:** ISO/SAE 21434, TISAX, UN R155
|
|
118
|
+
- **Healthcare:** HIPAA, HITRUST, CMS MARS-E
|
|
119
|
+
|
|
120
|
+
See [docs/coverage.md](docs/coverage.md) for the complete list of 261 frameworks.
|
|
101
121
|
|
|
102
122
|
## Tools
|
|
103
123
|
|
|
104
124
|
### Core Tools
|
|
105
125
|
|
|
106
|
-
**`list_frameworks()`** - List all
|
|
126
|
+
**`list_frameworks()`** - List all 261 frameworks with control counts
|
|
107
127
|
|
|
108
128
|
**`get_control(control_id)`** - Get full details for a specific SCF control
|
|
109
|
-
- Returns description, domain, weight, PPTDF category, and mappings to all
|
|
129
|
+
- Returns description, domain, weight, PPTDF category, and mappings to all 261 frameworks
|
|
110
130
|
|
|
111
131
|
**`search_controls(query, frameworks=[], limit=10)`** - Search controls by keyword
|
|
112
132
|
- Optional framework filtering
|
|
@@ -174,7 +194,7 @@ SCF JSON → In-memory index → MCP tools → AI response
|
|
|
174
194
|
Based on **SCF 2025.4** (released December 29, 2025)
|
|
175
195
|
|
|
176
196
|
- 1,451 controls across all domains
|
|
177
|
-
-
|
|
197
|
+
- **261 frameworks** with full mapping coverage
|
|
178
198
|
- Licensed under Creative Commons (data)
|
|
179
199
|
- Source: [ComplianceForge SCF](https://securecontrolsframework.com/)
|
|
180
200
|
|
|
@@ -1,6 +1,6 @@
|
|
|
1
1
|
[project]
|
|
2
2
|
name = "security-controls-mcp"
|
|
3
|
-
version = "0.
|
|
3
|
+
version = "0.4.0"
|
|
4
4
|
description = "MCP server for querying security framework controls (SCF) - map between ISO 27001, NIST CSF, DORA, PCI DSS, and more"
|
|
5
5
|
readme = "README.md"
|
|
6
6
|
requires-python = ">=3.10"
|
|
@@ -73,3 +73,8 @@ target-version = "py310"
|
|
|
73
73
|
[tool.ruff.lint]
|
|
74
74
|
select = ["E", "F", "I"]
|
|
75
75
|
ignore = ["E501"] # Ignore line length (allow > 100 chars)
|
|
76
|
+
|
|
77
|
+
[dependency-groups]
|
|
78
|
+
dev = [
|
|
79
|
+
"openpyxl (>=3.1.5,<4.0.0)"
|
|
80
|
+
]
|