2.3 KiB
Plugin system
Takopi uses Python entrypoints to extend engines, transports, and commands.
Why entrypoints
Entrypoints let Takopi discover plugins without hard dependencies on plugin packages. Installed distributions declare what they provide, and Takopi can list and load them at runtime.
This makes it possible to:
- Add new engines/transports/commands without changing Takopi itself.
- Ship plugins independently.
- Keep the core CLI small.
Why discovery is lazy
Takopi lists plugin IDs without importing plugin code, then imports a plugin only when:
- it is selected by routing (engine/transport), or
- it is invoked as a command, or
- you explicitly request loading via
takopi plugins --load.
This keeps takopi --help fast and prevents a broken third-party plugin from bricking the CLI.
Entrypoint rules (what Takopi expects)
Takopi uses three entrypoint groups:
[project.entry-points."takopi.engine_backends"]
myengine = "myengine.backend:BACKEND"
[project.entry-points."takopi.transport_backends"]
mytransport = "mytransport.backend:BACKEND"
[project.entry-points."takopi.command_backends"]
mycommand = "mycommand.backend:BACKEND"
Rules:
- The entrypoint name is the plugin id.
- The entrypoint value must resolve to a backend object:
- engine backend:
EngineBackend - transport backend:
TransportBackend - command backend:
CommandBackend
- engine backend:
- The backend object must have
id == entrypoint name.
Why there is an enabled list
Plugin visibility can be restricted via:
[plugins]
enabled = ["takopi-engine-acme", "takopi-transport-slack"]
When set, Takopi filters by distribution name (package metadata), not by entrypoint name. This lets you:
- ship multiple entrypoints from one distribution, and
- enable/disable whole plugin packages predictably.
IDs and collisions
Entrypoint names become plugin IDs and appear in user-facing surfaces (CLI subcommands, Telegram commands, /engine directives).
Takopi validates IDs and rejects collisions with reserved names.
Plugin IDs must match:
^[a-z0-9_]{1,32}$
Reserved IDs include core chat and CLI command names such as cancel, init, and plugins.
How to debug discovery and loading
takopi plugins
takopi plugins --load