-
Notifications
You must be signed in to change notification settings - Fork 3
/
gf_service.go
87 lines (64 loc) · 2.73 KB
/
gf_service.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
/*
GloFlow application and media management/publishing platform
Copyright (C) 2022 Ivan Trajkovic
This program is free software; you can redistribute it and/or modify
it under the terms of the GNU General Public License as published by
the Free Software Foundation; either version 2 of the License, or
(at your option) any later version.
This program is distributed in the hope that it will be useful,
but WITHOUT ANY WARRANTY; without even the implied warranty of
MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
GNU General Public License for more details.
You should have received a copy of the GNU General Public License
along with this program; if not, write to the Free Software
Foundation, Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA
*/
package gf_identity_core
//---------------------------------------------------
const (
GF_AUTH_SUBSYSTEM_TYPE__USERPASS = "userpass"
GF_AUTH_SUBSYSTEM_TYPE__ETH = "eth"
GF_AUTH_SUBSYSTEM_TYPE__AUTH0 = "auth0"
)
//---------------------------------------------------
type GFserviceInfo struct {
// name of this service, in case multiple are spawned
NameStr string
//------------------------
// DOMAIN - where this gf_solo instance is reachable on
DomainBaseStr string
// DOMAIN_FOR_AUTH_COOKIES - domain/pattern that is set on
// auth cookies, to restrict their scope.
// its either the same as DomainBaseStr, or can be prefixed with "."
// to include all the subdomains of that base domain.
// example:
// "gloflow.org" | ".gloflow.org" (include subdomains as well)
DomainForAuthCookiesStr *string
//------------------------
// AUTH_SUBSYSTEM_TYPE - userpass | auth0
AuthSubsystemTypeStr string
//------------------------
// ADMIN_MFA_SECRET_KEY_BASE32
AdminMFAsecretKeyBase32str string
//------------------------
// AUTH
// AUTH_LOGIN_URL - url of the login page to which the system should
// redirect users after certain operations
AuthLoginURLstr string
// AUTH_LOGIN_SUCCESS_REDIRECT_URL - url to redirect to when the user
// logs in successfuly. if ommited then dont redirect.
AuthLoginSuccessRedirectURLstr string
//------------------------
// FEATURE_FLAGS
// EVENTS_APP - enable sending of app events from various functions
EnableEventsAppBool bool
// enable storage of user_creds in a secret store
EnableUserCredsInSecretsStoreBool bool
// enable sending of emails for any function that needs it
EnableEmailBool bool
// enable login only for users that have confirmed their email
EnableEmailRequireConfirmForLoginBool bool
// enable login only for users that have confirmed their MFA code
EnableMFArequireConfirmForLoginBool bool
//------------------------
}