mirror of
https://github.com/drakkan/sftpgo.git
synced 2024-11-25 17:10:28 +00:00
43182fc25e
These new APIs match the web client features. I'm aware that some API do not follow REST best practises. I want to avoid things likes "/user/folders/<path>" where "path" must be encoded and making it optional create issues, so I defined resources as query parameters instead of path parameters
62 lines
1.1 KiB
Go
62 lines
1.1 KiB
Go
package dataprovider
|
|
|
|
import (
|
|
"sync"
|
|
)
|
|
|
|
var cachedPasswords passwordsCache
|
|
|
|
func init() {
|
|
cachedPasswords = passwordsCache{
|
|
cache: make(map[string]string),
|
|
}
|
|
}
|
|
|
|
type passwordsCache struct {
|
|
sync.RWMutex
|
|
cache map[string]string
|
|
}
|
|
|
|
func (c *passwordsCache) Add(username, password string) {
|
|
if !config.PasswordCaching || username == "" || password == "" {
|
|
return
|
|
}
|
|
|
|
c.Lock()
|
|
defer c.Unlock()
|
|
|
|
c.cache[username] = password
|
|
}
|
|
|
|
func (c *passwordsCache) Remove(username string) {
|
|
if !config.PasswordCaching {
|
|
return
|
|
}
|
|
|
|
c.Lock()
|
|
defer c.Unlock()
|
|
|
|
delete(c.cache, username)
|
|
}
|
|
|
|
// Check returns if the user is found and if the password match
|
|
func (c *passwordsCache) Check(username, password string) (bool, bool) {
|
|
if username == "" || password == "" {
|
|
return false, false
|
|
}
|
|
|
|
c.RLock()
|
|
defer c.RUnlock()
|
|
|
|
pwd, ok := c.cache[username]
|
|
if !ok {
|
|
return false, false
|
|
}
|
|
|
|
return true, pwd == password
|
|
}
|
|
|
|
// CheckCachedPassword is an utility method used only in test cases
|
|
func CheckCachedPassword(username, password string) (bool, bool) {
|
|
return cachedPasswords.Check(username, password)
|
|
}
|