Add sms and email providers to app.

This commit is contained in:
Yang Luo
2021-05-24 01:02:38 +08:00
parent bd888fad38
commit dbf11d61a7
6 changed files with 64 additions and 51 deletions

View File

@ -68,7 +68,9 @@ func extendApplicationWithProviders(application *Application) {
application.ProviderObjs = []*Provider{}
for _, providerName := range application.Providers {
application.ProviderObjs = append(application.ProviderObjs, m[providerName])
if provider, ok := m[providerName]; ok {
application.ProviderObjs = append(application.ProviderObjs, provider)
}
}
}
@ -93,7 +95,7 @@ func getApplication(owner string, name string) *Application {
}
}
func getApplicationByOrganization(organization string) *Application {
func GetApplicationByOrganizationName(organization string) *Application {
application := Application{}
existed, err := adapter.Engine.Where("organization=?", organization).Get(&application)
if err != nil {
@ -110,7 +112,7 @@ func getApplicationByOrganization(organization string) *Application {
}
func GetApplicationByUser(user *User) *Application {
return getApplicationByOrganization(user.Owner)
return GetApplicationByOrganizationName(user.Owner)
}
func getApplicationByClientId(clientId string) *Application {
@ -168,3 +170,31 @@ func DeleteApplication(application *Application) bool {
return affected != 0
}
func (application *Application) getProviderByCategory(category string) *Provider {
providers := GetProviders(application.Owner)
m := map[string]*Provider{}
for _, provider := range providers {
if provider.Category != category {
continue
}
m[provider.Name] = provider
}
for _, providerName := range application.Providers {
if provider, ok := m[providerName]; ok {
return provider
}
}
return nil
}
func (application *Application) GetEmailProvider() *Provider {
return application.getProviderByCategory("Email")
}
func (application *Application) GetSmsProvider() *Provider {
return application.getProviderByCategory("SMS")
}

View File

@ -18,11 +18,7 @@ package object
import "github.com/go-gomail/gomail"
func SendEmail(title, content, dest, sender string) (string, error) {
provider := getDefaultEmailProvider()
if provider == nil {
return "Please set an Email provider first", nil
}
func SendEmail(provider *Provider, title, content, dest, sender string) (string, error) {
dialer := gomail.NewDialer(provider.Host, provider.Port, provider.ClientId, provider.ClientSecret)
message := gomail.NewMessage()

View File

@ -70,32 +70,6 @@ func GetProvider(id string) *Provider {
return getProvider(owner, name)
}
func getDefaultEmailProvider() *Provider {
provider := Provider{Owner: "admin", Category: "Email"}
existed, err := adapter.Engine.Get(&provider)
if err != nil {
panic(err)
}
if !existed {
return nil
}
return &provider
}
func getDefaultPhoneProvider() *Provider {
provider := Provider{Owner: "admin", Category: "SMS"}
existed, err := adapter.Engine.Get(&provider)
if err != nil {
panic(err)
}
if !existed {
return nil
}
return &provider
}
func GetDefaultHumanCheckProvider() *Provider {
provider := Provider{Owner: "admin", Category: "HumanCheck"}
existed, err := adapter.Engine.Get(&provider)

View File

@ -20,11 +20,7 @@ import (
"github.com/casdoor/go-sms-sender"
)
func SendCodeToPhone(phone, code string) string {
provider := getDefaultPhoneProvider()
if provider == nil {
return "Please set an phone provider first"
}
func SendCodeToPhone(provider *Provider, phone, code string) string {
client := go_sms_sender.NewSmsClient(provider.Type, provider.ClientId, provider.ClientSecret, provider.SignName, provider.RegionId, provider.TemplateCode, provider.AppId)
if client == nil {
return fmt.Sprintf("Unsupported provide type: %s", provider.Type)

View File

@ -26,23 +26,28 @@ import (
type VerificationRecord struct {
RemoteAddr string `xorm:"varchar(100) notnull pk"`
Type string `xorm:"varchar(10) notnull pk"`
Provider string `xorm:"varchar(100) notnull"`
Receiver string `xorm:"varchar(100) notnull"`
Code string `xorm:"varchar(10) notnull"`
Time int64 `xorm:"notnull"`
IsUsed bool
}
func SendVerificationCodeToEmail(remoteAddr, dest string) string {
func SendVerificationCodeToEmail(provider *Provider, remoteAddr string, dest string) string {
if provider == nil {
return "Please set an Email provider first"
}
title := "Casdoor Verification Code"
sender := "Casdoor"
code := getRandomCode(5)
content := fmt.Sprintf("You have requested a verification code at Casdoor. Here is your code: %s, please enter in 5 minutes.", code)
if result := AddToVerificationRecord(remoteAddr, "email", dest, code); len(result) != 0 {
if result := AddToVerificationRecord(provider.Name, remoteAddr, "Email", dest, code); len(result) != 0 {
return result
}
msg, err := SendEmail(title, content, dest, sender)
msg, err := SendEmail(provider, title, content, dest, sender)
if msg != "" {
return msg
}
@ -53,19 +58,24 @@ func SendVerificationCodeToEmail(remoteAddr, dest string) string {
return ""
}
func SendVerificationCodeToPhone(remoteAddr, dest string) string {
func SendVerificationCodeToPhone(provider *Provider, remoteAddr string, dest string) string {
if provider == nil {
return "Please set a SMS provider first"
}
code := getRandomCode(5)
if result := AddToVerificationRecord(remoteAddr, "phone", dest, code); len(result) != 0 {
if result := AddToVerificationRecord(provider.Name, remoteAddr, "SMS", dest, code); len(result) != 0 {
return result
}
return SendCodeToPhone(dest, code)
return SendCodeToPhone(provider, dest, code)
}
func AddToVerificationRecord(remoteAddr, recordType, dest, code string) string {
func AddToVerificationRecord(providerName, remoteAddr, recordType, dest, code string) string {
var record VerificationRecord
record.RemoteAddr = remoteAddr
record.Type = recordType
record.Provider = providerName
has, err := adapter.Engine.Get(&record)
if err != nil {
panic(err)
@ -73,7 +83,7 @@ func AddToVerificationRecord(remoteAddr, recordType, dest, code string) string {
now := time.Now().Unix()
if has && now - record.Time < 60 {
if has && now-record.Time < 60 {
return "You can only send one code in 60s."
}