Skip to content
Resources
AGH RuntimeResources

Bundles

Package channels, jobs, triggers, and bridge presets from extensions into activatable runtime profiles.

Audience
Operators running durable agent work
Focus
Resources guidance shaped for scanability, day-two clarity, and operator context.

Bundles are extension-provided presets. A bundle catalog record describes what an extension can provide; a bundle activation chooses one profile and asks AGH to project its runtime resources.

Use bundles when a feature should install as a coherent unit: channels, automation jobs, triggers, and bridge instances that make sense together.

Activation flow

Rendering diagram...

Bundle activation projects one extension profile into runtime resources and optional network defaults.
ObjectWhat it does
Bundle catalogLists extension bundles and profiles available for activation.
Bundle profileChooses channels, jobs, triggers, and bridges inside one bundle.
Bundle activationRecords one active profile at global or workspace scope.
InventoryLists the resources AGH projected from the activation.
Network settingsReports declared channels and the effective default network channel.

Operator routes

GET /api/bundles/catalog
POST /api/bundles/preview
GET /api/bundles/activations
POST /api/bundles/activations
GET /api/bundles/activations/:id
PATCH /api/bundles/activations/:id
DELETE /api/bundles/activations/:id
GET /api/bundles/network/settings

These routes are available over HTTP and UDS. The generated OpenAPI file is still catching up to the full bundle surface, so treat this page and the API route map as the release-truth source for bundle route families.

Preview before activation

POST /api/bundles/preview
Content-Type: application/json

{
  "extension_name": "github",
  "bundle_name": "release-workflow",
  "profile_name": "default",
  "scope": "workspace",
  "workspace": "project",
  "bind_primary_channel_as_default": true
}

Preview returns the activation payload AGH would create: channels, jobs, triggers, bridges, and inventory. It does not mutate the runtime.

Activate a profile

POST /api/bundles/activations
Content-Type: application/json

{
  "extension_name": "github",
  "bundle_name": "release-workflow",
  "profile_name": "default",
  "scope": "workspace",
  "workspace": "project",
  "bind_primary_channel_as_default": true
}

Activation creates or updates a bundle.activation resource. Reconcile then projects the owned automation and bridge resources. The response includes the stable activation id and projected inventory so operators can audit what changed.

Scope and default channel rules

RuleBehavior
Global activationApplies without a workspace id.
Workspace activationRequires a workspace id resolved from the workspace request field.
Primary channel bindingCan make the profile's primary channel the effective default channel.
Default channel conflictOnly one active activation can claim the effective default at a time.
Extension dependencyThe bundle must still exist in the installed extension catalog.

Deactivation

DELETE /api/bundles/activations/act_123

Deactivation removes the activation and lets reconcile remove the owned projected resources. Remove bundle activations before disabling or removing the extension that owns them.

Failure guide

SymptomLikely causeFirst check
404 on preview or activationExtension, bundle, profile, or workspace missing.GET /api/bundles/catalog and workspace list.
409 on activationAnother activation claimed the default channel.GET /api/bundles/network/settings.
Activation exists but resources are absentReconcile failed after writing the activation.Activation inventory and daemon resource health.
Extension cannot be disabledActive bundle activations still depend on it.GET /api/bundles/activations.
Projected job or bridge should changeBundle profile changed or activation is stale.Preview the activation, then update/reactivate.

Next

  • Extensions explains install, enable, disable, and removal constraints.
  • Automation explains jobs and triggers after projection.
  • Bridges explains bridge instances after projection.

On this page