Skip to content
Projects
Groups
Snippets
Help
This project
Loading...
Sign in / Register
Toggle navigation
N
nexpie-grafana-theme
Overview
Overview
Details
Activity
Cycle Analytics
Repository
Repository
Files
Commits
Branches
Tags
Contributors
Graph
Compare
Charts
Registry
Registry
Issues
0
Issues
0
List
Board
Labels
Milestones
Merge Requests
0
Merge Requests
0
CI / CD
CI / CD
Pipelines
Jobs
Schedules
Charts
Wiki
Wiki
Snippets
Snippets
Members
Collapse sidebar
Close sidebar
Activity
Graph
Charts
Create a new issue
Jobs
Commits
Issue Boards
Open sidebar
Kornkitt Poolsup
nexpie-grafana-theme
Commits
a5e450a0
Commit
a5e450a0
authored
Jan 27, 2015
by
Torkel Ödegaard
Browse files
Options
Browse Files
Download
Email Patches
Plain Diff
Worked on anonymous access
parent
757b1853
Show whitespace changes
Inline
Side-by-side
Showing
7 changed files
with
61 additions
and
19 deletions
+61
-19
conf/grafana.ini
+2
-2
pkg/middleware/auth.go
+3
-6
pkg/middleware/middleware.go
+18
-1
pkg/models/account.go
+5
-0
pkg/models/user.go
+3
-0
pkg/services/sqlstore/account.go
+18
-2
pkg/setting/setting.go
+12
-8
No files found.
conf/grafana.ini
View file @
a5e450a0
...
...
@@ -59,9 +59,9 @@ default_role = Editor
; enable anonymous access
enabled
=
false
; specify account name that should be used for unauthenticated users
account
=
main
account
_name
=
main
; specify role for unauthenticated users
role
=
Viewer
account_
role
=
Viewer
[auth.github]
enabled
=
false
...
...
pkg/middleware/auth.go
View file @
a5e450a0
...
...
@@ -6,7 +6,6 @@ import (
"github.com/Unknwon/macaron"
"github.com/torkelo/grafana-pro/pkg/log"
m
"github.com/torkelo/grafana-pro/pkg/models"
"github.com/torkelo/grafana-pro/pkg/setting"
)
...
...
@@ -70,15 +69,13 @@ func RoleAuth(roles ...m.RoleType) macaron.Handler {
func
Auth
(
options
*
AuthOptions
)
macaron
.
Handler
{
return
func
(
c
*
Context
)
{
if
!
c
.
IsSignedIn
&&
options
.
ReqSignedIn
{
log
.
Info
(
"AppSubUrl: %v"
,
setting
.
AppSubUrl
)
c
.
SetCookie
(
"redirect_to"
,
url
.
QueryEscape
(
setting
.
AppSubUrl
+
c
.
Req
.
RequestURI
),
0
,
setting
.
AppSubUrl
+
"/"
)
if
!
c
.
IsGrafanaAdmin
&&
options
.
ReqGrafanaAdmin
{
authDenied
(
c
)
return
}
if
!
c
.
IsGrafanaAdmin
&&
options
.
ReqGrafanaAdmin
{
if
!
c
.
IsSignedIn
&&
options
.
ReqSignedIn
&&
!
c
.
HasAnonymousAccess
{
c
.
SetCookie
(
"redirect_to"
,
url
.
QueryEscape
(
setting
.
AppSubUrl
+
c
.
Req
.
RequestURI
),
0
,
setting
.
AppSubUrl
+
"/"
)
authDenied
(
c
)
return
}
...
...
pkg/middleware/middleware.go
View file @
a5e450a0
...
...
@@ -21,6 +21,7 @@ type Context struct {
Session
session
.
Store
IsSignedIn
bool
HasAnonymousAccess
bool
}
func
GetContextHandler
()
macaron
.
Handler
{
...
...
@@ -28,6 +29,9 @@ func GetContextHandler() macaron.Handler {
ctx
:=
&
Context
{
Context
:
c
,
Session
:
sess
,
SignedInUser
:
&
m
.
SignedInUser
{},
IsSignedIn
:
false
,
HasAnonymousAccess
:
false
,
}
// try get account id from request
...
...
@@ -36,8 +40,8 @@ func GetContextHandler() macaron.Handler {
if
err
:=
bus
.
Dispatch
(
&
query
);
err
!=
nil
{
log
.
Error
(
3
,
"Failed to get user by id, %v, %v"
,
userId
,
err
)
}
else
{
ctx
.
IsSignedIn
=
true
ctx
.
SignedInUser
=
query
.
Result
ctx
.
IsSignedIn
=
true
}
}
else
if
key
:=
getApiKey
(
ctx
);
key
!=
""
{
// Try API Key auth
...
...
@@ -56,6 +60,19 @@ func GetContextHandler() macaron.Handler {
ctx
.
ApiKeyId
=
keyInfo
.
Id
ctx
.
AccountId
=
keyInfo
.
AccountId
}
}
else
if
setting
.
AnonymousEnabled
{
accountQuery
:=
m
.
GetAccountByNameQuery
{
Name
:
setting
.
AnonymousAccountName
}
if
err
:=
bus
.
Dispatch
(
&
accountQuery
);
err
!=
nil
{
if
err
==
m
.
ErrAccountNotFound
{
log
.
Error
(
3
,
"Anonymous access account name does not exist"
,
nil
)
}
}
else
{
ctx
.
IsSignedIn
=
false
ctx
.
HasAnonymousAccess
=
true
ctx
.
SignedInUser
=
&
m
.
SignedInUser
{}
ctx
.
AccountRole
=
m
.
RoleType
(
setting
.
AnonymousAccountRole
)
ctx
.
AccountId
=
accountQuery
.
Result
.
Id
}
}
c
.
Map
(
ctx
)
...
...
pkg/models/account.go
View file @
a5e450a0
...
...
@@ -43,6 +43,11 @@ type GetAccountByIdQuery struct {
Result
*
Account
}
type
GetAccountByNameQuery
struct
{
Name
string
Result
*
Account
}
type
AccountDTO
struct
{
Id
int64
`json:"id"`
Name
string
`json:"name"`
...
...
pkg/models/user.go
View file @
a5e450a0
...
...
@@ -84,6 +84,9 @@ type SearchUsersQuery struct {
// DTO & Projections
type
SignedInUser
struct
{
IsSignedIn
bool
IsAnonymous
bool
UserId
int64
AccountId
int64
AccountName
string
...
...
pkg/services/sqlstore/account.go
View file @
a5e450a0
...
...
@@ -10,13 +10,14 @@ import (
)
func
init
()
{
bus
.
AddHandler
(
"sql"
,
GetAccount
)
bus
.
AddHandler
(
"sql"
,
GetAccount
ById
)
bus
.
AddHandler
(
"sql"
,
CreateAccount
)
bus
.
AddHandler
(
"sql"
,
SetUsingAccount
)
bus
.
AddHandler
(
"sql"
,
UpdateAccount
)
bus
.
AddHandler
(
"sql"
,
GetAccountByName
)
}
func
GetAccount
(
query
*
m
.
GetAccountByIdQuery
)
error
{
func
GetAccount
ById
(
query
*
m
.
GetAccountByIdQuery
)
error
{
var
account
m
.
Account
exists
,
err
:=
x
.
Id
(
query
.
Id
)
.
Get
(
&
account
)
if
err
!=
nil
{
...
...
@@ -31,6 +32,21 @@ func GetAccount(query *m.GetAccountByIdQuery) error {
return
nil
}
func
GetAccountByName
(
query
*
m
.
GetAccountByNameQuery
)
error
{
var
account
m
.
Account
exists
,
err
:=
x
.
Where
(
"name=?"
,
query
.
Name
)
.
Get
(
&
account
)
if
err
!=
nil
{
return
err
}
if
!
exists
{
return
m
.
ErrAccountNotFound
}
query
.
Result
=
&
account
return
nil
}
func
CreateAccount
(
cmd
*
m
.
CreateAccountCommand
)
error
{
return
inTransaction
(
func
(
sess
*
xorm
.
Session
)
error
{
...
...
pkg/setting/setting.go
View file @
a5e450a0
...
...
@@ -72,8 +72,10 @@ var (
// Http auth
AdminUser
string
AdminPassword
string
Anonymous
bool
AnonymousAccountId
int64
AnonymousEnabled
bool
AnonymousAccountName
string
AnonymousAccountRole
string
// Session settings.
SessionOptions
session
.
Options
...
...
@@ -195,17 +197,19 @@ func NewConfigContext() {
CookieUserName
=
security
.
Key
(
"cookie_username"
)
.
String
()
CookieRememberName
=
security
.
Key
(
"cookie_remember_name"
)
.
String
()
// admin
AdminUser
=
security
.
Key
(
"admin_user"
)
.
String
()
AdminPassword
=
security
.
Key
(
"admin_password"
)
.
String
()
// single account
SingleAccountMode
=
Cfg
.
Section
(
"account.single"
)
.
Key
(
"enabled"
)
.
MustBool
(
false
)
DefaultAccountName
=
Cfg
.
Section
(
"account.single"
)
.
Key
(
"account_name"
)
.
MustString
(
"main"
)
DefaultAccountRole
=
Cfg
.
Section
(
"account.single"
)
.
Key
(
"default_role"
)
.
In
(
"Editor"
,
[]
string
{
"Editor"
,
"Admin"
,
"Viewer"
})
// admin
AdminUser
=
security
.
Key
(
"admin_user"
)
.
String
()
AdminPassword
=
security
.
Key
(
"admin_password"
)
.
String
()
// Anonymous = Cfg.MustBool("auth", "anonymous", false)
// AnonymousAccountId = Cfg.MustInt64("auth", "anonymous_account_id", 0)
// anonymous access
AnonymousEnabled
=
Cfg
.
Section
(
"auth.anonymous"
)
.
Key
(
"enabled"
)
.
MustBool
(
false
)
AnonymousAccountName
=
Cfg
.
Section
(
"auth.anonymous"
)
.
Key
(
"account_name"
)
.
String
()
AnonymousAccountRole
=
Cfg
.
Section
(
"auth.anonymous"
)
.
Key
(
"account_role"
)
.
String
()
// PhantomJS rendering
ImagesDir
=
"data/png"
...
...
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