2018-12-24 18:45:15 +01:00
|
|
|
/*
|
2019-05-12 22:55:30 +02:00
|
|
|
* Copyright © 2018-2019 A Bunch Tell LLC.
|
2018-12-24 18:45:15 +01:00
|
|
|
*
|
|
|
|
* This file is part of WriteFreely.
|
|
|
|
*
|
|
|
|
* WriteFreely is free software: you can redistribute it and/or modify
|
|
|
|
* it under the terms of the GNU Affero General Public License, included
|
|
|
|
* in the LICENSE file in this source code package.
|
|
|
|
*/
|
2018-12-31 07:05:26 +01:00
|
|
|
|
2018-10-15 20:44:15 +02:00
|
|
|
package writefreely
|
|
|
|
|
|
|
|
import (
|
2018-11-11 23:52:24 +01:00
|
|
|
"github.com/writeas/web-core/log"
|
2019-06-13 16:14:35 +02:00
|
|
|
"github.com/writeas/writefreely/key"
|
2018-10-15 20:44:15 +02:00
|
|
|
"io/ioutil"
|
2018-11-11 23:52:24 +01:00
|
|
|
"os"
|
2018-11-11 23:16:05 +01:00
|
|
|
"path/filepath"
|
|
|
|
)
|
|
|
|
|
|
|
|
const (
|
|
|
|
keysDir = "keys"
|
|
|
|
)
|
|
|
|
|
|
|
|
var (
|
|
|
|
emailKeyPath = filepath.Join(keysDir, "email.aes256")
|
|
|
|
cookieAuthKeyPath = filepath.Join(keysDir, "cookies_auth.aes256")
|
|
|
|
cookieKeyPath = filepath.Join(keysDir, "cookies_enc.aes256")
|
2018-10-15 20:44:15 +02:00
|
|
|
)
|
|
|
|
|
2019-06-14 00:50:23 +02:00
|
|
|
// InitKeys loads encryption keys into memory via the given Apper interface
|
|
|
|
func InitKeys(apper Apper) error {
|
|
|
|
log.Info("Loading encryption keys...")
|
|
|
|
err := apper.LoadKeys()
|
|
|
|
if err != nil {
|
|
|
|
return err
|
|
|
|
}
|
|
|
|
return nil
|
|
|
|
}
|
2018-10-15 20:44:15 +02:00
|
|
|
|
2019-05-12 22:55:30 +02:00
|
|
|
func initKeyPaths(app *App) {
|
2019-01-20 20:18:09 +01:00
|
|
|
emailKeyPath = filepath.Join(app.cfg.Server.KeysParentDir, emailKeyPath)
|
|
|
|
cookieAuthKeyPath = filepath.Join(app.cfg.Server.KeysParentDir, cookieAuthKeyPath)
|
|
|
|
cookieKeyPath = filepath.Join(app.cfg.Server.KeysParentDir, cookieKeyPath)
|
|
|
|
}
|
|
|
|
|
2018-11-11 23:52:24 +01:00
|
|
|
// generateKey generates a key at the given path used for the encryption of
|
|
|
|
// certain user data. Because user data becomes unrecoverable without these
|
|
|
|
// keys, this won't overwrite any existing key, and instead outputs a message.
|
|
|
|
func generateKey(path string) error {
|
|
|
|
// Check if key file exists
|
2019-01-20 19:43:06 +01:00
|
|
|
if _, err := os.Stat(path); err == nil {
|
2018-11-11 23:52:24 +01:00
|
|
|
log.Info("%s already exists. rm the file if you understand the consquences.", path)
|
|
|
|
return nil
|
2019-01-20 19:43:06 +01:00
|
|
|
} else if !os.IsNotExist(err) {
|
|
|
|
log.Error("%s", err)
|
|
|
|
return err
|
2018-11-11 23:52:24 +01:00
|
|
|
}
|
|
|
|
|
|
|
|
log.Info("Generating %s.", path)
|
2019-06-13 16:14:35 +02:00
|
|
|
b, err := key.GenerateBytes(key.EncKeysBytes)
|
2018-11-11 23:52:24 +01:00
|
|
|
if err != nil {
|
|
|
|
log.Error("FAILED. %s. Run writefreely --gen-keys again.", err)
|
|
|
|
return err
|
|
|
|
}
|
|
|
|
err = ioutil.WriteFile(path, b, 0600)
|
|
|
|
if err != nil {
|
|
|
|
log.Error("FAILED writing file: %s", err)
|
|
|
|
return err
|
|
|
|
}
|
|
|
|
log.Info("Success.")
|
|
|
|
return nil
|
|
|
|
}
|