这是indexloc提供的服务,不要输入任何密码
Skip to content

ocdtrekkie/tempest

 
 

Folders and files

NameName
Last commit message
Last commit date

Latest commit

 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 

Repository files navigation

This repository contains an experimental replacement for Sandstorm. See the Blog Post.

Currently, most of the sandbox setup code is built, and tempest is capable of spawning sandstorm apps and plumbing http traffic to them from the outside, though many http features are not yet implemented.

Building

To build tempest, you will need:

  • Go 1.19 or later
  • tinygo
    • If the build complains about missing wasm-opt, you may also need to install the binaryen package.
  • Standard C development tools (make, a C compiler, etc).
  • capnp (command line tool) version 0.8 or later.
  • capnpc-go code generator plugin

You will also need to separately check out the source for go-capnp and go.sandstorm:

mkdir ../deps
cd ../deps
git clone https://github.com/capnproto/go-capnproto2
git clone https://github.com/zenhack/go.sandstorm
cd -

Then, run the configure script and then make. The configure script accepts most of the same options as typical gnu packages. Additionally you will need to supply the paths to the repositories checked out above:

./configure \
    --with-go-capnp=../deps/go-capnproto2 \
    --with-go-sandstorm=../deps/go.sandstorm
make

Then run make install to install tempest system wide.

Tip: you can configure tempest to share a grain/app storage directory with a sandstorm system by passing --localstatedir=/opt/sandstorm/var to ./configure. In addition to the files used by sandstorm, tempest will create a couple extra things underneath that path, namely:

  • an extra directory at sandstorm/mnt
  • a sqlite3 database at sandstorm/sandstorm.sqlite3

Importing data from sandstorm

Tempest comes with a tool to import some data from a sandstorm installation's database; after running make, there will be an executable at _build/sandstorm-import-tool. On a typical sandstorm server you can export the contents of the database via:

./_build/sandstorm-import-tool --snapshot-dir /desired/path/to/snapshot export

If your sandstorm installation is in a non-standard path or mongoDB is listening on a different port, you may have to supply additional options; see sandstorm-import-tool --help to see the full list.

You can then import the snapshot into tempest via:

./_build/sandstorm-import-tool --snapshot-dir /path/to/snapshot import

For some development, it can be useful to export & import from sandstorm frequently. Therefore, we have a Makefile target for this:

sudo make export-import

...which will automate the above, using the default values to sandstorm-import-tool's flags. It will also destroy the old database and fix permissions on the new one.

Running

At present, tempest has no user interface, and no way to install apps or create grains; to experiment with it you must separately arrange a suitable grain storage directory and populate the database. The easiest way to do this is to point it at an existing sandstorm installation, and import database info using sandstorm-import-tool, per above.

tempest should be run as the user and group chosen by the via the --user and --groupflags to./configure(by default bothsandstorm`). The easiest way to do this is to run as root:

sudo -u sandstorm -g sandstorm /path/to/tempest

For development purposes, the Makefile includes a dev target that will rebuild, reinstall, and then spawn tempest; simply run:

sudo make dev`

tempest will start a web server on port 8000; to connect to the UI, go to http://local.sandstorm.io:8000.

To log in with a developer account, click "Log in with dev account", and enter the dev account's name, e.g. "Alice Dev Admin."

Once you have logged in, a list of grains the user owns will be displayed; click the links to open the grains.

This will display the grain's UI within an iframe. Things like offer iframes and anything that uses sandstorm specific APIs will not work currently.

About

No description, website, or topics provided.

Resources

License

Stars

Watchers

Forks

Releases

No releases published

Packages

No packages published

Languages

  • Go 67.8%
  • Cap'n Proto 16.3%
  • C 11.3%
  • HTML 2.0%
  • CSS 1.7%
  • Makefile 0.9%