diff options
author | kali kaneko (leap communications) <kali@leap.se> | 2020-06-23 19:34:47 +0200 |
---|---|---|
committer | kali kaneko (leap communications) <kali@leap.se> | 2020-08-11 20:59:53 +0200 |
commit | 33b9ba9abadb8cea8f5840bb11fb9de489b120e3 (patch) | |
tree | 016d08673cefdedb58004a7bd5909d51d1770988 /pkg/bitmask | |
parent | 0f8eab4e1157e83f39cd7298378bb5cc9ddb913a (diff) |
[feat] authentication token for webapi
Diffstat (limited to 'pkg/bitmask')
-rw-r--r-- | pkg/bitmask/auth.go | 52 |
1 files changed, 52 insertions, 0 deletions
diff --git a/pkg/bitmask/auth.go b/pkg/bitmask/auth.go new file mode 100644 index 0000000..519eaf1 --- /dev/null +++ b/pkg/bitmask/auth.go @@ -0,0 +1,52 @@ +package bitmask + +import ( + "io/ioutil" + "log" + "math/rand" + "os" + "runtime" + "strings" + "time" +) + +/* functions for local authentication of control endpoints */ + +const tokenPath = "/dev/shm/bitmask-token" + +func GenerateAuthToken() { + if runtime.GOOS != "linux" { + log.Println("Authentication token only implemented in linux at the moment.") + return + } + t := getRandomString() + err := ioutil.WriteFile(tokenPath, []byte(t), os.FileMode(int(0600))) + if err != nil { + log.Println("Could not write authentication token.") + } +} + +func ReadAuthToken() string { + if runtime.GOOS != "linux" { + log.Println("Authentication token only implemented in linux at the moment.") + return "" + } + token, err := ioutil.ReadFile(tokenPath) + if err != nil { + log.Println("Error reading token:", err) + } + return string(token) +} + +func getRandomString() string { + rand.Seed(time.Now().UnixNano()) + chars := []rune("ABCDEFGHIJKLMNOPQRSTUVWXYZ" + + "abcdefghijklmnopqrstuvwxyz" + + "0123456789") + length := 40 + var b strings.Builder + for i := 0; i < length; i++ { + b.WriteRune(chars[rand.Intn(len(chars))]) + } + return b.String() +} |