1
0
This commit is contained in:
Zef Hemel 2022-10-24 13:51:26 +02:00
parent 2d9240ee25
commit 01aea4768b
11 changed files with 178 additions and 66 deletions

View File

@ -42,9 +42,31 @@ Or checkout these two videos:
## Installing Silver Bullet ## Installing Silver Bullet
Silver Bullet is built using [Deno](https://deno.land). To install it, you will ### Installing Deno
need to have Deno installed (tested on 1.26 or later). If you have homebrew on a
Mac, this is just a single `brew install deno` away. Silver Bullet is built using [Deno](https://deno.land). To install Deno on Linux
or Mac run:
```shell
curl -fsSL https://deno.land/install.sh | sh
```
This will install Deno into `~/.deno/bin`, add this folder to your `PATH` in
your `~/.bashrc` or `~/.zshrc` file.
To install Deno on Windows (using Powershell) run:
```powershell
irm https://deno.land/install.ps1 | iex
```
### Install Silver Bullet
With Deno installed (see instruction above), run:
```shell
deno install -f --name silverbullet -A --unstable https://get.silverbullet.md
```
To run Silver Bullet create a folder for your pages (it can be empty, or be an To run Silver Bullet create a folder for your pages (it can be empty, or be an
existing folder with `.md` files) and run the following command in your existing folder with `.md` files) and run the following command in your

29
cmd/fix.ts Normal file
View File

@ -0,0 +1,29 @@
import { path } from "../server/deps.ts";
export async function fixCommand(_options: any, folder: string) {
folder = path.resolve(Deno.cwd(), folder);
console.log("Now going to attempt to fix", folder);
console.log(`First, we'll purge the ${folder}/_plug folder...`);
try {
await Deno.remove(path.join(folder, "_plug"), { recursive: true });
} catch (e: any) {
if (e instanceof Deno.errors.NotFound) {
console.log("No _plug folder found, nothing to do here.");
} else {
console.error("Something went wrong:", e);
}
}
console.log("And now we'll delete data.db");
try {
await Deno.remove(path.join(folder, "data.db"));
} catch (e: any) {
if (e instanceof Deno.errors.NotFound) {
console.log("No data.db found, nothing to do here.");
} else {
console.error("Something went wrong:", e);
}
}
console.log(
"Alright then, that should be it. Try running Silver Bullet again.",
);
}

26
cmd/server.ts Normal file
View File

@ -0,0 +1,26 @@
import { path } from "../server/deps.ts";
import { HttpServer } from "../server/http_server.ts";
import assetBundle from "../dist/asset_bundle.json" assert { type: "json" };
import { AssetBundle, AssetJson } from "../plugos/asset_bundle/bundle.ts";
export function serveCommand(options: any, folder: string) {
const pagesPath = path.resolve(Deno.cwd(), folder);
const port = options.port || 3000;
console.log(
"Going to start Silver Bullet on port",
port,
"serving pages from",
pagesPath,
);
const httpServer = new HttpServer({
port: port,
pagesPath: pagesPath,
assetBundle: new AssetBundle(assetBundle as AssetJson),
password: options.password,
});
httpServer.start().catch((e) => {
console.error(e);
});
}

39
cmd/upgrade.ts Normal file
View File

@ -0,0 +1,39 @@
import { version } from "../version.ts";
export async function upgradeCommand() {
console.log(
"Now going to attempt an upgrade, this may involve downloading the Internet (but there may be cool spinners). Prepare!",
);
const p = Deno.run({
cmd: ["deno", "cache", "--reload", Deno.mainModule],
});
const exitCode = await p.status();
if (!exitCode.success) {
console.error("Something went wrong there...");
Deno.exit(1);
}
console.log(
"So, that's done. Now let's see if this actually did anything...",
);
const vp = Deno.run({
cmd: ["deno", "run", "-A", "--unstable", Deno.mainModule, "version"],
stdout: "piped",
});
const versionStatus = await vp.status();
if (!versionStatus.success) {
console.error("Could not run version command, something is wrong.");
Deno.exit(1);
}
const rawVersion = await vp.output();
const newVersion = new TextDecoder().decode(rawVersion).trim();
if (newVersion === version) {
console.log(
`Nope. I hate to tell you this, but it looks like we're stilling running ${newVersion}.\nThis was a bit of a futile exercise. Let's try again soon some time.`,
);
} else {
console.log(
`Congrats, we've upgraded you from ${version} to ${newVersion}. Seems like quite bump, enjoy! https://silverbullet.md/changelog/ may give you more hints on what's new.`,
);
}
}

5
cmd/version.ts Normal file
View File

@ -0,0 +1,5 @@
import { version } from "../version.ts";
export function versionCommand() {
console.log(version);
}

View File

@ -1,14 +1,15 @@
{ {
"tasks": { "tasks": {
"clean": "rm -rf dist dist_bundle", "clean": "rm -rf dist dist_bundle",
"install": "deno install -f -A --unstable plugos/bin/plugos-bundle.ts && deno install -f -n silverbullet -A --unstable server/silverbullet.ts", "install": "deno install -f -A --unstable plugos/bin/plugos-bundle.ts && deno install -f -A --unstable silverbullet.ts",
"test": "deno test -A --unstable", "test": "deno test -A --unstable",
"build": "./build_plugs.sh && deno run -A --unstable --check build.ts", "build": "./build_plugs.sh && deno run -A --unstable --check build.ts",
"watch-web": "deno run -A --unstable --check build.ts --watch", "watch-web": "deno run -A --unstable --check build.ts --watch",
"watch-server": "deno run -A --unstable --check --watch server/silverbullet.ts", "watch-server": "deno run -A --unstable --check --watch silverbullet.ts",
// The only reason to run a shell script is that deno task doesn't support globs yet (e.g. *.plug.yaml) // The only reason to run a shell script is that deno task doesn't support globs yet (e.g. *.plug.yaml)
"watch-plugs": "./build_plugs.sh --watch", "watch-plugs": "./build_plugs.sh --watch",
"bundle": "deno bundle --importmap import_map.json server/silverbullet.ts dist/silverbullet.js", "bundle": "deno bundle --importmap import_map.json silverbullet.ts dist/silverbullet.js",
// Regenerates some bundle files (checked into the repo)
"generate": "deno run -A plugos/gen.ts" "generate": "deno run -A plugos/gen.ts"
}, },

View File

@ -85,6 +85,7 @@ export class HttpServer {
this.system.addHook(namespaceHook); this.system.addHook(namespaceHook);
// The space // The space
try {
this.spacePrimitives = new AssetBundlePlugSpacePrimitives( this.spacePrimitives = new AssetBundlePlugSpacePrimitives(
new EventedSpacePrimitives( new EventedSpacePrimitives(
new PlugSpacePrimitives( new PlugSpacePrimitives(
@ -96,6 +97,14 @@ export class HttpServer {
this.assetBundle, this.assetBundle,
); );
this.space = new Space(this.spacePrimitives); this.space = new Space(this.spacePrimitives);
} catch (e: any) {
if (e instanceof Deno.errors.NotFound) {
console.error("Pages folder", options.pagesPath, "not found");
} else {
console.error(e.message);
}
Deno.exit(1);
}
// The database used for persistence (SQLite) // The database used for persistence (SQLite)
this.db = new AsyncSQLite(path.join(options.pagesPath, "data.db")); this.db = new AsyncSQLite(path.join(options.pagesPath, "data.db"));

View File

@ -1,45 +0,0 @@
import { Command } from "https://deno.land/x/cliffy@v0.25.2/command/command.ts";
import * as path from "https://deno.land/std@0.158.0/path/mod.ts";
import { HttpServer } from "./http_server.ts";
import assetBundle from "../dist/asset_bundle.json" assert { type: "json" };
import { AssetBundle, AssetJson } from "../plugos/asset_bundle/bundle.ts";
await new Command()
.name("silverbullet")
.description("Markdown as a platform")
// Main command
.arguments("<folder:string>")
.option("-p, --port <port:number>", "Port to listen on")
.option("--password <password:string>", "Password for basic authentication")
.action((options, folder) => {
const pagesPath = path.resolve(Deno.cwd(), folder);
const port = options.port || 3000;
console.log("Pages folder:", pagesPath);
const httpServer = new HttpServer({
port: port,
pagesPath: pagesPath,
assetBundle: new AssetBundle(assetBundle as AssetJson),
password: options.password,
});
httpServer.start().catch((e) => {
console.error(e);
});
})
// Upgrade command
.command("upgrade", "Upgrade Silver Bullet")
.action(async () => {
console.log("Attempting upgrade...");
const p = Deno.run({
cmd: ["deno", "cache", "--reload", Deno.mainModule],
});
const exitCode = await p.status();
if (exitCode.success) {
console.log("Upgrade succeeded");
} else {
console.error("Upgrade failed");
}
})
.parse(Deno.args);

View File

@ -1,5 +0,0 @@
export function safeRun(fn: () => Promise<void>) {
fn().catch((e) => {
console.error(e);
});
}

30
silverbullet.ts Executable file
View File

@ -0,0 +1,30 @@
import { Command } from "https://deno.land/x/cliffy@v0.25.2/command/command.ts";
import { version } from "./version.ts";
import { upgradeCommand } from "./cmd/upgrade.ts";
import { versionCommand } from "./cmd/version.ts";
import { fixCommand } from "./cmd/fix.ts";
import { serveCommand } from "./cmd/server.ts";
await new Command()
.name("silverbullet")
.description("Markdown as a platform")
.version(version)
.help({
colors: false,
})
.usage("<options> <folder> | <command> (see below)")
// Main command
.arguments("<folder:string>")
.option("-p, --port <port:number>", "Port to listen on")
.option("--password <password:string>", "Password for basic authentication")
.action(serveCommand)
.command("fix", "Fix a broken space")
.arguments("<folder:string>")
.action(fixCommand)
.command("upgrade", "Upgrade Silver Bullet")
.action(upgradeCommand)
.command("version", "Get current version")
.action(versionCommand)
.parse(Deno.args);

1
version.ts Normal file
View File

@ -0,0 +1 @@
export const version = "0.1.13";