npm package discovery and stats viewer.

Discover Tips

  • General search

    [free text search, go nuts!]

  • Package details

    pkg:[package-name]

  • User packages

    @[username]

Sponsor

Optimize Toolset

I’ve always been into building performant and accessible sites, but lately I’ve been taking it extremely seriously. So much so that I’ve been building a tool to help me optimize and monitor the sites that I build to make sure that I’m making an attempt to offer the best experience to those who visit them. If you’re into performant, accessible and SEO friendly sites, you might like it too! You can check it out at Optimize Toolset.

About

Hi, 👋, I’m Ryan Hefner  and I built this site for me, and you! The goal of this site was to provide an easy way for me to check the stats on my npm packages, both for prioritizing issues and updates, and to give me a little kick in the pants to keep up on stuff.

As I was building it, I realized that I was actually using the tool to build the tool, and figured I might as well put this out there and hopefully others will find it to be a fast and useful way to search and browse npm packages as I have.

If you’re interested in other things I’m working on, follow me on Twitter or check out the open source projects I’ve been publishing on GitHub.

I am also working on a Twitter bot for this site to tweet the most popular, newest, random packages from npm. Please follow that account now and it will start sending out packages soon–ish.

Open Software & Tools

This site wouldn’t be possible without the immense generosity and tireless efforts from the people who make contributions to the world and share their work via open source initiatives. Thank you 🙏

© 2026 – Pkg Stats / Ryan Hefner

@iflow-mcp/gdmacmillan-apt-mcp-server

v1.0.1

Published

A FastMCP server for controlling apt package manager on Linux via MCP tools.

Readme

Apt MCP Server

A TypeScript-based Model Context Protocol (MCP) server for controlling the apt package manager on Linux. Designed for integration with AI agents (e.g., Cursor, Claude Desktop, Windsurf) and developer tools, it exposes tools for installing, removing, updating, and querying apt packages using the system's native apt and dpkg binaries with sudo privileges.


Features

  • Install, remove, update, and query apt packages via MCP tools
  • Secure, passwordless sudo assumed for all operations
  • Input validation and robust error handling
  • Consistent, human-readable output for all tools
  • Designed for stdio transport (default for local AI agent integration)

Setup & Installation

  1. Clone the repository:
    git clone <your-repo-url>
    cd popos-control-mcp
  2. Install dependencies:
    npm install
  3. Build the project:
    npm run build
  4. Run the server (stdio transport):
    npm run dev
    # or
    npm start

Note: The server assumes the user has passwordless sudo for apt operations.


Tools & API Endpoints

All tools are exposed via MCP and can be called by AI agents or clients. Each tool returns a plain text response with a summary, stdout, stderr, and logs (if any).

1. installAptPackage

  • Description: Install one or more apt packages.
  • Parameters:
    • packages: array of package names (e.g., ["curl", "git"])
  • Example Input:
    { "packages": ["curl"] }
  • Example Output:
    Result: SUCCESS
    Summary: Apt install succeeded for: curl
    [stdout]
    ...
    [stderr]
    ...

2. removeAptPackage

  • Description: Remove one or more apt packages.
  • Parameters:
    • packages: array of package names
  • Example Input:
    { "packages": ["curl"] }
  • Example Output:
    Result: SUCCESS
    Summary: Apt remove succeeded for: curl
    [stdout]
    ...
    [stderr]
    ...

3. queryAptPackageStatus

  • Description: Query if a package is installed, available, or upgradable.
  • Parameters:
    • package: package name (string)
  • Example Input:
    { "package": "curl" }
  • Example Output:
    Result: SUCCESS
    Summary: Status for package curl: Installed=installed, Upgradable=false, Available=available
    [stdout]
    Package: curl
    Installed: installed
    Upgradable: no
    Available: available

4. updateAptPackages

  • Description: Update the apt package list and upgrade all packages.
  • Parameters: none
  • Example Input:
    {}
  • Example Output:
    Result: SUCCESS
    Summary: Apt update and upgrade completed successfully.
    [stdout]
    apt update stdout:
    ...
    apt upgrade stdout:
    ...
    [stderr]
    ...

5. listUpgradableAptPackages

  • Description: List all upgradable apt packages.
  • Parameters: none
  • Example Input:
    {}
  • Example Output:
    Result: SUCCESS
    Summary: Listed upgradable packages successfully.
    [stdout]
    ...
    [stderr]
    ...

6. upgradeSpecificAptPackage

  • Description: Upgrade a specific apt package.
  • Parameters:
    • package: package name (string)
  • Example Input:
    { "package": "curl" }
  • Example Output:
    Result: SUCCESS
    Summary: Apt only-upgrade succeeded for: curl
    [stdout]
    ...
    [stderr]
    ...

Example Usage

CLI (stdio transport)

You can test the server using the MCP CLI or by connecting with an AI agent (e.g., Cursor, Claude Desktop).

Node.js Example

const { Client } = require("@modelcontextprotocol/sdk/client");
const { StdioClientTransport } = require("@modelcontextprotocol/sdk/client/stdio");

const client = new Client({ name: "test-client", version: "1.0.0" });
const transport = new StdioClientTransport();

(async () => {
  await client.connect(transport);
  const result = await client.callTool("installAptPackage", { packages: ["curl"] });
  console.log(result);
})();

Error Handling & Troubleshooting

  • All errors are returned in a consistent format with Result: ERROR and a summary.
  • Common error causes:
    • Invalid package name: check spelling and allowed characters
    • Package not found: ensure the package exists in your repositories
    • Permission denied: ensure passwordless sudo is configured
    • Apt lock: the server retries once automatically, but if the error persists, wait and try again
  • Example error output:
    Result: ERROR
    Summary: Apt install failed: E: Unable to locate package notarealpackage
    [stdout]
    ...
    [stderr]
    E: Unable to locate package notarealpackage

FAQ

Q: Does the server require passwordless sudo? A: Yes, all apt/dpkg commands are run with sudo and assume no password prompt.

Q: What transport does the server use? A: Stdio by default, for easy integration with local AI agents and tools.

Q: Can I use this server remotely? A: You can adapt it to use HTTP/SSE transport, but stdio is recommended for local/agent use.

Q: How do I add new tools? A: Add a new server.addTool block in src/index.ts following the existing pattern.


License

MIT