1
0
Fork 0
mirror of https://github.com/silverbulletmd/silverbullet.git synced 2026-06-29 16:34:27 +00:00
No description
Find a file
2026-06-29 17:07:08 +02:00
.cargo Fix: FreeBSD build (hopefully) 2026-06-16 09:25:02 +02:00
.github Update reference from website/ to docs/ everywhere 2026-06-23 09:15:34 +02:00
.vscode More Deno cleanup 2026-02-27 16:25:34 +01:00
bench Performance: performance tuned LuaTable 2026-03-26 17:22:40 +01:00
bin Rust fmt 2026-06-23 09:19:30 +02:00
build Rust backend/CLI replacement (previously Go) (#2010) 2026-06-16 08:40:41 +02:00
client Fix: make frontmatter live preview more consistent with rest of editor 2026-06-29 17:07:08 +02:00
docs Fix: make frontmatter live preview more consistent with rest of editor 2026-06-29 17:07:08 +02:00
e2e Fix: Disable "Bake" button on fenced code blocks 2026-06-24 15:52:55 +02:00
libraries Feature: frontmatter folding 2026-06-29 16:45:16 +02:00
plug-api Update reference from website/ to docs/ everywhere 2026-06-23 09:15:34 +02:00
plugs Feature: frontmatter folding 2026-06-29 16:45:16 +02:00
scripts Update reference from website/ to docs/ everywhere 2026-06-23 09:15:34 +02:00
server Rust fmt 2026-06-23 09:19:30 +02:00
server-common Rust fmt 2026-06-23 09:19:30 +02:00
server-runtime-chrome Rust fmt 2026-06-23 09:19:30 +02:00
.dockerignore Rust backend/CLI replacement (previously Go) (#2010) 2026-06-16 08:40:41 +02:00
.editorconfig Enable biome based formatter and reformat 2026-03-10 09:38:59 +01:00
.gitignore website: add diagram 2026-06-23 09:01:10 +02:00
.node-version Fix node.js version to 24.13 2026-02-14 22:17:37 +01:00
.nvmrc Fix node.js version to 24.13 2026-02-14 22:17:37 +01:00
biome.json Rust backend/CLI replacement (previously Go) (#2010) 2026-06-16 08:40:41 +02:00
Cargo.lock Enable server-side compression for GET requests 2026-06-21 14:37:32 +02:00
Cargo.toml Rust backend/CLI replacement (previously Go) (#2010) 2026-06-16 08:40:41 +02:00
CHANGELOG.md Repo refactor: rename "website" to "docs" 2026-06-23 09:12:24 +02:00
CONTRIBUTING.md Removing reference to LLM use, moving back to "merit based" judgment 2026-05-14 08:37:26 +02:00
docker-entrypoint.sh Fixing #1935 (#1944) 2026-04-22 20:58:14 +02:00
Dockerfile Rust backend/CLI replacement (previously Go) (#2010) 2026-06-16 08:40:41 +02:00
Dockerfile.runtime-api Rust backend/CLI replacement (previously Go) (#2010) 2026-06-16 08:40:41 +02:00
Dockerfile.website Update reference from website/ to docs/ everywhere 2026-06-23 09:15:34 +02:00
LICENSE.md Refactor of asset bundles 2022-10-12 11:47:13 +02:00
Makefile Makefile: rename "website" to "edit-docs" 2026-06-23 09:20:25 +02:00
package-lock.json 2.9.0 2026-06-11 09:03:16 +02:00
package.json Build optimization 2026-06-19 16:10:14 +02:00
playwright.config.ts Speed up e2e tests 2026-06-19 16:41:48 +02:00
README.md Update reference from website/ to docs/ everywhere 2026-06-23 09:15:34 +02:00
rust-toolchain.toml Rust backend/CLI replacement (previously Go) (#2010) 2026-06-16 08:40:41 +02:00
rustfmt.toml Rust backend/CLI replacement (previously Go) (#2010) 2026-06-16 08:40:41 +02:00
STYLE.md Update reference from website/ to docs/ everywhere 2026-06-23 09:15:34 +02:00
tsconfig.json Update reference from website/ to docs/ everywhere 2026-06-23 09:15:34 +02:00
version.ts 2.9.0 2026-06-11 09:03:16 +02:00
vitest.config.ts Update reference from website/ to docs/ everywhere 2026-06-23 09:15:34 +02:00

GitHub Repo stars Docker Pulls GitHub Downloads (all assets, all releases) GitHub contributors Ask DeepWiki

SilverBullet

SilverBullet is a Programmable, Private, Browser-based, Open Source, Self Hosted, Personal Knowledge Database — a fancy term for a "notes app on steroids".

Yowza! That surely is a lot of adjectives to describe a browser-based Markdown editor programmable with Lua.

Lets get more specific.

SilverBullet combines a clean live-preview editor with wiki-style linking, a built-in database and query language, and a fully integrated Space Lua scripting environment, turning your notes into a programmable system that grows with you.

In SilverBullet you keep your content as a collection of Markdown Pages (called a Space). You navigate your space using the Page Picker like a traditional notes app, or through Links like a wiki (except they are bi-directional).

If you are the writer type, youll appreciate SilverBullet as a clean Markdown editor with Live Preview. If you have more of an outliner personality, SilverBullet has Outlining tools for you. Productivity freak? Have a look at Tasks. More of a database person? You will appreciate Objects and Queries (SLIQ).

And if you are comfortable programming a little bit — now were really talking. You will love dynamically generating content with Space Lua (SilverBullets Lua dialect), or to use it to create custom Commands, Page Templates or Widgets.

You were told theres no such thing as a silver bullet. You were told wrong.

Much more detail can be found on silverbullet.md

Installing SilverBullet

Check out the instructions.

Developing SilverBullet

SilverBullet's frontend ("client") is written in TypeScript and built on top of the excellent CodeMirror 6 editor component. Additional UI is built using Preact. ESBuild is used to build the frontend.

The server backend is written in Rust (a Cargo workspace). It serves the pre-built client bundle, the file/space HTTP API, authentication, and a headless-Chrome runtime for server-side Lua.

Code structure

  • bin/silverbullet/: The standalone silverbullet server binary (Rust) (this is the one you generally run)
  • bin/sb/: The sb CLI client (Rust)
  • bin/plug-compile.ts: the plug compiler
  • client/: The SilverBullet client (browser, TypeScript)
  • server/: The SilverBullet server library (Rust): HTTP router, handlers, auth, runtime seam
  • server-common/: Shared Rust crate (space primitives, shared types)
  • server-runtime-chrome/: Headless-Chrome runtime backend (Rust)
  • plugs: Set of built-in plugs (TypeScript) that are distributed with SilverBullet
  • libraries: A set of libraries (space scripts, page templates, slash templates) distributed with SilverBullet (Space Lua)
  • plug-api/: Useful APIs for use in plugs and published to NPM
    • lib/: Useful libraries to be used in plugs
    • syscalls/: TypeScript wrappers around syscalls
    • types/: Various (client) types that can be references from plugs
  • scripts/: Useful scripts
  • docs/: documentation (also serves a silverbullet.md website content)

Requirements

  • Node.js 24+ and npm 10+: Used to build the frontend (client) and plugs
  • Rust (stable, via rustup): Used to build the server

The project includes .nvmrc and .node-version files. If you use nvm or another Node version manager, it will automatically use the correct Node.js version:

nvm use  # If using nvm

First, install dependencies:

make setup

To create a (release) build:

make

This will produce silverbullet and cli binaries in ./target/release/, run ./target/release/silverbullet to run the server.

Development workflow

SilverBullet has two halves you rebuild independently:

  • The client (TypeScript: client/) is built by ESBuild into client_bundle/, which the server then serves.
  • The server (Rust: server/, server-common/, server-runtime-chrome/, bin/silverbullet/) is a compiled binary.

Run the server in development with cargo run. A debug build serves the client bundle live from client_bundle/ on disk (a release build embeds it instead):

npm run build
cargo run <PATH-TO-YOUR-SPACE>

When you change only the client (TypeScript in client/): you do not need to restart the server. Rebuild just the client bundle and reload the page in your browser — the debug server serves the freshly-built bundle straight from disk:

npm run build

To build a self-contained release binary (with the client bundle embedded), and run it:

make
./target/release/silverbullet <PATH-TO-YOUR-SPACE>

Useful development tasks

# Clean all generated files
make clean
# Typecheck and lint all code
make check
# Format all code
make fmt
# Run all tests
make test
# Run benchmarks
make bench

Build a docker container

Note, you do not need Node.js nor Go locally installed for this to work:

docker build -t silverbullet .

To run:

docker run -p 3000:3000 -v <PATH-TO-YOUR-SPACE>:/space silverbullet