Server data from the Official MCP Registry
Find and submit local 3D print files for manual PrintYourDuck quote review.
Find and submit local 3D print files for manual PrintYourDuck quote review.
Remote endpoints: streamable-http: https://printyourduck.com/api/mcp
PrintYourDuck MCP is a well-architected server with proper input validation, secure file handling, and appropriate permission scoping. The codebase demonstrates good security practices including path traversal protection, file size limits, and careful API boundary management. Minor code quality issues and logging concerns prevent a higher score, but no security vulnerabilities were identified. Package verification found 1 issue.
6 files analyzed · 6 issues found
Security scores are indicators to help you make informed decisions, not guarantees. Always review permissions before connecting any MCP server.
This plugin requests these system permissions. Most are normal for its category.
Available as Local & Remote
This plugin can run on your machine or connect to a hosted endpoint. during install.
From the project's GitHub README.
MCP server for sending local 3D print files to PrintYourDuck manual quote
review. It is built for coding-agent workflows where the user has generated or
selected a local .stl, .step, .stp, .3mf, .obj, or .zip file and
wants help preparing a quote request.
The server is preconfigured for https://printyourduck.com. Users do not need
to supply an API URL, API key, or shop routing configuration.
| Surface | Status |
|---|---|
| Remote MCP | Live at https://printyourduck.com/api/mcp |
| Local stdio package | Available via npm as @printyourduck/mcp |
| npm package | Public: @printyourduck/mcp |
| OCI image | Release target: ghcr.io/printyourduck/printyourduck-mcp:<version> |
| MCP Registry | Publish target: com.printyourduck/quote |
npx is the primary install path today. Use Docker only after verifying the
GHCR image is publicly pullable for the target version.
3D-print quote workflows are easy to get wrong when a user is coming from code, CAD generation, or rapid prototyping. This MCP server gives agents a narrow, auditable workflow:
It does not calculate instant pricing, collect payment at upload, automate checkout, or expose private operational details.
Use this now:
npx -y @printyourduck/mcp
Most stdio-capable MCP clients use a configuration like this:
{
"mcpServers": {
"printyourduck": {
"command": "npx",
"args": ["-y", "@printyourduck/mcp"]
}
}
}
Docker, after verifying the GHCR image is public:
docker run --rm -i ghcr.io/printyourduck/printyourduck-mcp:<version>
Remote-capable MCP clients can connect today:
https://printyourduck.com/api/mcp
| Tool | Purpose | Network/File Access |
|---|---|---|
get_printyourduck_quote_requirements | Returns accepted file types, material choices, required confirmations, and safety boundaries. | No local file access. No network. |
find_recent_printable_files | Finds recent printable files under an allowed local project directory. | Read-only local file metadata. |
submit_local_file_for_quote | Uploads one user-approved local file and creates a manual quote request. | Reads one allowed local file, uploads privately, then submits to PrintYourDuck. |
get_quote_status | Looks up public-safe quote status with quote ID and matching email. | Network request to PrintYourDuck only. |
Local file discovery and upload are limited to the current working directory by
default. Set PRINTYOURDUCK_MCP_ALLOWED_ROOTS to a path-delimited allowlist when
the MCP client should access additional project directories.
submit_local_file_for_quote derives a stable submissionId from the selected
file and quote details unless the caller provides one. Reuse that ID on retry to
avoid duplicate manual quote requests. The helper also caches the uploaded
private file key locally by submissionId and file hash so retries can reuse the
same uploaded file reference when the upload service returns a generated Blob
key.
This server preserves the PrintYourDuck manual-quote boundary:
Price ranges or instant estimates are a valid future capability only when they are explicitly scoped, tested, publicly documented, and clearly separated from checkout or payment collection.
pnpm install
pnpm check:release
Useful checks:
pnpm check # lint, tests, typecheck
pnpm check:security # audit, gitleaks, trufflehog
pnpm check:mcp # stdio initialize, tool list, fixture discovery, path guard
pnpm check:pack # npm tarball allowlist
pnpm check:mcp builds the server, starts it over stdio, verifies initialize and
tool metadata, creates a temporary .stl fixture, verifies local discovery, and
verifies files outside allowed roots are rejected before upload.
Run the live production smoke only when you intentionally want to create a real quote request:
PRINTYOURDUCK_MCP_LIVE_SMOKE=1 \
PRINTYOURDUCK_MCP_SMOKE_EMAIL=operator@example.com \
pnpm smoke:live
The live smoke uploads a tiny fixture through https://printyourduck.com,
submits one manual quote request, and verifies get_quote_status returns.
Only claim npm local-helper installability after all of these pass:
pnpm check:release
npm view @printyourduck/mcp version
VERSION="$(npm view @printyourduck/mcp version)"
gh release view "mcp-v${VERSION}"
PRINTYOURDUCK_MCP_LIVE_SMOKE=1 PRINTYOURDUCK_MCP_SMOKE_EMAIL=operator@example.com pnpm smoke:live
Release npm package changes from this dedicated MCP repository, not from the website repository.
The MCP Registry name is com.printyourduck/quote, so publication uses
domain-based HTTP authentication for printyourduck.com. Serve the public
v=MCPv1; ... record from https://printyourduck.com/.well-known/mcp-registry-auth
and keep the matching private key only in the MCP_REGISTRY_PRIVATE_KEY GitHub
Actions secret for this repository.
Only claim MCP Registry publication after this passes:
curl -f "https://registry.modelcontextprotocol.io/v0/servers/com.printyourduck%2Fquote/versions"
Only claim OCI/container installability after making package visibility public and running:
VERSION="$(node -p "require('./package.json').version")"
docker manifest inspect "ghcr.io/printyourduck/printyourduck-mcp:${VERSION}"
See CONTRIBUTING.md. Good first areas include client setup docs, path-safety hardening, MCP metadata safety, package release checks, and public-safe examples.
For security issues, see SECURITY.md. Do not include secrets, customer files, private file references, supplier/cost/margin details, or dashboard screenshots in public issues.
Be the first to review this server!
by Modelcontextprotocol · Developer Tools
Web content fetching and conversion for efficient LLM usage
by Toleno · Developer Tools
Toleno Network MCP Server — Manage your Toleno mining account with Claude AI using natural language.
by mcp-marketplace · Developer Tools
Create, build, and publish Python MCP servers to PyPI — conversationally.