influxdb/services/meta/write_authorizer.go

30 lines
804 B
Go
Raw Normal View History

2016-04-19 02:25:53 +00:00
package meta
import (
"fmt"
"github.com/influxdata/influxdb/influxql"
)
// WriteAuthorizer determines whether a user is authorized to write to a given database.
2016-04-19 02:25:53 +00:00
type WriteAuthorizer struct {
Client *Client
}
// NewWriteAuthorizer returns a new instance of WriteAuthorizer.
2016-04-19 02:25:53 +00:00
func NewWriteAuthorizer(c *Client) *WriteAuthorizer {
return &WriteAuthorizer{Client: c}
}
// AuthorizeWrite returns nil if the user has permission to write to the database.
func (a WriteAuthorizer) AuthorizeWrite(username, database string) error {
u, err := a.Client.User(username)
if err != nil || u == nil || !u.AuthorizeDatabase(influxql.WritePrivilege, database) {
2016-04-19 02:25:53 +00:00
return &ErrAuthorize{
Database: database,
Message: fmt.Sprintf("%s not authorized to write to %s", username, database),
}
}
return nil
}