2021-03-13 23:06:03 +08:00
|
|
|
// Copyright 2021 The casbin Authors. All Rights Reserved.
|
2020-12-20 23:24:09 +08:00
|
|
|
//
|
|
|
|
// Licensed under the Apache License, Version 2.0 (the "License");
|
|
|
|
// you may not use this file except in compliance with the License.
|
|
|
|
// You may obtain a copy of the License at
|
|
|
|
//
|
|
|
|
// http://www.apache.org/licenses/LICENSE-2.0
|
|
|
|
//
|
|
|
|
// Unless required by applicable law or agreed to in writing, software
|
|
|
|
// distributed under the License is distributed on an "AS IS" BASIS,
|
|
|
|
// WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
|
|
|
|
// See the License for the specific language governing permissions and
|
|
|
|
// limitations under the License.
|
|
|
|
|
|
|
|
package object
|
|
|
|
|
|
|
|
import (
|
|
|
|
"github.com/casdoor/casdoor/util"
|
|
|
|
"xorm.io/core"
|
|
|
|
)
|
|
|
|
|
|
|
|
type Application struct {
|
|
|
|
Owner string `xorm:"varchar(100) notnull pk" json:"owner"`
|
|
|
|
Name string `xorm:"varchar(100) notnull pk" json:"name"`
|
|
|
|
CreatedTime string `xorm:"varchar(100)" json:"createdTime"`
|
|
|
|
|
2021-04-29 21:28:24 +08:00
|
|
|
DisplayName string `xorm:"varchar(100)" json:"displayName"`
|
|
|
|
Logo string `xorm:"varchar(100)" json:"logo"`
|
|
|
|
HomepageUrl string `xorm:"varchar(100)" json:"homepageUrl"`
|
|
|
|
Description string `xorm:"varchar(100)" json:"description"`
|
|
|
|
Organization string `xorm:"varchar(100)" json:"organization"`
|
|
|
|
EnablePassword bool `json:"enablePassword"`
|
|
|
|
EnableSignUp bool `json:"enableSignUp"`
|
2021-05-01 22:27:20 +08:00
|
|
|
Providers []string `xorm:"varchar(1000)" json:"providers"`
|
2021-04-29 21:28:24 +08:00
|
|
|
ProviderObjs []*Provider `xorm:"-" json:"providerObjs"`
|
|
|
|
OrganizationObj *Organization `xorm:"-" json:"organizationObj"`
|
2021-03-06 16:39:17 +08:00
|
|
|
|
2021-05-24 21:27:00 +08:00
|
|
|
ClientId string `xorm:"varchar(100)" json:"clientId"`
|
|
|
|
ClientSecret string `xorm:"varchar(100)" json:"clientSecret"`
|
|
|
|
RedirectUris []string `xorm:"varchar(1000)" json:"redirectUris"`
|
|
|
|
ExpireInHours int `json:"expireInHours"`
|
|
|
|
SignupUrl string `xorm:"varchar(100)" json:"signupUrl"`
|
|
|
|
ForgetUrl string `xorm:"varchar(100)" json:"forgetUrl"`
|
|
|
|
AffiliationUrl string `xorm:"varchar(100)" json:"affiliationUrl"`
|
2020-12-20 23:24:09 +08:00
|
|
|
}
|
|
|
|
|
|
|
|
func GetApplications(owner string) []*Application {
|
|
|
|
applications := []*Application{}
|
2021-05-02 10:30:12 +08:00
|
|
|
err := adapter.Engine.Desc("created_time").Find(&applications, &Application{Owner: owner})
|
2020-12-20 23:24:09 +08:00
|
|
|
if err != nil {
|
|
|
|
panic(err)
|
|
|
|
}
|
|
|
|
|
|
|
|
return applications
|
|
|
|
}
|
|
|
|
|
2021-04-29 21:28:24 +08:00
|
|
|
func extendApplicationWithProviders(application *Application) {
|
2021-03-20 11:34:04 +08:00
|
|
|
providers := GetProviders(application.Owner)
|
|
|
|
m := map[string]*Provider{}
|
|
|
|
for _, provider := range providers {
|
2021-05-23 23:38:38 +08:00
|
|
|
if provider.Category != "OAuth" {
|
|
|
|
continue
|
|
|
|
}
|
|
|
|
|
2021-03-20 11:34:04 +08:00
|
|
|
provider.ClientSecret = ""
|
|
|
|
provider.ProviderUrl = ""
|
|
|
|
m[provider.Name] = provider
|
|
|
|
}
|
|
|
|
|
|
|
|
application.ProviderObjs = []*Provider{}
|
|
|
|
for _, providerName := range application.Providers {
|
2021-05-24 01:02:38 +08:00
|
|
|
if provider, ok := m[providerName]; ok {
|
|
|
|
application.ProviderObjs = append(application.ProviderObjs, provider)
|
|
|
|
}
|
2021-03-20 11:34:04 +08:00
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2021-04-29 21:28:24 +08:00
|
|
|
func extendApplicationWithOrg(application *Application) {
|
|
|
|
organization := getOrganization(application.Owner, application.Organization)
|
|
|
|
application.OrganizationObj = organization
|
|
|
|
}
|
|
|
|
|
2020-12-20 23:24:09 +08:00
|
|
|
func getApplication(owner string, name string) *Application {
|
|
|
|
application := Application{Owner: owner, Name: name}
|
2021-05-02 10:30:12 +08:00
|
|
|
existed, err := adapter.Engine.Get(&application)
|
2020-12-20 23:24:09 +08:00
|
|
|
if err != nil {
|
|
|
|
panic(err)
|
|
|
|
}
|
|
|
|
|
|
|
|
if existed {
|
2021-04-29 21:28:24 +08:00
|
|
|
extendApplicationWithProviders(&application)
|
|
|
|
extendApplicationWithOrg(&application)
|
2020-12-20 23:24:09 +08:00
|
|
|
return &application
|
|
|
|
} else {
|
|
|
|
return nil
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2021-05-24 01:02:38 +08:00
|
|
|
func GetApplicationByOrganizationName(organization string) *Application {
|
2021-05-16 23:07:45 +08:00
|
|
|
application := Application{}
|
|
|
|
existed, err := adapter.Engine.Where("organization=?", organization).Get(&application)
|
2021-04-19 01:14:41 +08:00
|
|
|
if err != nil {
|
|
|
|
panic(err)
|
|
|
|
}
|
|
|
|
|
|
|
|
if existed {
|
2021-04-29 21:28:24 +08:00
|
|
|
extendApplicationWithProviders(&application)
|
|
|
|
extendApplicationWithOrg(&application)
|
2021-04-19 01:14:41 +08:00
|
|
|
return &application
|
|
|
|
} else {
|
|
|
|
return nil
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2021-05-16 23:07:45 +08:00
|
|
|
func GetApplicationByUser(user *User) *Application {
|
2021-05-24 01:02:38 +08:00
|
|
|
return GetApplicationByOrganizationName(user.Owner)
|
2021-05-16 23:07:45 +08:00
|
|
|
}
|
|
|
|
|
2021-06-06 17:27:03 +08:00
|
|
|
func GetApplicationByClientId(clientId string) *Application {
|
2021-03-14 18:18:03 +08:00
|
|
|
application := Application{}
|
2021-05-02 10:30:12 +08:00
|
|
|
existed, err := adapter.Engine.Where("client_id=?", clientId).Get(&application)
|
2021-03-14 18:18:03 +08:00
|
|
|
if err != nil {
|
|
|
|
panic(err)
|
|
|
|
}
|
|
|
|
|
|
|
|
if existed {
|
2021-04-29 21:28:24 +08:00
|
|
|
extendApplicationWithProviders(&application)
|
|
|
|
extendApplicationWithOrg(&application)
|
2021-03-14 18:18:03 +08:00
|
|
|
return &application
|
|
|
|
} else {
|
|
|
|
return nil
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2020-12-20 23:24:09 +08:00
|
|
|
func GetApplication(id string) *Application {
|
|
|
|
owner, name := util.GetOwnerAndNameFromId(id)
|
|
|
|
return getApplication(owner, name)
|
|
|
|
}
|
|
|
|
|
|
|
|
func UpdateApplication(id string, application *Application) bool {
|
|
|
|
owner, name := util.GetOwnerAndNameFromId(id)
|
|
|
|
if getApplication(owner, name) == nil {
|
|
|
|
return false
|
|
|
|
}
|
|
|
|
|
2021-05-02 10:30:12 +08:00
|
|
|
affected, err := adapter.Engine.ID(core.PK{owner, name}).AllCols().Update(application)
|
2020-12-20 23:24:09 +08:00
|
|
|
if err != nil {
|
|
|
|
panic(err)
|
|
|
|
}
|
|
|
|
|
2021-03-28 00:48:34 +08:00
|
|
|
return affected != 0
|
2020-12-20 23:24:09 +08:00
|
|
|
}
|
|
|
|
|
|
|
|
func AddApplication(application *Application) bool {
|
2021-03-06 16:39:17 +08:00
|
|
|
application.ClientId = util.GenerateClientId()
|
|
|
|
application.ClientSecret = util.GenerateClientSecret()
|
|
|
|
|
2021-05-02 10:30:12 +08:00
|
|
|
affected, err := adapter.Engine.Insert(application)
|
2020-12-20 23:24:09 +08:00
|
|
|
if err != nil {
|
|
|
|
panic(err)
|
|
|
|
}
|
|
|
|
|
|
|
|
return affected != 0
|
|
|
|
}
|
|
|
|
|
|
|
|
func DeleteApplication(application *Application) bool {
|
2021-05-02 10:30:12 +08:00
|
|
|
affected, err := adapter.Engine.ID(core.PK{application.Owner, application.Name}).Delete(&Application{})
|
2020-12-20 23:24:09 +08:00
|
|
|
if err != nil {
|
|
|
|
panic(err)
|
|
|
|
}
|
|
|
|
|
|
|
|
return affected != 0
|
|
|
|
}
|
2021-05-24 01:02:38 +08:00
|
|
|
|
|
|
|
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")
|
|
|
|
}
|