2022-02-13 23:39:27 +08:00
|
|
|
// Copyright 2021 The Casdoor Authors. All Rights Reserved.
|
2021-02-14 00:22:24 +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 controllers
|
|
|
|
|
2021-08-28 11:13:38 +08:00
|
|
|
import (
|
2021-09-05 09:44:15 +08:00
|
|
|
"fmt"
|
2021-08-28 11:13:38 +08:00
|
|
|
|
2022-03-20 23:21:09 +08:00
|
|
|
"github.com/casdoor/casdoor/conf"
|
2022-10-23 15:16:24 +08:00
|
|
|
"github.com/casdoor/casdoor/i18n"
|
2022-01-20 14:11:46 +08:00
|
|
|
"github.com/casdoor/casdoor/object"
|
|
|
|
"github.com/casdoor/casdoor/util"
|
2021-08-28 11:13:38 +08:00
|
|
|
)
|
|
|
|
|
2022-08-20 21:09:32 +08:00
|
|
|
// ResponseJsonData ...
|
|
|
|
func (c *ApiController) ResponseJsonData(resp *Response, data ...interface{}) {
|
2021-08-08 16:00:19 +08:00
|
|
|
switch len(data) {
|
|
|
|
case 2:
|
|
|
|
resp.Data2 = data[1]
|
|
|
|
fallthrough
|
|
|
|
case 1:
|
|
|
|
resp.Data = data[0]
|
|
|
|
}
|
|
|
|
c.Data["json"] = resp
|
|
|
|
c.ServeJSON()
|
|
|
|
}
|
|
|
|
|
2022-08-20 21:09:32 +08:00
|
|
|
// ResponseOk ...
|
|
|
|
func (c *ApiController) ResponseOk(data ...interface{}) {
|
|
|
|
resp := &Response{Status: "ok"}
|
|
|
|
c.ResponseJsonData(resp, data...)
|
|
|
|
}
|
|
|
|
|
2021-08-07 22:02:56 +08:00
|
|
|
// ResponseError ...
|
2021-07-30 14:15:10 +08:00
|
|
|
func (c *ApiController) ResponseError(error string, data ...interface{}) {
|
2022-08-20 21:09:32 +08:00
|
|
|
resp := &Response{Status: "error", Msg: error}
|
|
|
|
c.ResponseJsonData(resp, data...)
|
2021-05-09 19:54:20 +08:00
|
|
|
}
|
2021-05-17 23:25:28 +08:00
|
|
|
|
2022-10-23 15:16:24 +08:00
|
|
|
func (c *ApiController) T(error string) string {
|
|
|
|
return i18n.Translate(c.GetAcceptLanguage(), error)
|
|
|
|
}
|
|
|
|
|
|
|
|
// GetAcceptLanguage ...
|
|
|
|
func (c *ApiController) GetAcceptLanguage() string {
|
2023-02-18 16:11:23 +08:00
|
|
|
language := c.Ctx.Request.Header.Get("Accept-Language")
|
|
|
|
return conf.GetLanguage(language)
|
2022-10-23 15:16:24 +08:00
|
|
|
}
|
|
|
|
|
2022-07-01 14:53:34 +08:00
|
|
|
// SetTokenErrorHttpStatus ...
|
|
|
|
func (c *ApiController) SetTokenErrorHttpStatus() {
|
|
|
|
_, ok := c.Data["json"].(*object.TokenError)
|
|
|
|
if ok {
|
2022-08-09 16:50:49 +08:00
|
|
|
if c.Data["json"].(*object.TokenError).Error == object.InvalidClient {
|
2022-07-01 14:53:34 +08:00
|
|
|
c.Ctx.Output.SetStatus(401)
|
|
|
|
c.Ctx.Output.Header("WWW-Authenticate", "Basic realm=\"OAuth2\"")
|
|
|
|
} else {
|
|
|
|
c.Ctx.Output.SetStatus(400)
|
|
|
|
}
|
|
|
|
}
|
|
|
|
_, ok = c.Data["json"].(*object.TokenWrapper)
|
|
|
|
if ok {
|
|
|
|
c.Ctx.Output.SetStatus(200)
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2021-08-07 22:02:56 +08:00
|
|
|
// RequireSignedIn ...
|
2021-05-17 23:25:28 +08:00
|
|
|
func (c *ApiController) RequireSignedIn() (string, bool) {
|
2021-07-18 07:15:22 +08:00
|
|
|
userId := c.GetSessionUsername()
|
2021-05-17 23:25:28 +08:00
|
|
|
if userId == "" {
|
2023-01-06 20:12:32 +08:00
|
|
|
c.ResponseError(c.T("general:Please login first"), "Please login first")
|
2021-05-17 23:25:28 +08:00
|
|
|
return "", false
|
|
|
|
}
|
|
|
|
return userId, true
|
|
|
|
}
|
2021-08-28 11:13:38 +08:00
|
|
|
|
2022-09-18 15:43:49 +08:00
|
|
|
// RequireSignedInUser ...
|
|
|
|
func (c *ApiController) RequireSignedInUser() (*object.User, bool) {
|
|
|
|
userId, ok := c.RequireSignedIn()
|
|
|
|
if !ok {
|
|
|
|
return nil, false
|
|
|
|
}
|
|
|
|
|
|
|
|
user := object.GetUser(userId)
|
|
|
|
if user == nil {
|
2022-10-29 20:18:02 +08:00
|
|
|
c.ClearUserSession()
|
2023-01-06 20:12:32 +08:00
|
|
|
c.ResponseError(fmt.Sprintf(c.T("general:The user: %s doesn't exist"), userId))
|
2022-09-18 15:43:49 +08:00
|
|
|
return nil, false
|
|
|
|
}
|
|
|
|
return user, true
|
|
|
|
}
|
|
|
|
|
2022-09-18 16:16:45 +08:00
|
|
|
// RequireAdmin ...
|
|
|
|
func (c *ApiController) RequireAdmin() (string, bool) {
|
|
|
|
user, ok := c.RequireSignedInUser()
|
|
|
|
if !ok {
|
|
|
|
return "", false
|
|
|
|
}
|
|
|
|
|
|
|
|
if user.Owner == "built-in" {
|
|
|
|
return "", true
|
|
|
|
}
|
|
|
|
return user.Owner, true
|
|
|
|
}
|
|
|
|
|
2021-09-05 09:44:15 +08:00
|
|
|
func (c *ApiController) GetProviderFromContext(category string) (*object.Provider, *object.User, bool) {
|
|
|
|
providerName := c.Input().Get("provider")
|
|
|
|
if providerName != "" {
|
2022-11-25 09:36:47 +08:00
|
|
|
provider := object.GetProvider(util.GetId("admin", providerName))
|
2021-09-05 09:44:15 +08:00
|
|
|
if provider == nil {
|
2023-05-01 23:15:51 +08:00
|
|
|
c.ResponseError(fmt.Sprintf(c.T("util:The provider: %s is not found"), providerName))
|
2021-09-05 09:44:15 +08:00
|
|
|
return nil, nil, false
|
|
|
|
}
|
|
|
|
return provider, nil, true
|
|
|
|
}
|
|
|
|
|
|
|
|
userId, ok := c.RequireSignedIn()
|
|
|
|
if !ok {
|
|
|
|
return nil, nil, false
|
|
|
|
}
|
|
|
|
|
|
|
|
application, user := object.GetApplicationByUserId(userId)
|
2021-09-05 10:30:51 +08:00
|
|
|
if application == nil {
|
2022-12-07 13:13:23 +08:00
|
|
|
c.ResponseError(fmt.Sprintf(c.T("util:No application is found for userId: %s"), userId))
|
2021-09-05 10:30:51 +08:00
|
|
|
return nil, nil, false
|
|
|
|
}
|
|
|
|
|
2021-09-05 09:44:15 +08:00
|
|
|
provider := application.GetProviderByCategory(category)
|
|
|
|
if provider == nil {
|
2022-12-07 13:13:23 +08:00
|
|
|
c.ResponseError(fmt.Sprintf(c.T("util:No provider for category: %s is found for application: %s"), category, application.Name))
|
2021-09-05 09:44:15 +08:00
|
|
|
return nil, nil, false
|
|
|
|
}
|
2021-09-05 10:30:51 +08:00
|
|
|
|
2021-09-05 09:44:15 +08:00
|
|
|
return provider, user, true
|
|
|
|
}
|
2022-11-29 11:01:41 +08:00
|
|
|
|
|
|
|
func checkQuotaForApplication(count int) error {
|
|
|
|
quota := conf.GetConfigQuota().Application
|
|
|
|
if quota == -1 {
|
|
|
|
return nil
|
|
|
|
}
|
|
|
|
if count >= quota {
|
|
|
|
return fmt.Errorf("application quota is exceeded")
|
|
|
|
}
|
|
|
|
return nil
|
|
|
|
}
|
|
|
|
|
|
|
|
func checkQuotaForOrganization(count int) error {
|
|
|
|
quota := conf.GetConfigQuota().Organization
|
|
|
|
if quota == -1 {
|
|
|
|
return nil
|
|
|
|
}
|
|
|
|
if count >= quota {
|
|
|
|
return fmt.Errorf("organization quota is exceeded")
|
|
|
|
}
|
|
|
|
return nil
|
|
|
|
}
|
|
|
|
|
|
|
|
func checkQuotaForProvider(count int) error {
|
|
|
|
quota := conf.GetConfigQuota().Provider
|
|
|
|
if quota == -1 {
|
|
|
|
return nil
|
|
|
|
}
|
|
|
|
if count >= quota {
|
|
|
|
return fmt.Errorf("provider quota is exceeded")
|
|
|
|
}
|
|
|
|
return nil
|
|
|
|
}
|
|
|
|
|
|
|
|
func checkQuotaForUser(count int) error {
|
|
|
|
quota := conf.GetConfigQuota().User
|
|
|
|
if quota == -1 {
|
|
|
|
return nil
|
|
|
|
}
|
|
|
|
if count >= quota {
|
|
|
|
return fmt.Errorf("user quota is exceeded")
|
|
|
|
}
|
|
|
|
return nil
|
|
|
|
}
|
2023-03-03 22:15:02 +08:00
|
|
|
|
2023-03-03 22:44:22 +08:00
|
|
|
func getInvalidSmsReceivers(smsForm SmsForm) []string {
|
2023-03-03 22:15:02 +08:00
|
|
|
var invalidReceivers []string
|
|
|
|
for _, receiver := range smsForm.Receivers {
|
|
|
|
// The receiver phone format: E164 like +8613854673829 +441932567890
|
|
|
|
if !util.IsPhoneValid(receiver, "") {
|
|
|
|
invalidReceivers = append(invalidReceivers, receiver)
|
|
|
|
}
|
|
|
|
}
|
|
|
|
return invalidReceivers
|
|
|
|
}
|