forked from direnv/direnv
-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathcmd_allow.go
65 lines (55 loc) · 1.57 KB
/
cmd_allow.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
64
65
package main
import (
"fmt"
"os"
"path/filepath"
)
// CmdAllow is `direnv allow [PATH_TO_RC]`
var CmdAllow = &Cmd{
Name: "allow",
Desc: "Grants direnv to load the given .envrc",
Args: []string{"[PATH_TO_RC]"},
Action: actionWithConfig(cmdAllowAction),
}
var migrationMessage = `
Migrating the allow data to the new location
The allowed .envrc permissions used to be stored in the XDG_CONFIG_DIR. It's
better to keep that folder for user-editable configuration so the data is
being moved to XDG_DATA_HOME.
`
func cmdAllowAction(env Env, args []string, config *Config) (err error) {
var rcPath string
if len(args) > 1 {
rcPath = args[1]
} else {
if rcPath, err = os.Getwd(); err != nil {
return err
}
}
if _, err = os.Stat(config.AllowDir()); os.IsNotExist(err) {
oldAllowDir := filepath.Join(config.ConfDir, "allow")
if _, err = os.Stat(oldAllowDir); err == nil {
fmt.Println(migrationMessage)
fmt.Printf("moving %s to %s\n", oldAllowDir, config.AllowDir())
if err = os.MkdirAll(filepath.Dir(config.AllowDir()), 0755); err != nil {
return err
}
if err = os.Rename(oldAllowDir, config.AllowDir()); err != nil {
return err
}
fmt.Printf("creating a symlink back from %s to %s for back-compat.\n", config.AllowDir(), oldAllowDir)
if err = os.Symlink(config.AllowDir(), oldAllowDir); err != nil {
return err
}
fmt.Println("")
fmt.Println("All done, have a nice day!")
}
}
rc, err := FindRC(rcPath, config)
if err != nil {
return err
} else if rc == nil {
return fmt.Errorf(".envrc file not found")
}
return rc.Allow()
}