1
0
mirror of https://github.com/beego/bee.git synced 2024-11-23 01:30:55 +00:00

policies implementation

This commit is contained in:
olegdemchenko 2016-09-28 21:21:50 +03:00
parent f7d2e04e07
commit 5dd70f1e44
3 changed files with 138 additions and 0 deletions

View File

@ -149,6 +149,9 @@ func generateDocs(curpath string) {
Name: strings.Trim(s, "/"), Name: strings.Trim(s, "/"),
Description: v, Description: v,
}) })
if policy := policyList[controllerName]; policy != nil {
policyPathList[version+s] = policy
}
} }
} }
} }
@ -189,6 +192,8 @@ func generateDocs(curpath string) {
if err != nil || erryml != nil { if err != nil || erryml != nil {
panic(err) panic(err)
} }
generatePolicies(curpath)
} }
// return version and the others params // return version and the others params
@ -321,6 +326,7 @@ func analisyscontrollerPkg(localName, pkgpath string) {
//parse controller definition comments //parse controller definition comments
if strings.TrimSpace(specDecl.Doc.Text()) != "" { if strings.TrimSpace(specDecl.Doc.Text()) != "" {
controllerComments[pkgpath+s.(*ast.TypeSpec).Name.String()] = specDecl.Doc.Text() controllerComments[pkgpath+s.(*ast.TypeSpec).Name.String()] = specDecl.Doc.Text()
controllerFindPolicies(specDecl.Doc, s.(*ast.TypeSpec).Name.Name, pkgpath)
} }
} }
} }
@ -368,6 +374,7 @@ func parserComments(comments *ast.CommentGroup, funcName, controllerName, pkgpat
opts := swagger.Operation{ opts := swagger.Operation{
Responses: make(map[string]swagger.Response), Responses: make(map[string]swagger.Response),
} }
policy := Policy{}
if comments != nil && comments.List != nil { if comments != nil && comments.List != nil {
for _, c := range comments.List { for _, c := range comments.List {
t := strings.TrimSpace(strings.TrimLeft(c.Text, "//")) t := strings.TrimSpace(strings.TrimLeft(c.Text, "//"))
@ -543,6 +550,11 @@ func parserComments(comments *ast.CommentGroup, funcName, controllerName, pkgpat
opts.Produces = append(opts.Produces, ahtml) opts.Produces = append(opts.Produces, ahtml)
} }
} }
} else if strings.HasPrefix(t, "@policy") {
policyFields := strings.FieldsFunc(t[len("@policy"):], func(c rune) bool {return !unicode.IsLetter(c) && !unicode.IsNumber(c) && c!='_'})
for _, val := range policyFields {
policy.Policies = append(policy.Policies, val)
}
} }
} }
} }
@ -575,6 +587,27 @@ func parserComments(comments *ast.CommentGroup, funcName, controllerName, pkgpat
item.Options = &opts item.Options = &opts
} }
controllerList[pkgpath+controllerName][routerPath] = item controllerList[pkgpath+controllerName][routerPath] = item
if len(policy.Policies) > 0 {
policy.Method = strings.ToLower(HTTPMethod)
if i := strings.Index(routerPath, ":"); i < 0 {
policy.Path = routerPath
} else {
policy.Path = routerPath[:i]
}
policyMethods := policyList[pkgpath+controllerName]
if policyMethods == nil {
policyMethods = make(map[string]*Policy)
policyList[pkgpath+controllerName] = policyMethods
}
if pm := policyMethods[policy.Method]; pm != nil {
for _, curPolicy := range policy.Policies {
pm.Policies = append(pm.Policies, curPolicy)
}
} else {
policyMethods[policy.Method] = &policy
}
}
} }
return nil return nil
} }

104
g_policies.go Normal file
View File

@ -0,0 +1,104 @@
// Copyright 2016 bee 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 main
import (
"bytes"
"go/ast"
"os"
"path"
"strings"
"text/template"
"unicode"
)
type Policy struct {
Method string
Path string
Policies []string
}
var (
policyList = make(map[string]map[string]*Policy) //controllername -> method -> policy
policyPathList = make(map[string]map[string]*Policy) //path -> method -> policy
)
func controllerFindPolicies(comments *ast.CommentGroup, controllerName, pkgpath string) {
if comments == nil || comments.List == nil {
return
}
for _, c := range comments.List {
t := strings.TrimSpace(strings.TrimLeft(c.Text, "//"))
if strings.HasPrefix(t, "@policy") {
policy := Policy{
Method: "*",
}
policyFields := strings.FieldsFunc(t[len("@policy"):], func(c rune) bool { return !unicode.IsLetter(c) && !unicode.IsNumber(c) && c != '_' })
for _, val := range policyFields {
policy.Policies = append(policy.Policies, val)
}
policyMethods := policyList[pkgpath+controllerName]
if policyMethods == nil {
policyMethods = make(map[string]*Policy)
policyList[pkgpath+controllerName] = policyMethods
}
if pm := policyMethods[policy.Method]; pm != nil {
for _, curPolicy := range policy.Policies {
pm.Policies = append(pm.Policies, curPolicy)
}
} else {
policyMethods[policy.Method] = &policy
}
}
}
}
func generatePolicies(curpath string) {
fn := template.FuncMap{
"join": strings.Join,
}
tmpl, err := template.New("policy template").Funcs(fn).Parse(policyTpl)
if err != nil {
panic("Can't parse policy template: " + err.Error())
}
var buf bytes.Buffer
err = tmpl.Execute(&buf, policyPathList)
if err != nil {
panic("Can't execute policy template: " + err.Error())
}
policyFile, err := os.Create(path.Join(curpath, "policies", "policies_autogen.go"))
if err != nil {
panic(err)
}
defer policyFile.Close()
_, err = policyFile.Write(buf.Bytes())
if err != nil {
panic(err)
}
}
var policyTpl = `// This file was auto-generated by bee tools, do not change it!
package policies
import "github.com/astaxie/beego"
func init() {
{{ range $path, $policyList := . }}{{ range $, $policy := $policyList }} beego.Policy("{{$path}}{{$policy.Path}}", "{{$policy.Method}}", {{ join $policy.Policies ", " }})
{{ end }}{{ end }}
}
`

View File

@ -253,6 +253,7 @@ var ignoredFilesRegExps = []string{
`.(\w+).go.swp`, `.(\w+).go.swp`,
`(\w+).go~`, `(\w+).go~`,
`(\w+).tmp`, `(\w+).tmp`,
`policies_autogen.go`,
} }
// checkIfWatchExt returns true if the name HasSuffix <watch_ext>. // checkIfWatchExt returns true if the name HasSuffix <watch_ext>.