-
Notifications
You must be signed in to change notification settings - Fork 1
/
Copy pathsec.go
64 lines (53 loc) · 2.32 KB
/
sec.go
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
//Copyright 2011 Siyabonga Dlamini (siyabonga.dlamini@gmail.com). All rights reserved.
//
//Redistribution and use in source and binary forms, with or without
//modification, are permitted provided that the following conditions
//are met:
//
// 1. Redistributions of source code must retain the above copyright
// notice, this list of conditions and the following disclaimer.
//
// 2. Redistributions in binary form must reproduce the above copyright
// notice, this list of conditions and the following disclaimer
// in the documentation and/or other materials provided with the
// distribution.
//
//THIS SOFTWARE IS PROVIDED BY THE AUTHOR ``AS IS'' AND ANY EXPRESS OR
//IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED WARRANTIES
//OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE DISCLAIMED.
//IN NO EVENT SHALL THE AUTHOR BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL,
//SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO,
//PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR PROFITS;
//OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY,
//WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR
//OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF
//ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
package gorest
import (
"net/http"
)
var authorizers map[string]Authorizer
//Signiture of functions to be used as Authorizers
type Authorizer func(string,string,*http.Request)(bool,bool,SessionData)
//Registers an Authorizer for the specified realm.
func RegisterRealmAuthorizer(realm string,auth Authorizer){
if authorizers ==nil{
authorizers = make(map[string]Authorizer,0)
}
if _,found := authorizers[realm]; !found{
authorizers[realm] = auth
}
}
//Returns the registred Authorizer for the specified realm.
func GetAuthorizer(realm string)(a Authorizer){
if authorizers ==nil{
authorizers = make(map[string]Authorizer,0)
}
a,_ = authorizers[realm]
return
}
//This is the default and exmaple authorizer that is used to authorize requests to endpints with no security realms.
//It always allows access and returns nil for SessionData.
func DefaultAuthorizer(id string,role string,_*http.Request)(bool,bool,SessionData) {
return true, true,nil
}