More website updates
parent
83c54b2754
commit
e291afc599
|
@ -1,34 +0,0 @@
|
|||
This is currently implemented in [this github repo](https://github.com/silverbulletmd/silverbullet-mount):
|
||||
|
||||
Space mounting in `MOUNTS`
|
||||
|
||||
```yaml
|
||||
- path: file:/Users/zef/git/blog
|
||||
prefix: blog/
|
||||
perm: ro,rw #default rw
|
||||
- path: http://someIP:3000
|
||||
prefix: prod/
|
||||
```
|
||||
|
||||
Features
|
||||
* Auto translates internal wiki links (prefixes with prefix) and removes prefix upon save
|
||||
|
||||
To do:
|
||||
* [ ] Handle queries
|
||||
* `page` and `link` query needs to dynamically add/remove a `and name =~ /^🚪 PREFIX/` clause)
|
||||
* `task` same but with `page` check
|
||||
* [x] Add `file:` support
|
||||
* [x] Add `http:`/`https:` support
|
||||
|
||||
* Due to namespacing, the mounted space needs to be namespaced somehow
|
||||
* Could be an emoji, could be a page prefix (now using `name`)
|
||||
* On the fly link rewriting on read and write with prefix
|
||||
* Will require an actual set of `fs` syscalls:
|
||||
* readFile(path)
|
||||
* writeFile(path, text)
|
||||
* listFiles(path) with stat-like results (at least enough for `PageMeta` responses)
|
||||
* If this exists, should not all disk file access work through plugs as well and have that abstraction happen at this level?
|
||||
|
||||
protocols:
|
||||
* file:
|
||||
* http/https with “password” field for authentication
|
|
@ -8,12 +8,12 @@ What does Silver Bullet look like? Well, have a look around. **You’re looking
|
|||
|
||||
Note that what you’re looking at is not a fully functional version, because the _back-end is read-only_. That said, it should give you some feel for what it’s like to use SB before making the commitment of running a single `npx` command (see below) to download and run it locally in its fully functioning mode.
|
||||
|
||||
## Playground
|
||||
## Start playing
|
||||
So, feel free to make some edits in this space. Don’t worry, you won’t break anything, nothing is saved (just reload the page to see).
|
||||
|
||||
Here are some things to try:
|
||||
|
||||
* Click on the page name at the top, or hit `Cmd-k` (Mac) or `Ctrl-k` (Linux and Windows) to open the **page switcher**. Type the a name of a non-existing page to create it (although it won’t save in this environment).
|
||||
* Click on the page title (`index` for this particular one) at the top, or hit `Cmd-k` (Mac) or `Ctrl-k` (Linux and Windows) to open the **page switcher**. Type the a name of a non-existing page to create it (although it won’t save in this environment).
|
||||
* Click on the run button (top right) or hit `Cmd-/` (Mac) or `Ctrl-/` (Linux and Windows) to open the **command palette** (note not all commands will work in this quasi read-only mode).
|
||||
* Select some text and hit `Alt-m` to ==highlight== it, or `Cmd-b` (Mac) or `Ctrl-b` to make it **bold**.
|
||||
* Click a link somewhere in this page to navigate there.
|
||||
|
@ -25,15 +25,15 @@ Here are some things to try:
|
|||
* Open this site on your phone or tablet and… it just works!
|
||||
* Are you using a browser with **PWA support** (e.g. any Chromium-based browser)? Click on that little icon to the right of your location bar that says “Install Silver Bullet” to give SB its own window frame and desktop icon, like it is a stand-alone app (not particularly useful on silverbullet.md, but definitely do this once you install it yourself).
|
||||
|
||||
There are a few features you don’t get to try in this environment, because they rely on back-end processing, such as:
|
||||
There are a few features you don’t get to fully experience in this environment, because they rely on a working back-end, such as:
|
||||
|
||||
* Using SB’s powerful page indexing and **query mechanism** where part of pages are automatically rendered and kept up to date by querying various data sources (such as pages and their metadata, back links, tasks embedded in pages, and list items) with an SQL like syntax, rendered with handlebars templates.
|
||||
* Intelligent page renaming, automatically updating any pages that link to it.
|
||||
* Full text search.
|
||||
* **Extending** and updating SB’s functionality by installing additional [[🔌 Plugs]] and writing your own.
|
||||
* Intelligent **page renaming**, automatically updating any pages that link to it.
|
||||
* **Full text search**.
|
||||
* **Extending** and updating SB’s functionality by installing additional [[🔌 Plugs]] (SB parlance for plug-ins) and writing your own.
|
||||
|
||||
## Extensions
|
||||
What type of extensions, you ask? Let us demonstrate this in a very meta way: by querying a list of plugs an injecting it into this page!
|
||||
What type of extensions, you ask? Let us demonstrate this in a very meta way: by querying a list of plugs and injecting it into this page!
|
||||
|
||||
Here’s a list of (non-built in) plugs documented in this space (note the `#query` ... `/query` notation used):
|
||||
|
||||
|
@ -46,7 +46,7 @@ Here’s a list of (non-built in) plugs documented in this space (note the `#que
|
|||
* [[🔌 Backlinks]] by **Guillermo Vayá** ([repo](https://github.com/Willyfrog/silverbullet-backlinks))
|
||||
<!-- /query -->.
|
||||
|
||||
In a regular SB installation, the body of this query 👆 (in between the placeholders) would automatically be kept up to date as new pages are added to the space that match the query. 🤯 Have a look at the [[template/plug]] template (referenced in the `render` clause) to see how the results are rendered, and have a look at one of the linked pages to see how the meta data used to query and render is supplied to SB. And to learn about the specific plug, of course.
|
||||
In a regular SB installation, the body of this query 👆 (in between the placeholders) would automatically be kept up to date as new pages are added to the space that match the query. 🤯 Have a look at the [[template/plug]] _template_ (referenced in the `render` clause) to see how the results are rendered using handlebars syntax, and have a look at one of the linked pages to see how the _meta data_ is specified, which is subsequently used to query and render in this page. And to learn about the specific plug, of course.
|
||||
|
||||
## Explore more
|
||||
Click on the links below to explore various aspects of Silver Bullet more in-depth:
|
||||
|
@ -67,7 +67,6 @@ Some core principles that underly Silver Bullet’s philosophy:
|
|||
|
||||
* **Free and open source**. Silver Bullet is MIT licensed.
|
||||
* **The truth is in the markdown.** Markdown is simply text files, stored on disk. Nothing fancy. No proprietary formats or lock in. While SB uses a database for indexing and caching some data, all of that can be rebuilt from its markdown source at any time. If SB would ever go away, you can still read your pages with any text editor.
|
||||
* **What you see is what it is.** No magic or hidden content.
|
||||
* **Single, distraction free mode.** SB doesn’t have a separate view and edit mode. It doesn’t have a “focus mode.” You’re always in focused edit mode, why wouldn’t you?
|
||||
* **Keyboard oriented**. You can use SB fully using the keyboard, typin’ the keys.
|
||||
* **Extend it your way**. SB is highly extensible with [[🔌 Plugs]], and you can customize it to your liking and your workflows.
|
||||
|
@ -79,10 +78,10 @@ To install and run SB, create a folder for your pages (it can be empty, or be an
|
|||
|
||||
npx @silverbulletmd/server <path-to-folder>
|
||||
|
||||
Optionally you can use the `—port` argument to specify a HTTP port (defaults to `3000`) and you can pass a `—password` flag to require a password to access. Note this is a rather weak security mechanism, so it’s recommended to add additional layers of security on top of this if you run this on a public server somewhere (at least add TLS). Personally I run it on a tiny Linux VM on my server at home, and use a VPN (Tailscale) to access it from outside my home.
|
||||
Optionally you can use the `--port` argument to specify a HTTP port (defaults to `3000`) and you can pass a `--password` flag to require a password to access. Note this is a rather weak security mechanism, so it’s recommended to add additional layers of security on top of this if you run this on a public server somewhere (at least add TLS). Personally I run it on a tiny Linux VM on my server at home, and use a VPN (Tailscale) to access it from outside my home.
|
||||
|
||||
Once downloaded and booted, you will be provided with a URL to open SB in your browser (spoiler alert: by default this will be http://localhost:3000 ).
|
||||
|
||||
That’s it! Enjoy.
|
||||
|
||||
If you (hypothetically) find bugs or have feature requests, post them in [our issue tracker](https://github.com/silverbulletmd/silverbullet). Want to contribute? [Check out the code](https://github.com/silverbulletmd/silverbullet).
|
||||
If you (hypothetically) find bugs or have feature requests, post them in [our issue tracker](https://github.com/silverbulletmd/silverbullet/issues). Want to contribute? [Check out the code](https://github.com/silverbulletmd/silverbullet).
|
||||
|
|
|
@ -20,4 +20,14 @@ Create a `MOUNTS` page:
|
|||
password: mypassword
|
||||
```
|
||||
|
||||
This will make these available under `🚪 docs/` and `🚪 remote/` respectively.
|
||||
This will make these available under `🚪 docs/` and `🚪 remote/` respectively.
|
||||
|
||||
## Features
|
||||
* Auto translates internal wiki links (prefixes with prefix) and removes prefix upon save
|
||||
|
||||
## To do
|
||||
* [ ] Handle queries
|
||||
* `page` and `link` query needs to dynamically add/remove a `and name =~ /^🚪 PREFIX/` clause)
|
||||
* `task` same but with `page` check
|
||||
* [x] Add `file:` support
|
||||
* [x] Add `http:`/`https:` support
|
||||
|
|
Loading…
Reference in New Issue