You can not select more than 25 topics Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
boundary/internal/auth/password/authmethod.go

94 lines
2.4 KiB

package password
import (
"github.com/hashicorp/boundary/internal/auth/password/store"
"github.com/hashicorp/boundary/internal/errors"
"github.com/hashicorp/boundary/internal/oplog"
"google.golang.org/protobuf/proto"
)
// A AuthMethod contains accounts and password configurations. It is owned
// by a scope.
type AuthMethod struct {
*store.AuthMethod
tableName string
}
func allocAuthMethod() AuthMethod {
return AuthMethod{
AuthMethod: &store.AuthMethod{},
}
}
// NewAuthMethod creates a new in memory AuthMethod assigned to scopeId.
// Name and description are the only valid options. All other options are
// ignored. MinLoginNameLength and MinPasswordLength are pre-set to the
// default values of 5 and 8 respectively.
func NewAuthMethod(scopeId string, opt ...Option) (*AuthMethod, error) {
const op = "password.NewAuthMethod"
if scopeId == "" {
return nil, errors.NewDeprecated(errors.InvalidParameter, op, "missing scope id")
}
opts := getOpts(opt...)
a := &AuthMethod{
AuthMethod: &store.AuthMethod{
ScopeId: scopeId,
Name: opts.withName,
Description: opts.withDescription,
MinLoginNameLength: 3,
MinPasswordLength: 8,
},
}
return a, nil
}
// Clone simply clones the AuthMethod
func (a *AuthMethod) Clone() *AuthMethod {
cp := proto.Clone(a.AuthMethod)
return &AuthMethod{
AuthMethod: cp.(*store.AuthMethod),
}
}
// TableName returns the table name.
func (a *AuthMethod) TableName() string {
if a.tableName != "" {
return a.tableName
}
return "auth_password_method"
}
// SetTableName sets the table name.
func (a *AuthMethod) SetTableName(n string) {
a.tableName = n
}
func (a *AuthMethod) oplog(op oplog.OpType) oplog.Metadata {
metadata := oplog.Metadata{
"resource-public-id": []string{a.GetPublicId()},
"resource-type": []string{"password auth method"},
"op-type": []string{op.String()},
}
if a.ScopeId != "" {
metadata["scope-id"] = []string{a.ScopeId}
}
return metadata
}
// authMethodView provides a simple way to read an AuthMethod with its
// IsPrimaryAuthMethod field set. By definition, it's used only for reading
// AuthMethods.
type authMethodView struct {
*store.AuthMethod
tableName string
}
// TableName returns the view name.
func (a *authMethodView) TableName() string {
if a.tableName != "" {
return a.tableName
}
return "auth_password_method_with_is_primary"
}