blob: 6d03ead8f0fca0d8a374c1b791ae969dd547d5bc [file] [log] [blame]
/*
Copyright 2019 Cesanta Software Ltd.
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
https://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 api
import (
"fmt"
"net"
"strings"
)
// Authorizer interface performs authorization of the request.
// It is invoked after authentication so it can be assumed that the requestor has
// presented satisfactory credentials for Account.
// Principally, it answers the question: is this Account allowed to perform these Actions
// on this Type.Name subject in the give Service?
type Authorizer interface {
// Authorize performs authorization given the request information.
// It returns a set of authorized actions (of the set requested), which can be empty/nil.
// Error should only be reported if request could not be serviced, not if it should be denied.
// A special NoMatch error is returned if the authorizer could not reach a decision,
// e.g. none of the rules matched.
// Implementations must be goroutine-safe.
Authorize(ai *AuthRequestInfo) ([]string, error)
// Finalize resources in preparation for shutdown.
// When this call is made there are guaranteed to be no Authenticate requests in flight
// and there will be no more calls made to this instance.
Stop()
// Human-readable name of the authenticator.
Name() string
}
type AuthRequestInfo struct {
Account string
Type string
Name string
Service string
IP net.IP
Actions []string
Labels Labels
}
func (ai AuthRequestInfo) String() string {
return fmt.Sprintf("{%s %s %s %s}", ai.Account, strings.Join(ai.Actions, ","), ai.Type, ai.Name)
}