summaryrefslogtreecommitdiffstats
path: root/model/switch_request.go
blob: 2a522f4924f9e79fd970a3baebc4ac01be7ffa1d (plain)
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
// Copyright (c) 2017-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)
}

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.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
}