Skip to content
Projects
Groups
Snippets
Help
Loading...
Sign in
Toggle navigation
B
beego
Project
Project
Details
Activity
Cycle Analytics
Repository
Repository
Files
Commits
Branches
Tags
Contributors
Graph
Compare
Charts
Issues
0
Issues
0
List
Board
Labels
Milestones
Merge Requests
0
Merge Requests
0
Wiki
Wiki
Snippets
Snippets
Members
Members
Collapse sidebar
Close sidebar
Activity
Graph
Charts
Create a new issue
Commits
Issue Boards
Open sidebar
go
beego
Commits
0be05eb4
Commit
0be05eb4
authored
Sep 28, 2016
by
olegdemchenko
Browse files
Options
Browse Files
Download
Email Patches
Plain Diff
policies implementation
parent
2d87d4fe
Hide whitespace changes
Inline
Side-by-side
Showing
2 changed files
with
106 additions
and
1 deletion
+106
-1
policy.go
policy.go
+97
-0
router.go
router.go
+9
-1
No files found.
policy.go
0 → 100644
View file @
0be05eb4
// Copyright 2016 beego 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
beego
import
(
"strings"
"github.com/astaxie/beego/context"
)
// PolicyFunc defines a policy function which is invoked before the controller handler is executed.
type
PolicyFunc
func
(
*
context
.
Context
)
// FindRouter Find Router info for URL
func
(
p
*
ControllerRegister
)
FindPolicy
(
cont
*
context
.
Context
)
[]
PolicyFunc
{
var
urlPath
=
cont
.
Input
.
URL
()
if
!
BConfig
.
RouterCaseSensitive
{
urlPath
=
strings
.
ToLower
(
urlPath
)
}
httpMethod
:=
cont
.
Input
.
Method
()
isWildcard
:=
false
// Find policy for current method
t
,
ok
:=
p
.
policies
[
httpMethod
]
// If not found - find policy for whole controller
if
!
ok
{
t
,
ok
=
p
.
policies
[
"*"
]
isWildcard
=
true
}
if
ok
{
runObjects
:=
t
.
Match
(
urlPath
,
cont
)
if
r
,
ok
:=
runObjects
.
([]
PolicyFunc
);
ok
{
return
r
}
else
if
!
isWildcard
{
// If no policies found and we checked not for "*" method - try to find it
t
,
ok
=
p
.
policies
[
"*"
]
if
ok
{
runObjects
=
t
.
Match
(
urlPath
,
cont
)
if
r
,
ok
=
runObjects
.
([]
PolicyFunc
);
ok
{
return
r
}
}
}
}
return
nil
}
func
(
p
*
ControllerRegister
)
addToPolicy
(
method
,
pattern
string
,
r
...
PolicyFunc
)
{
method
=
strings
.
ToUpper
(
method
)
p
.
enablePolicy
=
true
if
!
BConfig
.
RouterCaseSensitive
{
pattern
=
strings
.
ToLower
(
pattern
)
}
if
t
,
ok
:=
p
.
policies
[
method
];
ok
{
t
.
AddRouter
(
pattern
,
r
)
}
else
{
t
:=
NewTree
()
t
.
AddRouter
(
pattern
,
r
)
p
.
policies
[
method
]
=
t
}
}
// Register new policy in beego
func
Policy
(
pattern
,
method
string
,
policy
...
PolicyFunc
)
{
BeeApp
.
Handlers
.
addToPolicy
(
method
,
pattern
,
policy
...
)
}
// Find policies and execute if were found
func
(
p
*
ControllerRegister
)
execPolicy
(
cont
*
context
.
Context
,
urlPath
string
)
(
started
bool
)
{
if
!
p
.
enablePolicy
{
return
false
}
// Find Policy for method
policyList
:=
p
.
FindPolicy
(
cont
)
if
len
(
policyList
)
>
0
{
// Run policies
for
_
,
runPolicy
:=
range
policyList
{
runPolicy
(
cont
)
if
cont
.
ResponseWriter
.
Started
{
return
true
}
}
return
false
}
return
false
}
router.go
View file @
0be05eb4
...
@@ -114,6 +114,8 @@ type controllerInfo struct {
...
@@ -114,6 +114,8 @@ type controllerInfo struct {
// ControllerRegister containers registered router rules, controller handlers and filters.
// ControllerRegister containers registered router rules, controller handlers and filters.
type
ControllerRegister
struct
{
type
ControllerRegister
struct
{
routers
map
[
string
]
*
Tree
routers
map
[
string
]
*
Tree
enablePolicy
bool
policies
map
[
string
]
*
Tree
enableFilter
bool
enableFilter
bool
filters
[
FinishRouter
+
1
][]
*
FilterRouter
filters
[
FinishRouter
+
1
][]
*
FilterRouter
pool
sync
.
Pool
pool
sync
.
Pool
...
@@ -122,7 +124,8 @@ type ControllerRegister struct {
...
@@ -122,7 +124,8 @@ type ControllerRegister struct {
// NewControllerRegister returns a new ControllerRegister.
// NewControllerRegister returns a new ControllerRegister.
func
NewControllerRegister
()
*
ControllerRegister
{
func
NewControllerRegister
()
*
ControllerRegister
{
cr
:=
&
ControllerRegister
{
cr
:=
&
ControllerRegister
{
routers
:
make
(
map
[
string
]
*
Tree
),
routers
:
make
(
map
[
string
]
*
Tree
),
policies
:
make
(
map
[
string
]
*
Tree
),
}
}
cr
.
pool
.
New
=
func
()
interface
{}
{
cr
.
pool
.
New
=
func
()
interface
{}
{
return
beecontext
.
NewContext
()
return
beecontext
.
NewContext
()
...
@@ -711,6 +714,11 @@ func (p *ControllerRegister) ServeHTTP(rw http.ResponseWriter, r *http.Request)
...
@@ -711,6 +714,11 @@ func (p *ControllerRegister) ServeHTTP(rw http.ResponseWriter, r *http.Request)
goto
Admin
goto
Admin
}
}
//check policies
if
p
.
execPolicy
(
context
,
urlPath
)
{
goto
Admin
}
if
routerInfo
!=
nil
{
if
routerInfo
!=
nil
{
if
BConfig
.
RunMode
==
DEV
{
if
BConfig
.
RunMode
==
DEV
{
//store router pattern into context
//store router pattern into context
...
...
Write
Preview
Markdown
is supported
0%
Try again
or
attach a new file
Attach a file
Cancel
You are about to add
0
people
to the discussion. Proceed with caution.
Finish editing this message first!
Cancel
Please
register
or
sign in
to comment