To install the hz tool from npm:
$ npm install -g horizon
For a tutorial to learn how to use the cli, see the getting started guide.
For all the available commands for hz
, go to horizon.io/docs/server.
There are proper ways to get a certificate registered through a Certificate
Authority, but for the purpose of getting up-and-running as soon as possible,
generate a self-signed certificate. This command will generate the certificate
using the default options from openssl
, and should not be used for anything
serious:
hz create-cert
Once a key file and cert file have been obtained, launch the server with the --secure true
flag, and provide the files in the --key-file
and --cert-file
options.
One can also configure Horizon with a .hz/config.toml
toml configuration file. Here is an example configuration file below. Note that by default, hz serve
will look for .hz/config.toml
(which is created by hz init
) in the current directory.
This example shows the current defaults. To change them, you need to remove the #
from the beginning of the line and change the value. Note that [ table_name ]
toml table declarations need to also be uncommented in the OAuth configuration at the end of the file.
# This is a TOML file
###############################################################################
# IP options
# 'bind' controls which local interfaces will be listened on
# 'port' controls which port will be listened on
#------------------------------------------------------------------------------
# bind = [ "localhost" ]
# port = 8181
###############################################################################
# HTTPS Options
# 'insecure' will disable HTTPS and use HTTP instead
# 'key_file' and 'cert_file' are required for serving HTTPS
#------------------------------------------------------------------------------
# insecure = true
# key_file = "key.pem"
# cert_file = "cert.pem"
###############################################################################
# App Options
# 'project' will change to the given directory
# 'serve_static' will serve files from the given directory over HTTP/HTTPS
#------------------------------------------------------------------------------
# project = "horizon"
# serve_static = "dist"
###############################################################################
# Data Options
# WARNING: these should probably not be enabled on a publically accessible
# service. Tables and indexes are not lightweight objects, and allowing them
# to be created like this could open the service up to denial-of-service
# attacks.
# 'auto_create_table' creates a table when one is needed but does not exist
# 'auto_create_index' creates an index when one is needed but does not exist
#------------------------------------------------------------------------------
# auto_create_table = true
# auto_create_index = true
###############################################################################
# RethinkDB Options
# These options are mutually exclusive
# 'connect' will connect to an existing RethinkDB instance
# 'start_rethinkdb' will run an internal RethinkDB instance
#------------------------------------------------------------------------------
# connect = "localhost:28015"
# start_rethinkdb = false
###############################################################################
# Debug Options
# 'debug' enables debug log statements
#------------------------------------------------------------------------------
# debug = true
###############################################################################
# Authentication Options
# Each auth subsection will add an endpoint for authenticating through the
# specified provider.
# 'token_secret' is the key used to sign jwts
# 'allow_anonymous' issues new accounts to users without an auth provider
# 'allow_unauthenticated' allows connections that are not tied to a user id
# 'auth_redirect' specifies where users will be redirected to after login
#------------------------------------------------------------------------------
token_secret = <Long base64 key automatically generated by hz init>
# allow_anonymous = true
# allow_unauthenticated = true
# auth_redirect = "/"
#
# [auth.facebook]
# id = "000000000000000"
# secret = "00000000000000000000000000000000"
#
# [auth.google]
# id = "00000000000-00000000000000000000000000000000.apps.googleusercontent.com"
# secret = "000000000000000000000000"
#
# [auth.twitter]
# id = "0000000000000000000000000"
# secret = "00000000000000000000000000000000000000000000000000"
#
# [auth.github]
# id = "00000000000000000000"
# secret = "0000000000000000000000000000000000000000"
#
# [auth.twitch]
# id = "0000000000000000000000000000000"
# secret = "0000000000000000000000000000000"
If you are looking to work on Horizon itself, you will want your recent
changes to update your command line client hz
without having to go back
into each /client
, /server
, and /cli
directory to reinstall. So you
will want to use npm link
to update this on the fly.
We've included a script at /test/setupDev.sh
that you can run while
currently in the /test
directory that will set your hz
up in your
global npm folder.
Or you can follow these commands which achieve the same result:
# From the /client directory
npm link
# From the /server directory
npm link @horizon/client
npm link
# From the /cli directory
npm link @horizon/server
npm link