summaryrefslogtreecommitdiffstats
path: root/model/switch_request.go
blob: 1003929440e2cd425e0a01fcfc3a3f794545b8aa (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
54
55
56
57
58
59
60
61
62
// 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"`
	LdapId         string `json:"ldap_id"`
}

func (o *SwitchRequest) ToJson() string {
	b, err := json.Marshal(o)
	if err != nil {
		return ""
	} else {
		return string(b)
	}
}

func SwitchRequestFromJson(data io.Reader) *SwitchRequest {
	decoder := json.NewDecoder(data)
	var o SwitchRequest
	err := decoder.Decode(&o)
	if err == nil {
		return &o
	} else {
		return nil
	}
}

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
}