-
Notifications
You must be signed in to change notification settings - Fork 47
/
env.go
63 lines (54 loc) · 1.5 KB
/
env.go
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
// Copyright (c) 2018 Dean Jackson <deanishe@deanishe.net>
// MIT Licence - http://opensource.org/licenses/MIT
package aw
import (
"fmt"
"os"
"strings"
)
// Env is the data source for configuration lookups.
//
// Pass a custom implementation to NewFromEnv() to provide a custom
// source for the required workflow configuration settings.
//
// As an absolute minimum, the following variables must be set:
//
// alfred_workflow_bundleid
// alfred_workflow_cache
// alfred_workflow_data
//
// See EnvVar* consts for all variables set by Alfred.
type Env interface {
// Lookup retrieves the value of the variable named by key.
//
// It follows the same semantics as os.LookupEnv(). If a variable
// is unset, the boolean will be false. If a variable is set, the
// boolean will be true, but the variable may still be an empty
// string.
Lookup(key string) (string, bool)
}
// sysEnv implements Env based on the real environment.
type sysEnv struct{}
// Lookup wraps os.LookupEnv().
func (e sysEnv) Lookup(key string) (string, bool) { return os.LookupEnv(key) }
// Check that minimum required values are set.
func validateEnv(env Env) error {
var (
issues []string
required = []string{
EnvVarBundleID,
EnvVarCacheDir,
EnvVarDataDir,
}
)
for _, k := range required {
v, ok := env.Lookup(k)
if !ok || v == "" {
issues = append(issues, k+" is not set")
}
}
if issues != nil {
return fmt.Errorf("invalid Workflow environment: %s", strings.Join(issues, ", "))
}
return nil
}