/
websess.go
51 lines (44 loc) · 1.27 KB
/
websess.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
// Package auth - Content managed by Project Forge, see [projectforge.md] for details.
package auth
import (
"net/http"
"github.com/samber/lo"
"admini.dev/admini/app/controller/csession"
"admini.dev/admini/app/lib/user"
"admini.dev/admini/app/util"
)
const WebAuthKey = "auth"
func addToSession(
provider string, email string, picture string, token string, w http.ResponseWriter, websess util.ValueMap, logger util.Logger,
) (*user.Account, user.Accounts, error) {
ret := getCurrentAuths(websess)
s := &user.Account{Provider: provider, Email: email, Picture: picture, Token: token}
for _, x := range ret {
if x.Provider == s.Provider && x.Email == s.Email {
return s, ret, nil
}
}
ret = append(ret, s)
err := setCurrentAuths(ret, w, websess, logger)
if err != nil {
return nil, nil, err
}
return s, ret, nil
}
func removeProviderData(w http.ResponseWriter, websess util.ValueMap, logger util.Logger) error {
dirty := false
lo.ForEach(websess.Keys(), func(s string, _ int) {
if isProvider(s) {
logger.Debug("removing auth info for provider [" + s + "]")
dirty = true
delete(websess, s)
}
})
if dirty {
return csession.SaveSession(w, websess, logger)
}
return nil
}
func isProvider(k string) bool {
return lo.Contains(AvailableProviderKeys, k)
}