Documentation ¶
Overview ¶
Package serverconfig is responsible for mapping from a Camlistore configuration file and instantiating HTTP Handlers for all the necessary endpoints.
Index ¶
Constants ¶
const ( DefaultTLSCert = "config/selfgen_pem.crt" DefaultTLSKey = "config/selfgen_pem.key" )
Variables ¶
var ErrCamliPath = errors.New("Invalid Camlistore request path")
Functions ¶
Types ¶
type Config ¶
type Config struct { jsonconfig.Obj UIPath string // Not valid until after InstallHandlers // contains filtered or unexported fields }
A Config is the wrapper around a Camlistore JSON configuration file. Files on disk can be in either high-level or low-level format, but the Load function always returns the Config in its low-level format.
func Load ¶
Load returns a low-level "handler config" from the provided filename. If the config file doesn't contain a top-level JSON key of "handlerConfig" with boolean value true, the configuration is assumed to be a high-level "user config" file, and transformed into a low-level config.
func (*Config) InstallHandlers ¶
func (config *Config) InstallHandlers(hi HandlerInstaller, baseURL string, context *http.Request) (outerr error)
InstallHandlers creates and registers all the HTTP Handlers needed by config into the provided HandlerInstaller.
baseURL is required and specifies the root of this webserver, without trailing slash. context may be nil (used and required by App Engine only)
type HandlerInstaller ¶
A HandlerInstaller is anything that can register an HTTP Handler at a prefix path. Both *http.ServeMux and camlistore.org/pkg/webserver.Server implement HandlerInstaller.