@yawlabs/mcph 0.46.2 → 0.46.3
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/CHANGELOG.md +4 -0
- package/dist/index.js +66 -33
- package/package.json +2 -2
package/CHANGELOG.md
CHANGED
|
@@ -2,6 +2,10 @@
|
|
|
2
2
|
|
|
3
3
|
All notable changes to `@yawlabs/mcph` are documented here. This project uses [semantic versioning](https://semver.org) and a CI-gated release flow: pushing a `vX.Y.Z` tag triggers `.github/workflows/release.yml`, which publishes to npm.
|
|
4
4
|
|
|
5
|
+
## 0.46.3 — 2026-04-18
|
|
6
|
+
|
|
7
|
+
- **`mcph --help` rewritten: quickstart, grouped subcommands, env vars, config precedence** — The old help listed ten subcommands in a flat table and spent most of its real estate on install flag details (already available via `mcph install --help`) and a three-line token-resolution note. Subcommands are now grouped by purpose (Setup, Inspection, Maintenance, Other), each with a multi-line description that explains what the command actually does — not just its name. A numbered Quickstart at the top points users at the token URL and shows the two commands needed to finish onboarding. An Environment variables section documents the eight `MCPH_*` overrides (`MCPH_URL`, `MCPH_POLL_INTERVAL`, `MCPH_SERVER_CAP`, `MCPH_MIN_COMPLIANCE`, `MCPH_AUTO_LOAD`, `MCPH_PRUNE_RESPONSES`, `MCPH_DISABLE_PERSISTENCE`) that were previously only discoverable by reading the doctor source. Config resolution is expanded from three lines to a proper four-tier precedence list (env → project.local → project → user-global). Trailing pointer to `mcph <subcommand> --help` for flag-level detail so the top-level stays scannable. `INSTALL_USAGE` import removed from `index.ts` since the install flag block no longer inlines into top-level help.
|
|
8
|
+
|
|
5
9
|
## 0.46.2 — 2026-04-18
|
|
6
10
|
|
|
7
11
|
- **Doctor's UPGRADE AVAILABLE section points at `mcph upgrade`** — Previously it inlined `npm install -g @yawlabs/mcph@latest` with a long prose aside about npx-vs-global. Now it tells the user to run `mcph upgrade` (prints the exact command for their install method) or `mcph upgrade --run` (executes for global-npm). Shorter, single source of truth for "how do I actually update?" since doctor already detects staleness and the upgrade subcommand already understands how the install was done.
|
package/dist/index.js
CHANGED
|
@@ -1458,7 +1458,7 @@ function selectFlakyNamespaces(entries, limit) {
|
|
|
1458
1458
|
}
|
|
1459
1459
|
|
|
1460
1460
|
// src/doctor-cmd.ts
|
|
1461
|
-
var VERSION = true ? "0.46.
|
|
1461
|
+
var VERSION = true ? "0.46.3" : "dev";
|
|
1462
1462
|
async function runDoctor(opts = {}) {
|
|
1463
1463
|
if (opts.json) return runDoctorJson(opts);
|
|
1464
1464
|
const lines = [];
|
|
@@ -2542,7 +2542,6 @@ async function runInstallAll(opts, log2, err) {
|
|
|
2542
2542
|
exitCode: 1
|
|
2543
2543
|
};
|
|
2544
2544
|
}
|
|
2545
|
-
var INSTALL_USAGE = USAGE;
|
|
2546
2545
|
|
|
2547
2546
|
// src/reset-learning-cmd.ts
|
|
2548
2547
|
import { unlink } from "fs/promises";
|
|
@@ -4745,7 +4744,7 @@ function categorizeSpawnError(err) {
|
|
|
4745
4744
|
}
|
|
4746
4745
|
async function connectToUpstream(config, onDisconnect, onListChanged) {
|
|
4747
4746
|
const client = new Client(
|
|
4748
|
-
{ name: "mcph", version: true ? "0.46.
|
|
4747
|
+
{ name: "mcph", version: true ? "0.46.3" : "dev" },
|
|
4749
4748
|
{ capabilities: {} }
|
|
4750
4749
|
);
|
|
4751
4750
|
let transport;
|
|
@@ -5226,7 +5225,7 @@ var ConnectServer = class _ConnectServer {
|
|
|
5226
5225
|
this.apiUrl = apiUrl6;
|
|
5227
5226
|
this.token = token6;
|
|
5228
5227
|
this.server = new Server(
|
|
5229
|
-
{ name: "mcph", version: true ? "0.46.
|
|
5228
|
+
{ name: "mcph", version: true ? "0.46.3" : "dev" },
|
|
5230
5229
|
{
|
|
5231
5230
|
capabilities: {
|
|
5232
5231
|
tools: { listChanged: true },
|
|
@@ -7571,7 +7570,7 @@ async function runUpgrade(opts = {}) {
|
|
|
7571
7570
|
return { exitCode: 3, lines };
|
|
7572
7571
|
}
|
|
7573
7572
|
function readCurrentVersion() {
|
|
7574
|
-
return true ? "0.46.
|
|
7573
|
+
return true ? "0.46.3" : "dev";
|
|
7575
7574
|
}
|
|
7576
7575
|
|
|
7577
7576
|
// src/index.ts
|
|
@@ -7652,42 +7651,76 @@ if (subcommand === "compliance") {
|
|
|
7652
7651
|
}
|
|
7653
7652
|
runUpgrade(parsed.options).then((r) => process.exit(r.exitCode));
|
|
7654
7653
|
} else if (subcommand === "--help" || subcommand === "-h" || subcommand === "help") {
|
|
7655
|
-
|
|
7656
|
-
|
|
7657
|
-
`
|
|
7658
|
-
mcph \u2014 MCP server orchestrator for mcp.hosting
|
|
7654
|
+
process.stdout.write(`
|
|
7655
|
+
mcph \u2014 one install, every MCP server, managed from the cloud.
|
|
7659
7656
|
|
|
7660
|
-
|
|
7661
|
-
|
|
7662
|
-
mcph install
|
|
7663
|
-
mcph doctor
|
|
7664
|
-
mcph servers [--json] List servers configured in your mcp.hosting dashboard
|
|
7665
|
-
mcph bundles [list|match] Browse curated multi-server bundles
|
|
7666
|
-
mcph compliance <target> [flags] Run the compliance suite against an MCP server
|
|
7667
|
-
mcph reset-learning Clear cross-session learning history (~/.mcph/state.json)
|
|
7668
|
-
mcph completion <shell> Print a shell completion script (bash|zsh|fish|powershell)
|
|
7669
|
-
mcph upgrade [--run] [--json] Show (or run) the upgrade command for @yawlabs/mcph
|
|
7670
|
-
mcph --version Print version
|
|
7657
|
+
Quickstart:
|
|
7658
|
+
1. Get a token https://mcp.hosting/dashboard/settings/tokens
|
|
7659
|
+
2. Install mcph mcph install claude-code --token mcp_pat_...
|
|
7660
|
+
3. Verify setup mcph doctor
|
|
7671
7661
|
|
|
7672
|
-
|
|
7673
|
-
|
|
7662
|
+
Setup:
|
|
7663
|
+
install <client> Auto-edit an MCP client's config to launch mcph.
|
|
7664
|
+
Clients: claude-code | claude-desktop | cursor | vscode.
|
|
7665
|
+
install --list Detect MCP clients on this machine (read-only).
|
|
7666
|
+
install --all Install into every detected client in one shot.
|
|
7674
7667
|
|
|
7675
|
-
|
|
7676
|
-
|
|
7668
|
+
Inspection:
|
|
7669
|
+
doctor Diagnose setup: config, token, clients, learning,
|
|
7670
|
+
upgrade, flaky-namespace reliability rollup.
|
|
7671
|
+
servers [<filter>] List servers in your mcp.hosting dashboard; the
|
|
7672
|
+
positional arg substring-filters by namespace.
|
|
7673
|
+
bundles [list|match] Browse curated multi-server bundles. \`list\` shows
|
|
7674
|
+
all; \`match\` partitions against your enabled
|
|
7675
|
+
servers (ready vs. partially installed).
|
|
7677
7676
|
|
|
7678
|
-
|
|
7679
|
-
|
|
7680
|
-
|
|
7681
|
-
|
|
7677
|
+
Maintenance:
|
|
7678
|
+
upgrade Show (or --run) the command that bumps
|
|
7679
|
+
@yawlabs/mcph to the latest version.
|
|
7680
|
+
reset-learning Clear cross-session learning history
|
|
7681
|
+
(~/.mcph/state.json).
|
|
7682
|
+
completion <shell> Print a shell completion script for bash, zsh,
|
|
7683
|
+
fish, or powershell. Redirect to your
|
|
7684
|
+
completions directory to install.
|
|
7682
7685
|
|
|
7683
|
-
|
|
7684
|
-
|
|
7686
|
+
Other:
|
|
7687
|
+
compliance <target> Run the 88-test compliance suite against an MCP
|
|
7688
|
+
server. --publish posts the report to
|
|
7689
|
+
mcp.hosting and prints the public URL.
|
|
7690
|
+
help, --help, -h Show this help.
|
|
7691
|
+
--version, -V Print mcph version.
|
|
7685
7692
|
|
|
7686
|
-
|
|
7687
|
-
)
|
|
7693
|
+
Running \`mcph\` with no subcommand starts the MCP server (requires a
|
|
7694
|
+
resolved token). Most read-only subcommands accept \`--json\` for
|
|
7695
|
+
machine-readable output. Run \`mcph <subcommand> --help\` for per-
|
|
7696
|
+
subcommand flag details.
|
|
7697
|
+
|
|
7698
|
+
Environment variables:
|
|
7699
|
+
MCPH_TOKEN API token (overrides every config file).
|
|
7700
|
+
MCPH_URL API base URL (default https://mcp.hosting).
|
|
7701
|
+
MCPH_POLL_INTERVAL Dashboard polling interval, seconds (default 60).
|
|
7702
|
+
MCPH_SERVER_CAP Max concurrently active servers (default 6).
|
|
7703
|
+
MCPH_MIN_COMPLIANCE Minimum grade to auto-activate (A|B|C|D|F).
|
|
7704
|
+
MCPH_AUTO_LOAD Load all servers at startup, ignoring SERVER_CAP.
|
|
7705
|
+
MCPH_PRUNE_RESPONSES Set to \`0\` to disable response pruning.
|
|
7706
|
+
MCPH_DISABLE_PERSISTENCE Disable cross-session learning state.
|
|
7707
|
+
|
|
7708
|
+
Config resolution (highest precedence first):
|
|
7709
|
+
1. MCPH_TOKEN / MCPH_URL env vars
|
|
7710
|
+
2. <project>/.mcph/config.local.json machine-local overrides (gitignore)
|
|
7711
|
+
3. <project>/.mcph/config.json project-shared (checked in)
|
|
7712
|
+
4. ~/.mcph/config.json user-global default
|
|
7713
|
+
|
|
7714
|
+
Token rotation: mcph reads config at startup. Restart the MCP client
|
|
7715
|
+
(or kill mcph; the client will respawn it) after editing any config.
|
|
7716
|
+
|
|
7717
|
+
Docs: https://mcp.hosting
|
|
7718
|
+
Source: https://github.com/YawLabs/mcph
|
|
7719
|
+
|
|
7720
|
+
`);
|
|
7688
7721
|
process.exit(0);
|
|
7689
7722
|
} else if (subcommand === "--version" || subcommand === "-V") {
|
|
7690
|
-
process.stdout.write(`mcph ${true ? "0.46.
|
|
7723
|
+
process.stdout.write(`mcph ${true ? "0.46.3" : "dev"}
|
|
7691
7724
|
`);
|
|
7692
7725
|
process.exit(0);
|
|
7693
7726
|
} else if (subcommand && !subcommand.startsWith("-")) {
|
package/package.json
CHANGED
|
@@ -1,9 +1,9 @@
|
|
|
1
1
|
{
|
|
2
2
|
"name": "@yawlabs/mcph",
|
|
3
|
-
"version": "0.46.
|
|
3
|
+
"version": "0.46.3",
|
|
4
4
|
"description": "mcp.hosting — one install, all your MCP servers, managed from the cloud",
|
|
5
5
|
"license": "UNLICENSED",
|
|
6
|
-
"author": "Yaw Labs <
|
|
6
|
+
"author": "Yaw Labs <support@mcp.hosting> (https://mcp.hosting)",
|
|
7
7
|
"type": "module",
|
|
8
8
|
"bin": {
|
|
9
9
|
"mcph": "./dist/index.js"
|