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 - 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