File: C:/github_repos/casibase_customer_0058/controllers/base.go
// Copyright 2023 The Casibase Authors. All Rights Reserved.
//
// 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
import (
"encoding/gob"
"encoding/json"
"strings"
"time"
"github.com/beego/beego"
"github.com/beego/beego/logs"
"github.com/casdoor/casdoor-go-sdk/casdoorsdk"
"github.com/casibase/casibase/object"
)
type ApiController struct {
beego.Controller
}
func init() {
gob.Register(casdoorsdk.Claims{})
}
func GetUserName(user *casdoorsdk.User) string {
if user == nil {
return ""
}
return user.Name
}
func (c *ApiController) GetSessionClaims() *casdoorsdk.Claims {
s := c.GetSession("user")
if s == nil {
return nil
}
claims := s.(casdoorsdk.Claims)
return &claims
}
func (c *ApiController) SetSessionClaims(claims *casdoorsdk.Claims) {
if claims == nil {
c.DelSession("user")
return
}
c.SetSession("user", *claims)
}
func (c *ApiController) GetSessionUser() *casdoorsdk.User {
claims := c.GetSessionClaims()
if claims == nil {
return nil
}
return &claims.User
}
func (c *ApiController) SetSessionUser(user *casdoorsdk.User) {
if user == nil {
c.DelSession("user")
return
}
claims := c.GetSessionClaims()
if claims != nil {
claims.User = *user
c.SetSessionClaims(claims)
}
}
func (c *ApiController) GetSessionUsername() string {
user := c.GetSessionUser()
if user == nil {
return ""
}
return GetUserName(user)
}
func wrapActionResponse(affected bool, e ...error) *Response {
if len(e) != 0 && e[0] != nil {
return &Response{Status: "error", Msg: e[0].Error()}
} else if affected {
return &Response{Status: "ok", Msg: "", Data: "Affected"}
} else {
return &Response{Status: "ok", Msg: "", Data: "Unaffected"}
}
}
func wrapActionResponse2(affected bool, data interface{}, e ...error) *Response {
if len(e) != 0 && e[0] != nil {
return &Response{Status: "error", Msg: e[0].Error()}
} else if affected {
return &Response{Status: "ok", Msg: "", Data: "Affected", Data2: data}
} else {
return &Response{Status: "ok", Msg: "", Data: "Unaffected", Data2: data}
}
}
func (c *ApiController) Finish() {
if strings.HasPrefix(c.Ctx.Input.URL(), "/api") {
startTime := c.Ctx.Input.GetData("startTime")
if startTime != nil {
latency := time.Since(startTime.(time.Time)).Milliseconds()
object.ApiLatency.WithLabelValues(c.Ctx.Input.URL(), c.Ctx.Input.Method()).Observe(float64(latency))
}
}
c.errorLogFilter()
c.Controller.Finish()
}
func (c *ApiController) errorLogFilter() {
if v, ok := c.Data["json"]; ok {
var status string
switch r := v.(type) {
case Response:
status = r.Status
case *Response:
if r != nil {
status = r.Status
}
default:
status = ""
}
if status == "error" {
method := c.Ctx.Input.Method()
path := c.Ctx.Input.URL()
query := ""
if c.Ctx.Request != nil && c.Ctx.Request.URL != nil {
query = c.Ctx.Request.URL.RawQuery
}
body := string(c.Ctx.Input.RequestBody)
if len(body) > 4096 {
body = body[:4096] + "...(truncated)"
}
token := c.Ctx.Request.Header.Get("Authorization")
respJSON, _ := json.Marshal(v)
respStr := string(respJSON)
if len(respStr) > 4096 {
respStr = respStr[:4096] + "...(truncated)"
}
logs.Error("API error: method=%s path=%s query=%s token=%s body=%s response=%s", method, path, query, token, body, respStr)
}
}
}