mirror of
https://github.com/mattermost/mattermost.git
synced 2025-02-25 18:55:24 -06:00
* implement openid connect * update error strings * handle OpenIdSetting.Secret as FAKE SETTING * add openid to telemetry * update config defaults, add telemetry * fix bug with Office365 * Retrieve Office365 AuthData from IdToken * fix linter * add feature flag, reset defaults for config * fix build error * fix unit tests * add authentication permission to Feature Flags * turn off feature flag * set default button color * set default button color only on openid * fix for merging FeatureFlags in config * remove feature flag * revert config changes * remove debug statements Co-authored-by: Mattermod <mattermod@users.noreply.github.com>
56 lines
1.6 KiB
Go
56 lines
1.6 KiB
Go
// Copyright (c) 2015-present Mattermost, Inc. All Rights Reserved.
|
|
// See LICENSE.txt for license information.
|
|
|
|
package model
|
|
|
|
import (
|
|
"encoding/json"
|
|
"io"
|
|
)
|
|
|
|
type SwitchRequest struct {
|
|
CurrentService string `json:"current_service"`
|
|
NewService string `json:"new_service"`
|
|
Email string `json:"email"`
|
|
Password string `json:"password"`
|
|
NewPassword string `json:"new_password"`
|
|
MfaCode string `json:"mfa_code"`
|
|
LdapLoginId string `json:"ldap_id"`
|
|
}
|
|
|
|
func (o *SwitchRequest) ToJson() string {
|
|
b, _ := json.Marshal(o)
|
|
return string(b)
|
|
}
|
|
|
|
func SwitchRequestFromJson(data io.Reader) *SwitchRequest {
|
|
var o *SwitchRequest
|
|
json.NewDecoder(data).Decode(&o)
|
|
return o
|
|
}
|
|
|
|
func (o *SwitchRequest) EmailToOAuth() bool {
|
|
return o.CurrentService == USER_AUTH_SERVICE_EMAIL &&
|
|
(o.NewService == USER_AUTH_SERVICE_SAML ||
|
|
o.NewService == USER_AUTH_SERVICE_GITLAB ||
|
|
o.NewService == SERVICE_GOOGLE ||
|
|
o.NewService == SERVICE_OFFICE365 ||
|
|
o.NewService == SERVICE_OPENID)
|
|
}
|
|
|
|
func (o *SwitchRequest) OAuthToEmail() bool {
|
|
return (o.CurrentService == USER_AUTH_SERVICE_SAML ||
|
|
o.CurrentService == USER_AUTH_SERVICE_GITLAB ||
|
|
o.CurrentService == SERVICE_GOOGLE ||
|
|
o.CurrentService == SERVICE_OFFICE365 ||
|
|
o.CurrentService == SERVICE_OPENID) && o.NewService == USER_AUTH_SERVICE_EMAIL
|
|
}
|
|
|
|
func (o *SwitchRequest) EmailToLdap() bool {
|
|
return o.CurrentService == USER_AUTH_SERVICE_EMAIL && o.NewService == USER_AUTH_SERVICE_LDAP
|
|
}
|
|
|
|
func (o *SwitchRequest) LdapToEmail() bool {
|
|
return o.CurrentService == USER_AUTH_SERVICE_LDAP && o.NewService == USER_AUTH_SERVICE_EMAIL
|
|
}
|