1
0
silverbullet/website/🔌 Plugs.md

84 lines
4.7 KiB
Markdown
Raw Normal View History

2022-10-29 14:57:12 +00:00
Silver Bullet at its core is bare bones in terms of functionality, most of its power it gains from **plugs**.
2022-11-27 08:12:24 +00:00
Plugs are an extension mechanism (implemented using a library called `plugos` that runs plug code on the server in a sandboxed v8 Deno web worker, and in the browser using web workers). Plugs can hook into SB in various ways:
* Extend the Markdown parser and its syntax
* Define new commands and keybindings
* Respond to various events triggered either on the server or client-side
* Run recurring and background tasks.
* Define their own extension mechanisms through custom events
Each plug runs in its own _sandboxed environment_ and communicates with SB via _syscalls_ that expose a vast range of functionality. Plugs can be loaded, unloaded, and updated without having to restart SB itself.
2022-06-28 12:14:15 +00:00
2022-11-25 15:01:05 +00:00
## Core plugs
These plugs are distributed with Silver Bullet and are automatically enabled:
<!-- #query page where type = "plug" and uri = null order by name render [[template/plug]] -->
2022-11-27 08:12:24 +00:00
* [[🔌 Collab]]
* [[🔌 Core]]
* [[🔌 Directive]]
* [[🔌 Emoji]]
* [[🔌 Markdown]]
* [[🔌 Share]]
* [[🔌 Tasks]]
2022-11-25 15:01:05 +00:00
<!-- /query -->
## Third-party plugs
2022-11-27 08:12:24 +00:00
These plugs are written either by third parties or distributed separately from the main SB distribution:
2022-11-25 15:01:05 +00:00
<!-- #query page where type = "plug" and uri != null order by name render [[template/plug]] -->
* [[🔌 Backlinks]] by **Guillermo Vayá** ([repo](https://github.com/Willyfrog/silverbullet-backlinks))
2022-10-29 14:57:12 +00:00
* [[🔌 Ghost]] by **Zef Hemel** ([repo](https://github.com/silverbulletmd/silverbullet-ghost))
* [[🔌 Git]] by **Zef Hemel** ([repo](https://github.com/silverbulletmd/silverbullet-github))
* [[🔌 Github]] by **Zef Hemel** ([repo](https://github.com/silverbulletmd/silverbullet-github))
2022-11-25 15:01:05 +00:00
* [[🔌 Graph View]] by **Bertjan Broeksema** ([repo](https://github.com/bbroeksema/silverbullet-graphview))
2022-10-29 14:57:12 +00:00
* [[🔌 Mattermost]] by **Zef Hemel** ([repo](https://github.com/silverbulletmd/silverbullet-mattermost))
* [[🔌 Serendipity]] by **Pantelis Vratsalis** ([repo](https://github.com/m1lt0n/silverbullet-serendipity))
2022-11-25 15:01:05 +00:00
* [[🔌 Twitter]] by **Silver Bullet Authors** ([repo](https://github.com/silverbulletmd/silverbullet-twitter))
<!-- /query -->
2022-07-16 10:18:31 +00:00
## How to develop your own plug
2022-10-29 14:57:12 +00:00
The easiest way to get started is to click the “Use this template” on the [silverbullet-plug-template](https://github.com/silverbulletmd/silverbullet-plug-template) repo.
2022-10-12 09:47:13 +00:00
Generally, every plug consists of a YAML manifest file named
2022-10-29 14:57:12 +00:00
`yourplugname.plug.yml`. This file defines all functions that form your plug. To be loadable by Silver Bullet (or any plugos-based system for that matter), it needs to be compiled into a JSON bundle (ending with `.plug.json`).
Generally, the way to do this is to run `silverbullet plug:compile` as follows:
2022-07-16 10:18:31 +00:00
2022-10-29 14:57:12 +00:00
silverbullet plug:compile yourplugname.plug.yaml
2022-07-16 10:18:31 +00:00
2022-10-29 14:57:12 +00:00
However, if you use the plug template, this command is wrapped in your `deno.jsonc` file, so you can just run either:
2022-07-16 10:18:31 +00:00
2022-10-29 14:57:12 +00:00
deno task build
2022-07-16 10:18:31 +00:00
2022-10-29 14:57:12 +00:00
to build it once, or
2022-07-16 10:18:31 +00:00
2022-10-29 14:57:12 +00:00
deno task watch
2022-07-16 10:18:31 +00:00
2022-10-29 14:57:12 +00:00
to build it and rebuild when files are changed.
2022-07-16 10:18:31 +00:00
2022-10-29 14:57:12 +00:00
This will write out a `yourplugname.plug.json` file into the same folder.
2022-07-16 10:18:31 +00:00
2022-10-29 14:57:12 +00:00
Once you have a compiled `.plug.json` file you can load it into SB in a few ways by listing it in your spaces `PLUGS` page.
For development its easiest to use the `file:` prefix for this, by adding this in the `yaml` block section there to your existing list of plugs:
2022-07-16 10:18:31 +00:00
- file:/home/me/git/yourplugname/yourplugname.plug.json
2022-10-29 14:57:12 +00:00
Reload your list of plugs via the `Plugs: Update` command (`Cmd-Shift-p` on Mac, `Ctrl-Shift-p` on Linux and Windows) to load the list of plugs from the various sources on the server and your browser client. No need to reload the page, your plugs are now active.
2022-07-16 10:18:31 +00:00
Once youre happy with your plug, you can distribute it in various ways:
2022-10-29 14:57:12 +00:00
- You can put it on github by simply committing the resulting `.plug.json` file there and instructing users to point to by adding
`- github:yourgithubuser/yourrepo/yourplugname.plug.json` to their `PLUGS` file
- Add a release in your github repo and instruct users to add the release as `- ghr:yourgithubuser/yourrepo` or if they need a spcecific release `- ghr:yourgithubuser/yourrepo/release-name`
- You can put it on any other web server, and tell people to load it via https, e.g. `- https://mydomain.com/mypugname.plug.json`.
2022-07-16 10:18:31 +00:00
### Recommended development workflow
2022-10-29 14:57:12 +00:00
I develop plugs as follows: in one terminal I have `deno task watch` running at all times, constantly recompiling my code as I change it.
2022-07-16 10:18:31 +00:00
I also have SB open with a `file:` based link in my `PLUGS` file.
2022-10-29 14:57:12 +00:00
Whenever I want to test a change, I switch to SB, hit `Cmd-Shift-p` and test if stuff works.
2022-07-16 10:18:31 +00:00
2022-10-29 14:57:12 +00:00
Often I also have the `Debug: Show Logs` command running to monitor both server and client logs for any errors and debug information.