Skip to main content

Rust-backed secrets detection plugin for MCP Gateway

Project description

cpex-secrets-detection

Rust-backed secrets detection plugin for MCP Gateway / CPEX.

Runtime Requirements

This plugin depends on cpex>=0.1.0rc1,<0.2 and imports hook models from cpex.framework. The compiled Rust extension is mandatory; there is no Python fallback implementation.

What it does

This plugin scans hook payloads for likely secrets and can either:

  • block processing when a secret is found
  • redact matched values in the returned payload
  • attach findings metadata to the hook result

Supported hooks:

  • prompt_pre_fetch: scans payload.args
  • tool_post_invoke: scans payload.result
  • resource_post_fetch: scans payload.content.text

It walks nested values, not just top-level strings. Coverage includes:

  • plain strings
  • dict
  • list
  • tuple
  • custom Python objects with __dict__
  • slot-based objects with __slots__
  • Pydantic-style objects that expose model_dump() and model_copy()

When redaction is enabled, the plugin preserves payload shape as much as possible instead of flattening everything to plain dicts.

Exact detector coverage

The plugin ships these regex-based detectors:

  • aws_access_key_id
  • aws_secret_access_key
  • google_api_key
  • github_token
  • stripe_secret_key
  • slack_token
  • private_key_block
  • generic_api_key_assignment
  • jwt_like
  • hex_secret_32
  • base64_24

Default behavior:

  • enabled by default:
    • aws_access_key_id
    • aws_secret_access_key
    • google_api_key
    • github_token
    • stripe_secret_key
    • slack_token
    • private_key_block
  • disabled by default because they are broader and more false-positive-prone:
    • generic_api_key_assignment
    • jwt_like
    • hex_secret_32
    • base64_24

What it does not do

This plugin is intentionally narrow. It does not:

  • verify whether a matched credential is real, active, or revoked
  • call external services
  • decode or unpack data before scanning
    • no base64 decode pass
    • no hex decode pass
    • no gzip, zip, or archive inspection
  • scan binary resource bodies
    • resource_post_fetch only scans content.text
  • inspect arbitrary object internals unless they are exposed through supported Python state surfaces such as model_dump(), __dict__, or __slots__
  • guarantee detection of every secret format
    • coverage is limited to the listed regex patterns
  • use entropy scoring, ML classification, or semantic analysis
  • infer secret validity from surrounding prose

It also does not emit the original matched secret in outward-facing findings metadata or violation examples. Those surfaces contain secret types only.

Config

Available config keys:

  • enabled: map of detector name to true or false
  • redact: whether to replace matches in returned payloads
  • redaction_text: replacement text used when redact=true
  • block_on_detection: whether to stop processing on detection
  • min_findings_to_block: threshold for blocking

Defaults:

enabled:
  aws_access_key_id: true
  aws_secret_access_key: true
  google_api_key: true
  github_token: true
  stripe_secret_key: true
  generic_api_key_assignment: false
  slack_token: true
  private_key_block: true
  jwt_like: false
  hex_secret_32: false
  base64_24: false
redact: false
redaction_text: "***REDACTED***"
block_on_detection: true
min_findings_to_block: 1

Result shape

On detection, the plugin may return:

  • modified_payload with redacted values when redact=true
  • metadata.count
  • metadata.secrets_redacted=true when redaction happened
  • metadata.secrets_findings=[{"type": "..."}] when reporting findings without redaction
  • a PluginViolation with code="SECRETS_DETECTED" when blocking

Build

uv sync --dev
make install
make test-all

Project details


Download files

Download the file for your platform. If you're not sure which to choose, learn more about installing packages.

Source Distribution

cpex_secrets_detection-0.3.0.tar.gz (100.6 kB view details)

Uploaded Source

Built Distributions

If you're not sure about the file name format, learn more about wheel file names.

cpex_secrets_detection-0.3.0-cp311-abi3-win_amd64.whl (777.7 kB view details)

Uploaded CPython 3.11+Windows x86-64

cpex_secrets_detection-0.3.0-cp311-abi3-manylinux_2_34_x86_64.whl (851.8 kB view details)

Uploaded CPython 3.11+manylinux: glibc 2.34+ x86-64

cpex_secrets_detection-0.3.0-cp311-abi3-manylinux_2_34_s390x.whl (889.1 kB view details)

Uploaded CPython 3.11+manylinux: glibc 2.34+ s390x

cpex_secrets_detection-0.3.0-cp311-abi3-manylinux_2_34_ppc64le.whl (875.0 kB view details)

Uploaded CPython 3.11+manylinux: glibc 2.34+ ppc64le

cpex_secrets_detection-0.3.0-cp311-abi3-manylinux_2_34_aarch64.whl (790.4 kB view details)

Uploaded CPython 3.11+manylinux: glibc 2.34+ ARM64

cpex_secrets_detection-0.3.0-cp311-abi3-macosx_11_0_arm64.whl (748.3 kB view details)

Uploaded CPython 3.11+macOS 11.0+ ARM64

File details

Details for the file cpex_secrets_detection-0.3.0.tar.gz.

File metadata

  • Download URL: cpex_secrets_detection-0.3.0.tar.gz
  • Upload date:
  • Size: 100.6 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? Yes
  • Uploaded via: twine/6.1.0 CPython/3.13.7

File hashes

Hashes for cpex_secrets_detection-0.3.0.tar.gz
Algorithm Hash digest
SHA256 ebf5436cefa66739735874216b4f46d8e2ccf637732fee56af8e053778d355b3
MD5 2a4d9fdbb00e7bfcd095077560bc5903
BLAKE2b-256 d672c79c733d855b62777bb3131eafaa872c802b024b21942672620fa6ccbb78

See more details on using hashes here.

Provenance

The following attestation bundles were made for cpex_secrets_detection-0.3.0.tar.gz:

Publisher: release-rust-python-package.yaml on IBM/cpex-plugins

Attestations: Values shown here reflect the state when the release was signed and may no longer be current.

File details

Details for the file cpex_secrets_detection-0.3.0-cp311-abi3-win_amd64.whl.

File metadata

File hashes

Hashes for cpex_secrets_detection-0.3.0-cp311-abi3-win_amd64.whl
Algorithm Hash digest
SHA256 5365fca8b3bf304549d9d760dacb7fc1bba624e7e37c1daf4c957bc1cdedeab2
MD5 97cfcc977cffeab8e0e179bd8a936227
BLAKE2b-256 d0f5c522d71c1325ac6a198bbe50dded4f608d23b00a51fda0079e7b3bf3eeeb

See more details on using hashes here.

Provenance

The following attestation bundles were made for cpex_secrets_detection-0.3.0-cp311-abi3-win_amd64.whl:

Publisher: release-rust-python-package.yaml on IBM/cpex-plugins

Attestations: Values shown here reflect the state when the release was signed and may no longer be current.

File details

Details for the file cpex_secrets_detection-0.3.0-cp311-abi3-manylinux_2_34_x86_64.whl.

File metadata

File hashes

Hashes for cpex_secrets_detection-0.3.0-cp311-abi3-manylinux_2_34_x86_64.whl
Algorithm Hash digest
SHA256 071f20c03211cae2ecf1748b0d85bb10510106b9e9a299b750e97a1ac2817017
MD5 ec758b1bac9b59a73ea6c43689fd87ff
BLAKE2b-256 ac498d0bbf4ba62cfcfe344139a6c1e4224f3b063fcdf9fbff89869b4fd6dabc

See more details on using hashes here.

Provenance

The following attestation bundles were made for cpex_secrets_detection-0.3.0-cp311-abi3-manylinux_2_34_x86_64.whl:

Publisher: release-rust-python-package.yaml on IBM/cpex-plugins

Attestations: Values shown here reflect the state when the release was signed and may no longer be current.

File details

Details for the file cpex_secrets_detection-0.3.0-cp311-abi3-manylinux_2_34_s390x.whl.

File metadata

File hashes

Hashes for cpex_secrets_detection-0.3.0-cp311-abi3-manylinux_2_34_s390x.whl
Algorithm Hash digest
SHA256 d9275a7f814a4fed574c8034db0a1544d08aaf502144f3875e412de4ad9e75fd
MD5 0ff312dc7f781eebec79582b382dadb9
BLAKE2b-256 a7d8e1d43c2a1aa893d2fc48f924712c88626bdc25f16ee88507104f8a2ab949

See more details on using hashes here.

Provenance

The following attestation bundles were made for cpex_secrets_detection-0.3.0-cp311-abi3-manylinux_2_34_s390x.whl:

Publisher: release-rust-python-package.yaml on IBM/cpex-plugins

Attestations: Values shown here reflect the state when the release was signed and may no longer be current.

File details

Details for the file cpex_secrets_detection-0.3.0-cp311-abi3-manylinux_2_34_ppc64le.whl.

File metadata

File hashes

Hashes for cpex_secrets_detection-0.3.0-cp311-abi3-manylinux_2_34_ppc64le.whl
Algorithm Hash digest
SHA256 8555ea4086703f3fb116d4d8d1784ec709054561b8c0ffc3a82f0c44bf17fcb6
MD5 cde2738f6911e9ab74ef99522a8f2fa3
BLAKE2b-256 54167457cb2ed220a3e1da4600c6998c0175b7884463b37c381e476879c33b16

See more details on using hashes here.

Provenance

The following attestation bundles were made for cpex_secrets_detection-0.3.0-cp311-abi3-manylinux_2_34_ppc64le.whl:

Publisher: release-rust-python-package.yaml on IBM/cpex-plugins

Attestations: Values shown here reflect the state when the release was signed and may no longer be current.

File details

Details for the file cpex_secrets_detection-0.3.0-cp311-abi3-manylinux_2_34_aarch64.whl.

File metadata

File hashes

Hashes for cpex_secrets_detection-0.3.0-cp311-abi3-manylinux_2_34_aarch64.whl
Algorithm Hash digest
SHA256 4664bf34074583eb2ddf8445c0de4d0046931794e666d0eea1d1881cbcf53374
MD5 cc8584437eebb5335c93a8405d8f1e3a
BLAKE2b-256 0e8d81e53c3749c527fc0f731f6dd09a1dccc5b37e95993971060aa4eb23a60e

See more details on using hashes here.

Provenance

The following attestation bundles were made for cpex_secrets_detection-0.3.0-cp311-abi3-manylinux_2_34_aarch64.whl:

Publisher: release-rust-python-package.yaml on IBM/cpex-plugins

Attestations: Values shown here reflect the state when the release was signed and may no longer be current.

File details

Details for the file cpex_secrets_detection-0.3.0-cp311-abi3-macosx_11_0_arm64.whl.

File metadata

File hashes

Hashes for cpex_secrets_detection-0.3.0-cp311-abi3-macosx_11_0_arm64.whl
Algorithm Hash digest
SHA256 403e7a4990f22fe0f73d14f866ada958b57c9840ba4b9feda001c12cc5249992
MD5 5c7f77cd63dd3afe8186be516ccc10ea
BLAKE2b-256 c854efbef3337c57a07722e1b5034f6002cf4f7a8d661ba663c3506780c7c780

See more details on using hashes here.

Provenance

The following attestation bundles were made for cpex_secrets_detection-0.3.0-cp311-abi3-macosx_11_0_arm64.whl:

Publisher: release-rust-python-package.yaml on IBM/cpex-plugins

Attestations: Values shown here reflect the state when the release was signed and may no longer be current.

Supported by

AWS Cloud computing and Security Sponsor Datadog Monitoring Depot Continuous Integration Fastly CDN Google Download Analytics Pingdom Monitoring Sentry Error logging StatusPage Status page