2019-08-14 18:20:01 +02:00
|
|
|
// Copyright 2019 Google LLC
|
|
|
|
//
|
|
|
|
// Licensed under the Apache License, Version 2.0 (the "License"); you may not
|
|
|
|
// use this file except in compliance with the License. You may obtain a copy of
|
|
|
|
// the License at
|
|
|
|
//
|
|
|
|
// https://www.apache.org/licenses/LICENSE-2.0
|
|
|
|
//
|
|
|
|
// Unless required by applicable law or agreed to in writing, software
|
|
|
|
// distributed under the License is distributed on an "AS IS" BASIS, WITHOUT
|
|
|
|
// WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. See the
|
|
|
|
// License for the specific language governing permissions and limitations under
|
|
|
|
// the License.
|
|
|
|
|
|
|
|
// Package config implements structures to store Nixery's configuration at
|
|
|
|
// runtime as well as the logic for instantiating this configuration from the
|
|
|
|
// environment.
|
|
|
|
package config
|
|
|
|
|
|
|
|
import (
|
|
|
|
"io/ioutil"
|
|
|
|
"log"
|
|
|
|
"os"
|
|
|
|
|
|
|
|
"cloud.google.com/go/storage"
|
|
|
|
)
|
|
|
|
|
|
|
|
// Load (optional) GCS bucket signing data from the GCS_SIGNING_KEY and
|
|
|
|
// GCS_SIGNING_ACCOUNT envvars.
|
|
|
|
func signingOptsFromEnv() *storage.SignedURLOptions {
|
|
|
|
path := os.Getenv("GCS_SIGNING_KEY")
|
|
|
|
id := os.Getenv("GCS_SIGNING_ACCOUNT")
|
|
|
|
|
|
|
|
if path == "" || id == "" {
|
|
|
|
log.Println("GCS URL signing disabled")
|
|
|
|
return nil
|
|
|
|
}
|
|
|
|
|
|
|
|
log.Printf("GCS URL signing enabled with account %q\n", id)
|
|
|
|
k, err := ioutil.ReadFile(path)
|
|
|
|
if err != nil {
|
|
|
|
log.Fatalf("Failed to read GCS signing key: %s\n", err)
|
|
|
|
}
|
|
|
|
|
|
|
|
return &storage.SignedURLOptions{
|
|
|
|
GoogleAccessID: id,
|
|
|
|
PrivateKey: k,
|
|
|
|
Method: "GET",
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2019-09-03 00:32:36 +02:00
|
|
|
func getConfig(key, desc, def string) string {
|
2019-08-14 18:20:01 +02:00
|
|
|
value := os.Getenv(key)
|
2019-09-03 00:32:36 +02:00
|
|
|
if value == "" && def == "" {
|
2019-08-14 18:20:01 +02:00
|
|
|
log.Fatalln(desc + " must be specified")
|
2019-09-03 00:32:36 +02:00
|
|
|
} else if value == "" {
|
|
|
|
return def
|
2019-08-14 18:20:01 +02:00
|
|
|
}
|
|
|
|
|
|
|
|
return value
|
|
|
|
}
|
|
|
|
|
2019-09-30 18:40:01 +02:00
|
|
|
// Config holds the Nixery configuration options.
|
2019-08-14 18:20:01 +02:00
|
|
|
type Config struct {
|
|
|
|
Bucket string // GCS bucket to cache & serve layers
|
|
|
|
Signing *storage.SignedURLOptions // Signing options to use for GCS URLs
|
|
|
|
Port string // Port on which to launch HTTP server
|
2019-09-08 22:53:22 +02:00
|
|
|
Pkgs PkgSource // Source for Nix package set
|
2019-09-03 00:32:36 +02:00
|
|
|
Timeout string // Timeout for a single Nix builder (seconds)
|
|
|
|
WebDir string // Directory with static web assets
|
2019-09-21 13:15:38 +02:00
|
|
|
PopUrl string // URL to the Nix package popularity count
|
2019-08-14 18:20:01 +02:00
|
|
|
}
|
|
|
|
|
2019-09-08 22:53:22 +02:00
|
|
|
func FromEnv() (*Config, error) {
|
|
|
|
pkgs, err := pkgSourceFromEnv()
|
|
|
|
if err != nil {
|
|
|
|
return nil, err
|
|
|
|
}
|
|
|
|
|
2019-08-14 18:20:01 +02:00
|
|
|
return &Config{
|
2019-09-03 00:32:36 +02:00
|
|
|
Bucket: getConfig("BUCKET", "GCS bucket for layer storage", ""),
|
|
|
|
Port: getConfig("PORT", "HTTP port", ""),
|
2019-09-08 22:53:22 +02:00
|
|
|
Pkgs: pkgs,
|
2019-08-14 18:20:01 +02:00
|
|
|
Signing: signingOptsFromEnv(),
|
2019-09-03 00:32:36 +02:00
|
|
|
Timeout: getConfig("NIX_TIMEOUT", "Nix builder timeout", "60"),
|
|
|
|
WebDir: getConfig("WEB_DIR", "Static web file dir", ""),
|
2019-09-21 13:15:38 +02:00
|
|
|
PopUrl: os.Getenv("NIX_POPULARITY_URL"),
|
2019-09-08 22:53:22 +02:00
|
|
|
}, nil
|
2019-08-14 18:20:01 +02:00
|
|
|
}
|