Skip to main content

uv-installable wrapper for the vercel-labs/skills CLI with an embedded Node runtime

Project description

npx-skills

npx-skills is a uv-installable Python wrapper around the upstream skills CLI.

This allows you to use skills.sh from within Python projects without a global dependency on Node/npm and impose versioning constraints on npx skills on a project-by-project basis.

It does this by shipping a vendored Node runtime and the published JavaScript CLI payload, then forwards execution to the embedded runtime so users do not need a separate Node install.

Install

uv add npx-skills
skills -h

OR use with uvx

uvx npx-skills

Versioning

The npx-skills package version tracks the upstream skills npm module version one-to-one. Installing npx-skills==1.4.8 gives you exactly skills@1.4.8 — the CLI payload is baked into the wheel at build time, so pinning npx-skills in your pyproject.toml or lockfile pins the underlying JavaScript CLI too. A new upstream skills release on npm has no effect on an already-installed npx-skills; you only move when you explicitly bump npx-skills. Packaging-only republishes of an existing upstream version use PEP 440 post-releases (e.g. 1.4.8.post1).

How it works

Refresh Vendored Artifacts

The repository includes a vendoring script that copies:

  • the published skills package payload (package.json, bin/, dist/, README.md, ThirdPartyNoticeText.txt)
  • the package's runtime node_modules dependencies
  • the current platform's node binary

By default it will use a built package root if you pass --source, or fall back to the newest cached ~/.npm/_npx/*/node_modules/skills install.

uv run python scripts/vendor_upstream.py

Or point it at a specific built package root:

uv run python scripts/vendor_upstream.py --source /path/to/node_modules/skills

If you point --source at the upstream git repo, it must already contain dist/cli.mjs.

To rebuild only the embedded Node runtime from the payload already committed in this repo, point --source at the vendored package root:

uv run python scripts/vendor_upstream.py --source src/npx_skills/vendor/skills

Build

The wheel is intentionally platform-specific because it includes a native node binary.

uv build

Release Automation

GitHub Actions builds one wheel per native runner target:

  • Linux x64 via manylinux_2_28
  • Linux arm64 via manylinux_2_28
  • macOS x64
  • macOS arm64
  • Windows x64
  • Windows arm64

The workflow lives at .github/workflows/wheels.yml. It reuses the committed skills payload, re-vendors the Node runtime for the current runner architecture, runs the test suite, builds wheels with uv (cibuildwheel via uvx on Linux), smoke-tests the built wheel, and uploads wheel artifacts for manual release use.

This project intentionally publishes wheels only. An sdist would not be portable without re-vendoring the embedded Node runtime for the target platform.

Publishing runs through a separate manual workflow at .github/workflows/publish.yml. It invokes the wheel builder in the same workflow run, then publishes from GitHub after all target wheels succeed. The intended entrypoint is the npx-skills-dev helper:

uv run --package npx-skills-dev npx-skills-dev publish-to-pypi

Or via make:

make publish

Use --ref <branch> to dispatch the workflow from a specific branch and --dry-run to build and validate without publishing.

The GitHub publish job authenticates to PyPI using a project API token stored as the PYPI_API_TOKEN repository secret and consumed via UV_PUBLISH_TOKEN. The job runs in the pypi GitHub Actions environment, which can optionally be gated with required reviewers.

Upstream Sync Automation

A scheduled workflow at .github/workflows/auto-sync-upstream.yml runs daily (06:17 UTC) and keeps the vendored payload in lock-step with the upstream skills npm release. It is the mechanism that preserves the one-to-one version mapping described in the Versioning section above.

The job is implemented by the npx-skills-dev auto-sync-upstream command (packages/npx-skills-dev/src/npx_skills_dev/commands/auto_sync_upstream.py) and performs the following steps:

  1. Reads the currently vendored version from src/npx_skills/vendor/manifest.json (upstream.version).
  2. Fetches skills@latest from the npm registry.
  3. If the versions match (and --force was not passed) the job exits as a no-op.
  4. Otherwise it npm installs skills@<latest> into a temporary directory and runs scripts/vendor_upstream.py --source ... against it to refresh the vendored payload.
  5. Rewrites the version in pyproject.toml and src/npx_skills/__init__.py to match the new upstream version.
  6. Runs the unit test suite.
  7. Commits src/npx_skills/vendor, src/npx_skills/__init__.py, and pyproject.toml with the message Auto-sync upstream skills@<version> and pushes to master.
  8. Dispatches publish.yml against master, which builds wheels for every target platform and publishes them to PyPI.

The workflow can also be triggered manually via workflow_dispatch, with an optional force input that re-runs the full flow even when the upstream version is unchanged.

Layout

The vendored runtime is kept under src/npx_skills/vendor/:

vendor/
  manifest.json
  node/<platform>/node
  skills/
    package.json
    bin/cli.mjs
    dist/
    node_modules/

Project details


Download files

Download the file for your platform. If you're not sure which to choose, learn more about installing packages.

Source Distributions

No source distribution files available for this release.See tutorial on generating distribution archives.

Built Distributions

If you're not sure about the file name format, learn more about wheel file names.

npx_skills-1.5.0-py3-none-win_arm64.whl (30.1 MB view details)

Uploaded Python 3Windows ARM64

npx_skills-1.5.0-py3-none-win_amd64.whl (33.7 MB view details)

Uploaded Python 3Windows x86-64

npx_skills-1.5.0-py3-none-manylinux_2_28_x86_64.whl (45.5 MB view details)

Uploaded Python 3manylinux: glibc 2.28+ x86-64

npx_skills-1.5.0-py3-none-manylinux_2_28_aarch64.whl (44.7 MB view details)

Uploaded Python 3manylinux: glibc 2.28+ ARM64

npx_skills-1.5.0-py3-none-macosx_15_0_arm64.whl (37.3 MB view details)

Uploaded Python 3macOS 15.0+ ARM64

npx_skills-1.5.0-py3-none-macosx_10_13_universal2.whl (39.0 MB view details)

Uploaded Python 3macOS 10.13+ universal2 (ARM64, x86-64)

File details

Details for the file npx_skills-1.5.0-py3-none-win_arm64.whl.

File metadata

  • Download URL: npx_skills-1.5.0-py3-none-win_arm64.whl
  • Upload date:
  • Size: 30.1 MB
  • Tags: Python 3, Windows ARM64
  • Uploaded using Trusted Publishing? No
  • Uploaded via: uv/0.11.6 {"installer":{"name":"uv","version":"0.11.6","subcommand":["publish"]},"python":null,"implementation":{"name":null,"version":null},"distro":{"name":"Ubuntu","version":"24.04","id":"noble","libc":null},"system":{"name":null,"release":null},"cpu":null,"openssl_version":null,"setuptools_version":null,"rustc_version":null,"ci":true}

File hashes

Hashes for npx_skills-1.5.0-py3-none-win_arm64.whl
Algorithm Hash digest
SHA256 0ad71b48b206daa2fb6dc5f37ff2688905bc3c847003811654c2674a90ddca4a
MD5 84c9564a0bdf4f36ac496ef7290c9fa1
BLAKE2b-256 f3366f77ed2c4bf3ea01838bb9ff9c4cd4c30f556783eded66addf5311ec81fe

See more details on using hashes here.

File details

Details for the file npx_skills-1.5.0-py3-none-win_amd64.whl.

File metadata

  • Download URL: npx_skills-1.5.0-py3-none-win_amd64.whl
  • Upload date:
  • Size: 33.7 MB
  • Tags: Python 3, Windows x86-64
  • Uploaded using Trusted Publishing? No
  • Uploaded via: uv/0.11.6 {"installer":{"name":"uv","version":"0.11.6","subcommand":["publish"]},"python":null,"implementation":{"name":null,"version":null},"distro":{"name":"Ubuntu","version":"24.04","id":"noble","libc":null},"system":{"name":null,"release":null},"cpu":null,"openssl_version":null,"setuptools_version":null,"rustc_version":null,"ci":true}

File hashes

Hashes for npx_skills-1.5.0-py3-none-win_amd64.whl
Algorithm Hash digest
SHA256 5a3399e862a5d72a6f0fb087a3bad2f65630f03414cdb365f166d73c0fcda8ad
MD5 3e4df4cb7f48ee03f5f779acec128d22
BLAKE2b-256 008aa4ece8e25095dcc64f57008b4b4ec433c6a53c6ca7ddb1fd728ad766d6e0

See more details on using hashes here.

File details

Details for the file npx_skills-1.5.0-py3-none-manylinux_2_28_x86_64.whl.

File metadata

  • Download URL: npx_skills-1.5.0-py3-none-manylinux_2_28_x86_64.whl
  • Upload date:
  • Size: 45.5 MB
  • Tags: Python 3, manylinux: glibc 2.28+ x86-64
  • Uploaded using Trusted Publishing? No
  • Uploaded via: uv/0.11.6 {"installer":{"name":"uv","version":"0.11.6","subcommand":["publish"]},"python":null,"implementation":{"name":null,"version":null},"distro":{"name":"Ubuntu","version":"24.04","id":"noble","libc":null},"system":{"name":null,"release":null},"cpu":null,"openssl_version":null,"setuptools_version":null,"rustc_version":null,"ci":true}

File hashes

Hashes for npx_skills-1.5.0-py3-none-manylinux_2_28_x86_64.whl
Algorithm Hash digest
SHA256 fdb388a6d33f5d0ee8bb5bf8fa598d479175a87e8a10912562a0c5f66592af35
MD5 1c5bd6457fb9f31608bab347fb678dbb
BLAKE2b-256 2a7faacbfc2c3edb6e96634dda30e701b4b66b4654b0244a26b6f9670fcbd306

See more details on using hashes here.

File details

Details for the file npx_skills-1.5.0-py3-none-manylinux_2_28_aarch64.whl.

File metadata

  • Download URL: npx_skills-1.5.0-py3-none-manylinux_2_28_aarch64.whl
  • Upload date:
  • Size: 44.7 MB
  • Tags: Python 3, manylinux: glibc 2.28+ ARM64
  • Uploaded using Trusted Publishing? No
  • Uploaded via: uv/0.11.6 {"installer":{"name":"uv","version":"0.11.6","subcommand":["publish"]},"python":null,"implementation":{"name":null,"version":null},"distro":{"name":"Ubuntu","version":"24.04","id":"noble","libc":null},"system":{"name":null,"release":null},"cpu":null,"openssl_version":null,"setuptools_version":null,"rustc_version":null,"ci":true}

File hashes

Hashes for npx_skills-1.5.0-py3-none-manylinux_2_28_aarch64.whl
Algorithm Hash digest
SHA256 c50fc2d6bd230fa7eafbf32a440451c3c4274c4057dbb9f854e49355835f352e
MD5 5d4f12f885e5deee58183e860e73b813
BLAKE2b-256 59b838966b4152f4b0664cd8e708a2109f44fa68f0667a5157dfaf225e75566b

See more details on using hashes here.

File details

Details for the file npx_skills-1.5.0-py3-none-macosx_15_0_arm64.whl.

File metadata

  • Download URL: npx_skills-1.5.0-py3-none-macosx_15_0_arm64.whl
  • Upload date:
  • Size: 37.3 MB
  • Tags: Python 3, macOS 15.0+ ARM64
  • Uploaded using Trusted Publishing? No
  • Uploaded via: uv/0.11.6 {"installer":{"name":"uv","version":"0.11.6","subcommand":["publish"]},"python":null,"implementation":{"name":null,"version":null},"distro":{"name":"Ubuntu","version":"24.04","id":"noble","libc":null},"system":{"name":null,"release":null},"cpu":null,"openssl_version":null,"setuptools_version":null,"rustc_version":null,"ci":true}

File hashes

Hashes for npx_skills-1.5.0-py3-none-macosx_15_0_arm64.whl
Algorithm Hash digest
SHA256 5968f79a4a8a272c2a794a02a6f0fa6f99f831b6e5c6bc41f635ada2260d0aac
MD5 938f4fe47c0174465bf70dab341c7fb9
BLAKE2b-256 a6f2d34a430317b9567da3d04af3acbf45e6c61d759339dd593f7313e8c47549

See more details on using hashes here.

File details

Details for the file npx_skills-1.5.0-py3-none-macosx_10_13_universal2.whl.

File metadata

  • Download URL: npx_skills-1.5.0-py3-none-macosx_10_13_universal2.whl
  • Upload date:
  • Size: 39.0 MB
  • Tags: Python 3, macOS 10.13+ universal2 (ARM64, x86-64)
  • Uploaded using Trusted Publishing? No
  • Uploaded via: uv/0.11.6 {"installer":{"name":"uv","version":"0.11.6","subcommand":["publish"]},"python":null,"implementation":{"name":null,"version":null},"distro":{"name":"Ubuntu","version":"24.04","id":"noble","libc":null},"system":{"name":null,"release":null},"cpu":null,"openssl_version":null,"setuptools_version":null,"rustc_version":null,"ci":true}

File hashes

Hashes for npx_skills-1.5.0-py3-none-macosx_10_13_universal2.whl
Algorithm Hash digest
SHA256 77290a04fd5a10327ea8e2815654a7c77b92de69cadbe56e6c4f165fed4a37a3
MD5 7d2b823bcb57afa25e732be0eea75794
BLAKE2b-256 1463b828f0f048794bc52dafb17c09e9f51470ec75a173cc8ec64c49aa939fd5

See more details on using hashes here.

Supported by

AWS Cloud computing and Security Sponsor Datadog Monitoring Depot Continuous Integration Fastly CDN Google Download Analytics Pingdom Monitoring Sentry Error logging StatusPage Status page