1
0
mirror of https://github.com/osmarks/mycorrhiza.git synced 2024-10-30 11:46:16 +00:00
mycorrhiza/user/files.go

169 lines
3.6 KiB
Go
Raw Normal View History

2020-11-14 14:46:04 +00:00
package user
import (
"encoding/json"
"io/ioutil"
"log"
"os"
"golang.org/x/crypto/bcrypt"
2021-04-28 10:12:05 +00:00
"github.com/bouncepaw/mycorrhiza/cfg"
"github.com/bouncepaw/mycorrhiza/util"
2021-04-28 10:12:05 +00:00
"github.com/bouncepaw/mycorrhiza/files"
2020-11-14 14:46:04 +00:00
)
2021-04-28 10:12:05 +00:00
// InitUserDatabase checks the configuration for auth methods and loads users
// if necessary. Call it during initialization.
func InitUserDatabase() {
AuthUsed = cfg.UseFixedAuth || cfg.UseRegistration
2021-04-28 10:12:05 +00:00
2021-06-19 04:51:10 +00:00
if AuthUsed {
2021-04-28 10:12:05 +00:00
ReadUsersFromFilesystem()
}
}
// ReadUsersFromFilesystem reads all user information from filesystem and stores it internally.
func ReadUsersFromFilesystem() {
if cfg.UseFixedAuth {
// This one will be removed.
2021-04-26 16:29:41 +00:00
rememberUsers(usersFromFixedCredentials())
}
// And this one will be renamed to just "users" in the future.
rememberUsers(usersFromRegistrationCredentials())
// Migrate fixed users to registered
tryToMigrate()
readTokensToUsers()
}
func tryToMigrate() {
// Fixed authorization should be removed by the next release (1.13).
// So let's try to help fixed users and migrate them over!
migrated := 0
for user := range YieldUsers() {
if user.Source == SourceFixed {
hashedPasswd, err := bcrypt.GenerateFromPassword([]byte(user.Password), bcrypt.DefaultCost)
if err != nil {
log.Fatal("Failed to migrate fixed users:", err)
}
user.Password = ""
user.HashedPassword = string(hashedPasswd)
user.Source = SourceRegistration
migrated++
}
}
if migrated > 0 {
if err := dumpRegistrationCredentials(); err != nil {
log.Fatal("Failed to migrate fixed users:", err)
}
log.Printf("Migrated %d users", migrated)
}
}
2021-04-26 16:29:41 +00:00
func usersFromFile(path string, source UserSource) (users []*User) {
contents, err := ioutil.ReadFile(path)
if os.IsNotExist(err) {
return
}
2020-11-14 14:46:04 +00:00
if err != nil {
log.Fatal(err)
}
err = json.Unmarshal(contents, &users)
2020-11-14 14:46:04 +00:00
if err != nil {
log.Fatal(err)
}
for _, u := range users {
2021-06-03 13:16:15 +00:00
u.Name = util.CanonicalName(u.Name)
2021-04-26 16:29:41 +00:00
u.Source = source
}
2021-04-26 16:29:41 +00:00
return users
}
func usersFromFixedCredentials() []*User {
users := usersFromFile(files.FixedCredentialsJSON(), SourceFixed)
log.Println("Found", len(users), "fixed users")
return users
}
func usersFromRegistrationCredentials() []*User {
users := usersFromFile(files.RegistrationCredentialsJSON(), SourceRegistration)
2021-04-26 16:29:41 +00:00
log.Println("Found", len(users), "registered users")
return users
}
func rememberUsers(userList []*User) {
for _, user := range userList {
users.Store(user.Name, user)
2020-11-14 14:46:04 +00:00
}
}
2020-11-14 14:46:04 +00:00
func readTokensToUsers() {
contents, err := ioutil.ReadFile(files.TokensJSON())
2020-11-14 14:46:04 +00:00
if os.IsNotExist(err) {
return
}
if err != nil {
log.Fatal(err)
}
2020-11-14 14:46:04 +00:00
var tmp map[string]string
err = json.Unmarshal(contents, &tmp)
if err != nil {
log.Fatal(err)
}
2020-11-14 14:46:04 +00:00
for token, username := range tmp {
commenceSession(username, token)
2020-11-14 14:46:04 +00:00
}
log.Println("Found", len(tmp), "active sessions")
}
2021-04-26 16:29:41 +00:00
func dumpRegistrationCredentials() error {
tmp := []*User{}
for u := range YieldUsers() {
if u.Source != SourceRegistration {
continue
}
copiedUser := u
copiedUser.Password = ""
tmp = append(tmp, copiedUser)
}
blob, err := json.MarshalIndent(tmp, "", "\t")
2021-04-26 16:29:41 +00:00
if err != nil {
log.Println(err)
return err
}
err = ioutil.WriteFile(files.RegistrationCredentialsJSON(), blob, 0644)
2021-04-26 16:29:41 +00:00
if err != nil {
log.Println(err)
return err
}
return nil
}
func dumpTokens() {
tmp := make(map[string]string)
tokens.Range(func(k, v interface{}) bool {
token := k.(string)
username := v.(string)
tmp[token] = username
return true
})
blob, err := json.MarshalIndent(tmp, "", "\t")
if err != nil {
log.Println(err)
} else {
ioutil.WriteFile(files.TokensJSON(), blob, 0644)
}
}