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 | Live as 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
For team-shared or reproducible client configs, pin a package version:
npx -y @printyourduck/mcp@<version>
MCP client configuration files are not identical across clients. Use the shape expected by your client, then restart or refresh that client so it reloads the server.
Claude Code, local user setup:
claude mcp add --transport stdio printyourduck -- npx -y @printyourduck/mcp
Claude Code, project-shared .mcp.json:
{
"mcpServers": {
"printyourduck": {
"command": "npx",
"args": ["-y", "@printyourduck/mcp"]
}
}
}
Use project-shared .mcp.json only when a repository should intentionally
offer PrintYourDuck tools to everyone opening that project. Claude Code prompts
for approval before using project-scoped MCP servers.
VS Code workspace setup in .vscode/mcp.json:
{
"servers": {
"printyourduck": {
"command": "npx",
"args": ["-y", "@printyourduck/mcp"]
}
}
}
Clients that use the common mcpServers shape can use the Claude Code project
snippet above.
Test the local server with MCP Inspector:
npx -y @modelcontextprotocol/inspector npx -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
Claude Code remote HTTP setup:
claude mcp add --transport http printyourduck 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.
For each tagged release, verify the npm package was published from the tagged commit:
VERSION="$(node -p "require('./package.json').version")"
test "$(npm view "@printyourduck/mcp@${VERSION}" gitHead)" = "$(git rev-parse HEAD)"
npm view "@printyourduck/mcp@${VERSION}" dist.tarball dist.integrity
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"
Before tagging a release, make the GHCR package public in GitHub's package
settings. The release workflow fails before publishing npm if
ghcr.io/printyourduck/printyourduck-mcp is still private, because the public
release must be anonymously pullable.
Only claim OCI/container installability after making package visibility public and running:
VERSION="$(node -p "require('./package.json').version")"
DOCKER_CONFIG="$(mktemp -d)" 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 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.
by Microsoft · Content & Media
Convert files (PDF, Word, Excel, images, audio) to Markdown for LLM consumption