-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathmanagement.go
92 lines (86 loc) · 2.57 KB
/
management.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
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
package oauth
import (
"context"
"einstein-server/database"
"fmt"
"os"
"github.com/auth0/go-auth0/management"
"github.com/google/uuid"
"golang.org/x/oauth2"
)
func GetClient() (*management.Management, error) {
// Initialize a new client using a domain, client ID and secret.
m, err := management.New(
os.Getenv("AUTH0_DOMAIN"),
management.WithClientCredentials(
context.TODO(),
os.Getenv("AUTH0_CLIENT_ID"),
os.Getenv("AUTH0_CLIENT_SECRET"),
),
)
if err != nil {
logger.Err(err).Msg("")
return nil, err
}
return m, nil
}
func GetUserIdPToken(userId uuid.UUID, provider string) (oauth2.Token, error) {
client, err := GetClient()
tok := oauth2.Token{}
if err != nil {
logger.Err(err).Msg("")
return tok, err
}
db := database.GetConnection()
var dbUser database.User
if err = db.Get(&dbUser, database.SqlUserSelect, userId); err != nil {
logger.Err(err).Msg("")
return tok, err
}
users, err := client.User.ListByEmail(context.TODO(), dbUser.Email)
if len(users) > 0 {
for _, user := range users {
for _, i := range user.Identities {
if *i.Provider == provider {
if i.AccessToken != nil {
tok.AccessToken = *i.AccessToken
}
if i.RefreshToken != nil {
tok.RefreshToken = *i.RefreshToken
}
return tok, nil
}
}
}
} else {
err = fmt.Errorf("There is no user with such email.")
logger.Err(err).Msg("")
return tok, err
}
return tok, nil
}
func AttachSecondaryUser(emailPrimary, emailSecondary string) error {
client, err := GetClient()
if err != nil {
logger.Err(err).Msg("")
return err
}
users, err := client.User.ListByEmail(context.TODO(), emailPrimary)
primaryUser := users[0]
users, err = client.User.ListByEmail(context.TODO(), emailSecondary)
secondaryUser := users[0]
secondaryIdentity := getGoogleIdentity(*secondaryUser)
client.User.Link(context.TODO(), *primaryUser.ID, &management.UserIdentityLink{
UserID: secondaryUser.ID,
Provider: secondaryIdentity.Provider,
})
return nil
}
func getGoogleIdentity(user management.User) *management.UserIdentity {
for _, i := range user.Identities {
if *i.Provider == "google-oauth2" {
return i
}
}
return nil
}