This guide documents .dcplugin packaging for official DeepChat plugins bundled with DeepChat
release packages.
A .dcplugin file is a zip archive built from one plugin directory.
Required files:
plugin.json: hydrated manifest used by the installer.checksums.json: SHA-256 checksums for packaged files.- every file declared by manifest skills and settings contributions.
- runtime payloads required by the target platform and architecture.
The packager excludes development-only sources such as vendor/, build/, node_modules/,
.build/, .DS_Store, and symlinks.
Official packages keep DeepChat release asset URLs in their manifest metadata:
https://github.com/ThinkInAIXYZ/deepchat/releases/download/v<version>/<asset-name>.dcplugin
The CUA plugin ships one macOS helper app per CPU architecture. The bundled package filename includes both platform and architecture:
deepchat-plugin-cua-<version>-darwin-arm64.dcplugin
deepchat-plugin-cua-<version>-darwin-x64.dcplugin
The manifest inside each package keeps the official DeepChat release-download namespace for trust metadata. Runtime detection inside the package uses the same architecture-specific plugin path:
plugin:runtime/darwin/<arch>/DeepChat Computer Use.app/Contents/MacOS/cua-driver
Architecture mapping:
| DeepChat arch | Swift arch | Runtime directory |
|---|---|---|
arm64 |
arm64 |
runtime/darwin/arm64/ |
x64 |
x86_64 |
runtime/darwin/x64/ |
Each .dcplugin contains only the runtime directory for its target architecture.
Validate the package metadata for the current host architecture:
pnpm run plugin:cua:validateBuild and package the current host architecture:
pnpm run plugin:cua:packageBuild and package explicit macOS architectures:
pnpm run plugin:cua:package:mac:arm64
pnpm run plugin:cua:package:mac:x64Build the package that will be embedded into the macOS app:
pnpm run plugin:cua:bundle:mac:arm64
pnpm run plugin:cua:bundle:mac:x64Validate explicit macOS architectures after their helper runtimes have been staged:
pnpm run plugin:cua:validate:mac:arm64
pnpm run plugin:cua:validate:mac:x64Standalone packages are written to:
dist/plugins/
Bundled packages are written to:
build/bundled-plugins/
The macOS build matrix in .github/workflows/build.yml builds the matching CUA plugin bundle before
running electron-builder. Electron Builder embeds it into:
DeepChat.app/Contents/Resources/app.asar.unpacked/plugins/
Each matrix job verifies the expected bundled .dcplugin exists inside the app before uploading
artifacts.
The release workflow repeats the same bundled package step. The final release uploads app artifacts
only; .dcplugin files are not published as separate GitHub Release assets.
Expected embedded files:
app.asar.unpacked/plugins/deepchat-plugin-cua-<version>-darwin-x64.dcplugin
app.asar.unpacked/plugins/deepchat-plugin-cua-<version>-darwin-arm64.dcplugin