* add: generic cache random time offset expired. * bugfix: Csrf token should be Secure and httpOnly, but not now * fix: expose the Offset property to allow external modifications * improving the concurrency performance of random value calculation * add WithOffsetFunc to define private RandomExpireCache.offset field * fix: add seconds definition * build(deps): bump github.com/stretchr/testify from 1.7.1 to 1.8.0 Bumps [github.com/stretchr/testify](https://github.com/stretchr/testify) from 1.7.1 to 1.8.0. - [Release notes](https://github.com/stretchr/testify/releases) - [Commits](https://github.com/stretchr/testify/compare/v1.7.1...v1.8.0) --- updated-dependencies: - dependency-name: github.com/stretchr/testify dependency-type: direct:production update-type: version-update:semver-minor ... Signed-off-by: dependabot[bot] <support@github.com> * fix 4907: force admin service http only * Feat: add get all tasks function (#4999) * feat: add get all tasks function * Refine Comments : admin/profile.go,bean/mock.go,config/global.go... (#5009) * Refine Comments * refine comments for cache.go * refine comments for log.go * Update orm.go * refine comments for orm_log.go,types.go * Update utils.go * Update doc.go * refine comments for for four files (#5011) * refine comments for cache.go * refine comments for log.go * Update orm.go * refine comments for orm_log.go,types.go * Update utils.go * Update doc.go * Update db.go * fix pass []any as any in variadic function by asasalint (#5012) * fix pass []any as any in variadic function * add change log * build(deps): bump go.opentelemetry.io/otel/trace from 1.7.0 to 1.8.0 (#5019) Bumps [go.opentelemetry.io/otel/trace](https://github.com/open-telemetry/opentelemetry-go) from 1.7.0 to 1.8.0. - [Release notes](https://github.com/open-telemetry/opentelemetry-go/releases) - [Changelog](https://github.com/open-telemetry/opentelemetry-go/blob/main/CHANGELOG.md) - [Commits](https://github.com/open-telemetry/opentelemetry-go/compare/v1.7.0...v1.8.0) --- updated-dependencies: - dependency-name: go.opentelemetry.io/otel/trace dependency-type: direct:production update-type: version-update:semver-minor ... Signed-off-by: dependabot[bot] <support@github.com> Co-authored-by: dependabot[bot] <49699333+dependabot[bot]@users.noreply.github.com> * refine comments for package core (#5014) * Refine Comments * refine comments for cache.go * refine comments for log.go * Update orm.go * refine comments for orm_log.go,types.go * Update utils.go * Update doc.go * refine comments * refine comments * Update db.go * refine comments for core * build(deps): bump go.opentelemetry.io/otel/exporters/stdout/stdouttrace (#5018) Bumps [go.opentelemetry.io/otel/exporters/stdout/stdouttrace](https://github.com/open-telemetry/opentelemetry-go) from 1.7.0 to 1.8.0. - [Release notes](https://github.com/open-telemetry/opentelemetry-go/releases) - [Changelog](https://github.com/open-telemetry/opentelemetry-go/blob/main/CHANGELOG.md) - [Commits](https://github.com/open-telemetry/opentelemetry-go/compare/v1.7.0...v1.8.0) --- updated-dependencies: - dependency-name: go.opentelemetry.io/otel/exporters/stdout/stdouttrace dependency-type: direct:production update-type: version-update:semver-minor ... Signed-off-by: dependabot[bot] <support@github.com> Co-authored-by: dependabot[bot] <49699333+dependabot[bot]@users.noreply.github.com> * fix 5022: Miss assiging ln to graceful Server (#5028) * prepare for releasing v2.0.5 (#5032) Co-authored-by: auual <ding@ibyte.me> Co-authored-by: Leon Ding <deen.job@qq.com> Co-authored-by: dada0z <zhang.guangda@qq.com> Co-authored-by: kevinzeng <kevinzeng@zego.im> Co-authored-by: Kevin Tsang <39397413+ktalg@users.noreply.github.com> Co-authored-by: dependabot[bot] <49699333+dependabot[bot]@users.noreply.github.com> Co-authored-by: 日暮颂歌1991 <448081525@qq.com> Co-authored-by: Regan Yue <1131625869@qq.com> Co-authored-by: alingse <alingse@foxmail.com>
261 lines
8.4 KiB
Go
261 lines
8.4 KiB
Go
// Copyright 2014 beego Author. 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 adapter
|
|
|
|
import (
|
|
"net/http"
|
|
|
|
context2 "github.com/beego/beego/v2/adapter/context"
|
|
"github.com/beego/beego/v2/server/web"
|
|
"github.com/beego/beego/v2/server/web/context"
|
|
)
|
|
|
|
// BeeApp is an application instance
|
|
var BeeApp *App
|
|
|
|
func init() {
|
|
// create beego application
|
|
BeeApp = (*App)(web.BeeApp)
|
|
}
|
|
|
|
// App defines beego application with a new PatternServeMux.
|
|
type App web.HttpServer
|
|
|
|
// NewApp returns a new beego application.
|
|
func NewApp() *App {
|
|
return (*App)(web.NewHttpSever())
|
|
}
|
|
|
|
// MiddleWare function for http.Handler
|
|
type MiddleWare web.MiddleWare
|
|
|
|
// Run beego application.
|
|
func (app *App) Run(mws ...MiddleWare) {
|
|
newMws := oldMiddlewareToNew(mws)
|
|
(*web.HttpServer)(app).Run("", newMws...)
|
|
}
|
|
|
|
func oldMiddlewareToNew(mws []MiddleWare) []web.MiddleWare {
|
|
newMws := make([]web.MiddleWare, 0, len(mws))
|
|
for _, old := range mws {
|
|
newMws = append(newMws, (web.MiddleWare)(old))
|
|
}
|
|
return newMws
|
|
}
|
|
|
|
// Router adds a patterned controller handler to BeeApp.
|
|
// it's an alias method of HttpServer.Router.
|
|
// usage:
|
|
// simple router
|
|
// beego.Router("/admin", &admin.UserController{})
|
|
// beego.Router("/admin/index", &admin.ArticleController{})
|
|
//
|
|
// regex router
|
|
//
|
|
// beego.Router("/api/:id([0-9]+)", &controllers.RController{})
|
|
//
|
|
// custom rules
|
|
// beego.Router("/api/list",&RestController{},"*:ListFood")
|
|
// beego.Router("/api/create",&RestController{},"post:CreateFood")
|
|
// beego.Router("/api/update",&RestController{},"put:UpdateFood")
|
|
// beego.Router("/api/delete",&RestController{},"delete:DeleteFood")
|
|
func Router(rootpath string, c ControllerInterface, mappingMethods ...string) *App {
|
|
return (*App)(web.Router(rootpath, c, mappingMethods...))
|
|
}
|
|
|
|
// UnregisterFixedRoute unregisters the route with the specified fixedRoute. It is particularly useful
|
|
// in web applications that inherit most routes from a base webapp via the underscore
|
|
// import, and aim to overwrite only certain paths.
|
|
// The method parameter can be empty or "*" for all HTTP methods, or a particular
|
|
// method type (e.g. "GET" or "POST") for selective removal.
|
|
//
|
|
// Usage (replace "GET" with "*" for all methods):
|
|
// beego.UnregisterFixedRoute("/yourpreviouspath", "GET")
|
|
// beego.Router("/yourpreviouspath", yourControllerAddress, "get:GetNewPage")
|
|
func UnregisterFixedRoute(fixedRoute string, method string) *App {
|
|
return (*App)(web.UnregisterFixedRoute(fixedRoute, method))
|
|
}
|
|
|
|
// Include will generate router file in the router/xxx.go from the controller's comments
|
|
// usage:
|
|
// beego.Include(&BankAccount{}, &OrderController{},&RefundController{},&ReceiptController{})
|
|
// type BankAccount struct{
|
|
// beego.Controller
|
|
// }
|
|
//
|
|
// register the function
|
|
// func (b *BankAccount)Mapping(){
|
|
// b.Mapping("ShowAccount" , b.ShowAccount)
|
|
// b.Mapping("ModifyAccount", b.ModifyAccount)
|
|
// }
|
|
//
|
|
// //@router /account/:id [get]
|
|
// func (b *BankAccount) ShowAccount(){
|
|
// //logic
|
|
// }
|
|
//
|
|
//
|
|
// //@router /account/:id [post]
|
|
// func (b *BankAccount) ModifyAccount(){
|
|
// //logic
|
|
// }
|
|
//
|
|
// the comments @router url methodlist
|
|
// url support all the function Router's pattern
|
|
// methodlist [get post head put delete options *]
|
|
func Include(cList ...ControllerInterface) *App {
|
|
newList := oldToNewCtrlIntfs(cList)
|
|
return (*App)(web.Include(newList...))
|
|
}
|
|
|
|
func oldToNewCtrlIntfs(cList []ControllerInterface) []web.ControllerInterface {
|
|
newList := make([]web.ControllerInterface, 0, len(cList))
|
|
for _, c := range cList {
|
|
newList = append(newList, c)
|
|
}
|
|
return newList
|
|
}
|
|
|
|
// RESTRouter adds a restful controller handler to BeeApp.
|
|
// its' controller implements beego.ControllerInterface and
|
|
// defines a param "pattern/:objectId" to visit each resource.
|
|
func RESTRouter(rootpath string, c ControllerInterface) *App {
|
|
return (*App)(web.RESTRouter(rootpath, c))
|
|
}
|
|
|
|
// AutoRouter adds defined controller handler to BeeApp.
|
|
// it's same to HttpServer.AutoRouter.
|
|
// if beego.AddAuto(&MainController{}) and MainController has methods List and Page,
|
|
// visit the url /main/list to exec List function or /main/page to exec Page function.
|
|
func AutoRouter(c ControllerInterface) *App {
|
|
return (*App)(web.AutoRouter(c))
|
|
}
|
|
|
|
// AutoPrefix adds controller handler to BeeApp with prefix.
|
|
// it's same to HttpServer.AutoRouterWithPrefix.
|
|
// if beego.AutoPrefix("/admin",&MainController{}) and MainController has methods List and Page,
|
|
// visit the url /admin/main/list to exec List function or /admin/main/page to exec Page function.
|
|
func AutoPrefix(prefix string, c ControllerInterface) *App {
|
|
return (*App)(web.AutoPrefix(prefix, c))
|
|
}
|
|
|
|
// Get used to register router for Get method
|
|
// usage:
|
|
// beego.Get("/", func(ctx *context.Context){
|
|
// ctx.Output.Body("hello world")
|
|
// })
|
|
func Get(rootpath string, f FilterFunc) *App {
|
|
return (*App)(web.Get(rootpath, func(ctx *context.Context) {
|
|
f((*context2.Context)(ctx))
|
|
}))
|
|
}
|
|
|
|
// Post used to register router for Post method
|
|
// usage:
|
|
// beego.Post("/api", func(ctx *context.Context){
|
|
// ctx.Output.Body("hello world")
|
|
// })
|
|
func Post(rootpath string, f FilterFunc) *App {
|
|
return (*App)(web.Post(rootpath, func(ctx *context.Context) {
|
|
f((*context2.Context)(ctx))
|
|
}))
|
|
}
|
|
|
|
// Delete used to register router for Delete method
|
|
// usage:
|
|
// beego.Delete("/api", func(ctx *context.Context){
|
|
// ctx.Output.Body("hello world")
|
|
// })
|
|
func Delete(rootpath string, f FilterFunc) *App {
|
|
return (*App)(web.Delete(rootpath, func(ctx *context.Context) {
|
|
f((*context2.Context)(ctx))
|
|
}))
|
|
}
|
|
|
|
// Put used to register router for Put method
|
|
// usage:
|
|
// beego.Put("/api", func(ctx *context.Context){
|
|
// ctx.Output.Body("hello world")
|
|
// })
|
|
func Put(rootpath string, f FilterFunc) *App {
|
|
return (*App)(web.Put(rootpath, func(ctx *context.Context) {
|
|
f((*context2.Context)(ctx))
|
|
}))
|
|
}
|
|
|
|
// Head used to register router for Head method
|
|
// usage:
|
|
// beego.Head("/api", func(ctx *context.Context){
|
|
// ctx.Output.Body("hello world")
|
|
// })
|
|
func Head(rootpath string, f FilterFunc) *App {
|
|
return (*App)(web.Head(rootpath, func(ctx *context.Context) {
|
|
f((*context2.Context)(ctx))
|
|
}))
|
|
}
|
|
|
|
// Options used to register router for Options method
|
|
// usage:
|
|
// beego.Options("/api", func(ctx *context.Context){
|
|
// ctx.Output.Body("hello world")
|
|
// })
|
|
func Options(rootpath string, f FilterFunc) *App {
|
|
return (*App)(web.Options(rootpath, func(ctx *context.Context) {
|
|
f((*context2.Context)(ctx))
|
|
}))
|
|
}
|
|
|
|
// Patch used to register router for Patch method
|
|
// usage:
|
|
// beego.Patch("/api", func(ctx *context.Context){
|
|
// ctx.Output.Body("hello world")
|
|
// })
|
|
func Patch(rootpath string, f FilterFunc) *App {
|
|
return (*App)(web.Patch(rootpath, func(ctx *context.Context) {
|
|
f((*context2.Context)(ctx))
|
|
}))
|
|
}
|
|
|
|
// Any used to register router for all methods
|
|
// usage:
|
|
// beego.Any("/api", func(ctx *context.Context){
|
|
// ctx.Output.Body("hello world")
|
|
// })
|
|
func Any(rootpath string, f FilterFunc) *App {
|
|
return (*App)(web.Any(rootpath, func(ctx *context.Context) {
|
|
f((*context2.Context)(ctx))
|
|
}))
|
|
}
|
|
|
|
// Handler used to register a Handler router
|
|
// usage:
|
|
// beego.Handler("/api", http.HandlerFunc(func (w http.ResponseWriter, r *http.Request) {
|
|
// fmt.Fprintf(w, "Hello, %q", html.EscapeString(r.URL.Path))
|
|
// }))
|
|
func Handler(rootpath string, h http.Handler, options ...interface{}) *App {
|
|
return (*App)(web.Handler(rootpath, h, options...))
|
|
}
|
|
|
|
// InsertFilter adds a FilterFunc with pattern condition and action constant.
|
|
// The pos means action constant including
|
|
// beego.BeforeStatic, beego.BeforeRouter, beego.BeforeExec, beego.AfterExec and beego.FinishRouter.
|
|
// The bool params is for setting the returnOnOutput value (false allows multiple filters to execute)
|
|
func InsertFilter(pattern string, pos int, filter FilterFunc, params ...bool) *App {
|
|
opts := oldToNewFilterOpts(params)
|
|
return (*App)(web.InsertFilter(pattern, pos, func(ctx *context.Context) {
|
|
filter((*context2.Context)(ctx))
|
|
}, opts...))
|
|
}
|