Random-number utilities exposed via Model Context Protocol
Project description
Random Number MCP
Production-ready MCP server that provides LLMs with essential random generation abilities --- built entirely on Python's standard library.
🎲 Tools
| Tool | Purpose | Python function |
|---|---|---|
random_int |
Generate random integers | random.randint() |
random_float |
Generate random floats | random.uniform() |
random_choices |
Choose items from a list (optional weights) | random.choices() |
random_shuffle |
Return a new list with items shuffled | random.sample() |
secure_token_hex |
Generate cryptographically secure hex tokens | secrets.token_hex() |
secure_random_int |
Generate cryptographically secure integers | secrets.randbelow() |
🔧 Setup
Claude Desktop
Add this to your Claude Desktop configuration file:
macOS: ~/Library/Application Support/Claude/claude_desktop_config.json
Windows: %APPDATA%/Claude/claude_desktop_config.json
{
"mcpServers": {
"random-number": {
"command": "uvx",
"args": ["random-number-mcp"]
}
}
}
📋 Tool Reference
random_int
Generate a random integer between low and high (inclusive).
Parameters:
low(int): Lower bound (inclusive)high(int): Upper bound (inclusive)
Example:
{
"name": "random_int",
"arguments": {
"low": 1,
"high": 100
}
}
random_float
Generate a random float between low and high.
Parameters:
low(float, optional): Lower bound (default: 0.0)high(float, optional): Upper bound (default: 1.0)
Example:
{
"name": "random_float",
"arguments": {
"low": 0.5,
"high": 2.5
}
}
random_choices
Choose k items from a population with replacement, optionally weighted.
Parameters:
population(list): List of items to choose fromk(int, optional): Number of items to choose (default: 1)weights(list, optional): Weights for each item (default: equal weights)
Example:
{
"name": "random_choices",
"arguments": {
"population": ["red", "blue", "green", "yellow"],
"k": 2,
"weights": [0.4, 0.3, 0.2, 0.1]
}
}
random_shuffle
Return a new list with items in random order.
Parameters:
items(list): List of items to shuffle
Example:
{
"name": "random_shuffle",
"arguments": {
"items": [1, 2, 3, 4, 5]
}
}
secure_token_hex
Generate a cryptographically secure random hex token.
Parameters:
nbytes(int, optional): Number of random bytes (default: 32)
Example:
{
"name": "secure_token_hex",
"arguments": {
"nbytes": 16
}
}
secure_random_int
Generate a cryptographically secure random integer below upper_bound.
Parameters:
upper_bound(int): Upper bound (exclusive)
Example:
{
"name": "secure_random_int",
"arguments": {
"upper_bound": 1000
}
}
🔒 Security Considerations
This package provides both standard pseudorandom functions (suitable for simulations, games, etc.) and cryptographically secure functions (suitable for tokens, keys, etc.):
- Standard functions (
random_int,random_float,random_choices,random_shuffle): Use Python'srandommodule - fast but not cryptographically secure - Secure functions (
secure_token_hex,secure_random_int): Use Python'ssecretsmodule - slower but cryptographically secure
🛠️ Development
Prerequisites
- Python 3.10+
- uv package manager
Setup
# Clone the repository
git clone https://github.com/example/random-number-mcp
cd random-number-mcp
# Install dependencies
uv sync --dev
# Run tests
uv run pytest
# Run linting
uv run ruff check
uv run ruff format
# Type checking
uv run mypy src/
Building
# Build package
uv build
# Test installation
uv run --with dist/*.whl random-number-mcp
Notes
- The server communicates via STDIO using JSON-RPC 2.0 protocol.
Testing with MCP Inspector
For exploring and/or developing this server, use the MCP Inspector npm utility:
# Install MCP Inspector
npm install -g @modelcontextprotocol/inspector
# Run local development server with the inspector
npx @modelcontextprotocol/inspector uv run random-number-mcp
# Run PyPI production server with the inspector
npx @modelcontextprotocol/inspector uvx random-number-mcp
📝 License
MIT License - see LICENSE file for details.
🤝 Contributing
Contributions are welcome! Please feel free to submit a Pull Request.
📚 Links
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 random_number_mcp-0.1.0.tar.gz.
File metadata
- Download URL: random_number_mcp-0.1.0.tar.gz
- Upload date:
- Size: 8.9 kB
- Tags: Source
- Uploaded using Trusted Publishing? Yes
- Uploaded via: twine/6.1.0 CPython/3.12.9
File hashes
| Algorithm | Hash digest | |
|---|---|---|
| SHA256 |
f10861026bab1b2d23c8583f420b4799674b883f5d1ab40bcb47def1f87a4ba1
|
|
| MD5 |
f03ca522d450688dffc78db7adccb2d6
|
|
| BLAKE2b-256 |
7113ebf3f5ddcf171fd8772954115f11d33f20da153268f1fad96d0e33f13e89
|
Provenance
The following attestation bundles were made for random_number_mcp-0.1.0.tar.gz:
Publisher:
publish.yml on zazencodes/random-number-mcp
-
Statement:
-
Statement type:
https://in-toto.io/Statement/v1 -
Predicate type:
https://docs.pypi.org/attestations/publish/v1 -
Subject name:
random_number_mcp-0.1.0.tar.gz -
Subject digest:
f10861026bab1b2d23c8583f420b4799674b883f5d1ab40bcb47def1f87a4ba1 - Sigstore transparency entry: 249782308
- Sigstore integration time:
-
Permalink:
zazencodes/random-number-mcp@3b6296fadd75698b262b704f32ecef73e65c983c -
Branch / Tag:
refs/tags/v0.1.0 - Owner: https://github.com/zazencodes
-
Access:
public
-
Token Issuer:
https://token.actions.githubusercontent.com -
Runner Environment:
github-hosted -
Publication workflow:
publish.yml@3b6296fadd75698b262b704f32ecef73e65c983c -
Trigger Event:
release
-
Statement type:
File details
Details for the file random_number_mcp-0.1.0-py3-none-any.whl.
File metadata
- Download URL: random_number_mcp-0.1.0-py3-none-any.whl
- Upload date:
- Size: 7.2 kB
- Tags: Python 3
- Uploaded using Trusted Publishing? Yes
- Uploaded via: twine/6.1.0 CPython/3.12.9
File hashes
| Algorithm | Hash digest | |
|---|---|---|
| SHA256 |
e7a37f3504ece7b3a08482fe5a3fe77c3e64696aa2fb2309ccf8554747c83402
|
|
| MD5 |
8276da5bdf1b068794401552901031c5
|
|
| BLAKE2b-256 |
b99319154ebb2de969aac470ef520b3cf00a2384b167f4d954945950c234535e
|
Provenance
The following attestation bundles were made for random_number_mcp-0.1.0-py3-none-any.whl:
Publisher:
publish.yml on zazencodes/random-number-mcp
-
Statement:
-
Statement type:
https://in-toto.io/Statement/v1 -
Predicate type:
https://docs.pypi.org/attestations/publish/v1 -
Subject name:
random_number_mcp-0.1.0-py3-none-any.whl -
Subject digest:
e7a37f3504ece7b3a08482fe5a3fe77c3e64696aa2fb2309ccf8554747c83402 - Sigstore transparency entry: 249782312
- Sigstore integration time:
-
Permalink:
zazencodes/random-number-mcp@3b6296fadd75698b262b704f32ecef73e65c983c -
Branch / Tag:
refs/tags/v0.1.0 - Owner: https://github.com/zazencodes
-
Access:
public
-
Token Issuer:
https://token.actions.githubusercontent.com -
Runner Environment:
github-hosted -
Publication workflow:
publish.yml@3b6296fadd75698b262b704f32ecef73e65c983c -
Trigger Event:
release
-
Statement type: