Skip to content

Manifest

Every plugin requires a manifest at the root of the .hcp archive. The example below shows every field; real plugins usually declare only the entries they use.

json
{
  "id": "com.example.my-plugin",
  "name": "My Plugin",
  "version": "1.0.0",

  "author": "Example Inc.",
  "description": "README.md",
  "icon": "assets/icon.png",
  "screenshots": [
    {
      "path": "assets/screenshots/settings.png",
      "caption": "Settings panel"
    },
    {
      "path": "assets/screenshots/sidebar.png",
      "caption": "Sidebar tools"
    }
  ],
  "homepage": "https://example.com/my-plugin",
  "bugs": {
    "url": "https://github.com/example/my-plugin/issues"
  },

  "engines": {
    "harborclient": ">=1.7.0"
  },
  "renderer": "dist/renderer.js",
  "main": "dist/main.js",
  "permissions": ["ui", "storage"],

  "contributes": {
    "settingsSections": [{ "id": "myPlugin.settings", "title": "My Plugin" }],
    "sidebarPanels": [{ "id": "myPlugin.panel", "title": "My Plugin" }],
    "sidebarSections": [{ "id": "myPlugin.section", "title": "My Plugin" }],
    "mainViews": [{ "id": "myPlugin.view", "title": "My Plugin" }],
    "requestTabs": [{ "id": "myPlugin.requestTab", "title": "Audit" }],
    "responseTabs": [{ "id": "myPlugin.responseTab", "title": "Summary" }],
    "collectionSettingsTabs": [{ "id": "myPlugin.collTab", "title": "Plugin" }],
    "footerPanels": [{ "id": "myPlugin.footer", "title": "My Plugin" }],
    "requestToolbarActions": [{ "id": "myPlugin.sendAction", "title": "Run check" }],
    "contextMenus": [{ "id": "myPlugin.requestMenu", "title": "Plugin action" }],
    "statusBarItems": [{ "id": "myPlugin.status", "title": "Status" }],
    "themes": [{ "id": "solarized", "title": "Solarized Dark", "type": "dark" }],
    "commands": [{ "id": "myPlugin.run", "title": "Run plugin command" }],
    "menus": [
      {
        "menu": "view",
        "command": "myPlugin.run",
        "group": "plugin"
      }
    ]
  }
}
FieldRequiredDescription
idYesReverse-DNS identifier. Namespaces storage and plugin updates.
nameYesDisplay name shown in Settings and install dialogs.
versionYesSemver version string.
authorNoPublisher or author name shown on the plugin detail page.
descriptionNoPath to a Markdown file (for example README.md) with the full plugin description. Rendered in Settings → Plugins detail view.
iconNoPath to a square PNG or SVG icon (recommended 128×128 px or larger). Shown in the plugin list and install dialog.
screenshotsNoGallery images for the plugin detail page. See Screenshots below.
homepageNoURL to the plugin's website or documentation. Shown as a link on the detail page.
bugsNoIssue tracker for bug reports. Use { "url": "https://…" }. Shown as Report issue on the detail page.
engines.harborclientYesMinimum HarborClient version (for example >=1.7.0).
rendererNoPath to the renderer entry bundle (UI).
mainNoPath to the main entry bundle (hooks, IPC, logic).
permissionsYesCapabilities the plugin needs. Summarized in the install confirmation dialog.
contributesNoDeclarative UI slots listed before plugin code activates.

Plugin metadata

Listing metadata is separate from contributes — it describes the package for users browsing Settings → Plugins, not UI slots inside the app.

description

Points to a Markdown file at the plugin package root (relative path only; no absolute paths or URLs). HarborClient renders the file in the plugin detail view with the same Markdown subset used elsewhere in the app (headings, lists, links, code fences, emphasis).

Use this for install-time documentation: features, setup notes, permission rationale, and changelog highlights. Keep manifest.json lean; put prose in README.md or description.md.

markdown
# My Plugin

Logs every outbound HTTP request to the terminal and adds a **Solarized Dark** theme.

## Permissions

- `http` — before/after send hooks for request logging
- `ui` — theme registration

icon

Path to a PNG or SVG under the plugin directory. Recommended 128×128 px minimum; HarborClient scales down for list rows and up for the detail header. Use a transparent background for PNG icons.

Screenshots

An array of screenshot entries. Each entry is either:

  • a string — plugin-relative image path, or
  • an object{ "path": "assets/…", "caption": "Optional label" }

Supported formats: PNG, JPEG, WebP. Recommended width 1280 px or wider; HarborClient scales images to fit the detail gallery. Include two to five screenshots that show primary UI contributions.

json
"screenshots": [
  "assets/screenshots/overview.png",
  { "path": "assets/screenshots/settings.png", "caption": "Plugin settings" }
]

author, homepage, and bugs

FieldExampleShown in UI
author"Acme HTTP Tools"Publisher line on detail page
homepage"https://example.com/my-plugin"Website link
bugs.url"https://github.com/example/my-plugin/issues"Report issue link

All URL fields must use https:// (or http:// for local development documentation only). HarborClient opens links in the system default browser.

Contribution types

The contributes block declares where your plugin can appear. Each entry's id must match the id passed to the corresponding hc.ui.register* call at activation time.

Manifest keyhc.ui registrarUI surface
settingsSectionsregisterSettingsSectionSettings sidebar and panel
sidebarPanelsregisterSidebarPanelSwitchable left sidebar destination
sidebarSectionsregisterSidebarSectionCollapsible block inside the scrollable sidebar
mainViewsregisterMainViewFull main-area overlay (Team Hubs pattern)
requestTabsregisterRequestTabRequest editor segmented tabs
responseTabsregisterResponseTabResponse viewer tabs
collectionSettingsTabsregisterCollectionSettingsTabCollection settings segmented tabs
footerPanelsregisterFooterPanelSlide-up footer panel
requestToolbarActionsregisterRequestToolbarActionButton near Send in the URL bar
contextMenusregisterContextMenuItemRow actions on sidebar collections, folders, requests
statusBarItemsregisterStatusBarItemFooter status area (beside sidebar / AI toggles)
themeshc.themes.registerAppearance theme in Settings → General
commandshc.commands.registerCommand handlers (menus, toolbar, context menus)
menusregisterMenuItemFile, Edit, View, or Help application menu

Settings sections ship in the initial plugin release. Other contribution types are part of the target API documented in the Renderer API and will roll out in subsequent HarborClient versions. Declare them in the manifest now so install dialogs and future host versions can discover slots before your code loads.

See UI contributions for registration method reference.