auth

package
v0.3.2 Latest Latest
Warning

This package is not in the latest version of its module.

Go to latest
Published: Nov 16, 2022 License: GPL-3.0 Imports: 10 Imported by: 0

Documentation

Index

Constants

View Source
const (
	MetaKeyLogin   = "login"
	MetaKeyBaseURL = "base-url"
)

Variables

View Source
var ErrCredentialNotExist = errors.New("credential doesn't exist")

Functions

func IdExist

func IdExist(repo repository.RepoConfig, id entity.Id) bool

IdExist return whether a credential id exist or not

func NewErrMultipleMatchCredential

func NewErrMultipleMatchCredential(matching []entity.Id) *entity.ErrMultipleMatch

func PrefixExist

func PrefixExist(repo repository.RepoConfig, prefix string) bool

PrefixExist return whether a credential id prefix exist or not

func Remove

func Remove(repo repository.RepoConfig, id entity.Id) error

Remove removes a credential from the global git config

func Store

func Store(repo repository.RepoConfig, cred Credential) error

Store stores a credential in the global git config

Types

type ById

type ById []Credential

func (ById) Len

func (b ById) Len() int

func (ById) Less

func (b ById) Less(i, j int) bool

func (ById) Swap

func (b ById) Swap(i, j int)

type Credential

type Credential interface {
	ID() entity.Id
	Kind() CredentialKind
	Target() string
	CreateTime() time.Time
	Salt() []byte
	Validate() error

	Metadata() map[string]string
	GetMetadata(key string) (string, bool)
	SetMetadata(key string, value string)
	// contains filtered or unexported methods
}

func List

func List(repo repository.RepoConfig, opts ...Option) ([]Credential, error)

List load all existing credentials

func LoadWithId

func LoadWithId(repo repository.RepoConfig, id entity.Id) (Credential, error)

Load loads a credential from the repo config

func LoadWithPrefix

func LoadWithPrefix(repo repository.RepoConfig, prefix string) (Credential, error)

LoadWithPrefix load a credential from the repo config with a prefix

type CredentialBase

type CredentialBase struct {
	TargetT     string            `json:"target"`
	CreateTimeT time.Time         `json:"create_time"`
	SaltT       []byte            `json:"salt"`
	MetaT       map[string]string `json:"meta"`
}

func (*CredentialBase) CreateTime

func (cb *CredentialBase) CreateTime() time.Time

func (*CredentialBase) GetMetadata

func (cb *CredentialBase) GetMetadata(key string) (string, bool)

func (*CredentialBase) Metadata

func (cb *CredentialBase) Metadata() map[string]string

func (*CredentialBase) Salt

func (cb *CredentialBase) Salt() []byte

func (*CredentialBase) SetMetadata

func (cb *CredentialBase) SetMetadata(key string, value string)

func (*CredentialBase) Target

func (cb *CredentialBase) Target() string

type CredentialKind

type CredentialKind string
const (
	KindToken         CredentialKind = "token"
	KindLogin         CredentialKind = "login"
	KindLoginPassword CredentialKind = "login-password"
)

type Login

type Login struct {
	*CredentialBase
	Login string
}

func NewLogin

func NewLogin(target, login string) *Login

func NewLoginFromConfig

func NewLoginFromConfig(conf map[string]string) (*Login, error)

func (*Login) ID

func (lp *Login) ID() entity.Id

func (*Login) Kind

func (lp *Login) Kind() CredentialKind

func (*Login) Validate

func (lp *Login) Validate() error

type LoginPassword

type LoginPassword struct {
	*CredentialBase
	Login    string
	Password string
}

func NewLoginPassword

func NewLoginPassword(target, login, password string) *LoginPassword

func NewLoginPasswordFromConfig

func NewLoginPasswordFromConfig(conf map[string]string) (*LoginPassword, error)

func (*LoginPassword) ID

func (lp *LoginPassword) ID() entity.Id

func (*LoginPassword) Kind

func (lp *LoginPassword) Kind() CredentialKind

func (*LoginPassword) Validate

func (lp *LoginPassword) Validate() error

type Option

type Option func(opts *options)

func WithKind

func WithKind(kind CredentialKind) Option

WithKind match credentials with the given kind. Can be specified multiple times.

func WithMeta

func WithMeta(key string, val string) Option

func WithTarget

func WithTarget(target string) Option

type Token

type Token struct {
	*CredentialBase
	Value string
}

Token holds an API access token data

func NewToken

func NewToken(target, value string) *Token

NewToken instantiate a new token

func NewTokenFromConfig

func NewTokenFromConfig(conf map[string]string) (*Token, error)

func (*Token) ID

func (t *Token) ID() entity.Id

func (*Token) Kind

func (t *Token) Kind() CredentialKind

func (*Token) Validate

func (t *Token) Validate() error

Validate ensure token important fields are valid

Jump to

Keyboard shortcuts

? : This menu
/ : Search site
f or F : Jump to
y or Y : Canonical URL