Documentation ¶
Index ¶
- Constants
- Variables
- func DownloadPluginFromGithub(ctx context.Context, localPath string, org string, name string, version string, ...) error
- func GenerateRandomUnixSocketName() string
- func WithBinarySuffix(filePath string) string
- func WithDirectory(directory string) func(*Client)
- func WithLogger(logger zerolog.Logger) func(*Client)
- func WithNoSentry() func(*Client)
- type Client
- type Clients
- type Config
- type LogReader
- type Metrics
- type Option
- type PluginType
- type Registry
Constants ¶
const ( DefaultDownloadDir = ".cq" RetryAttempts = 5 RetryWaitTime = 1 * time.Second )
Variables ¶
var (
ErrLogLineToLong = errors.New("log line too long, discarding")
)
Functions ¶
func GenerateRandomUnixSocketName ¶
func GenerateRandomUnixSocketName() string
func WithBinarySuffix ¶
func WithDirectory ¶
func WithLogger ¶
func WithNoSentry ¶
func WithNoSentry() func(*Client)
Types ¶
type Client ¶
type Client struct { LocalPath string Conn *grpc.ClientConn // contains filtered or unexported fields }
func NewClient ¶
NewClient creates a new plugin client. If registrySpec is GitHub then client downloads the plugin, spawns it and creates a gRPC connection. If registrySpec is Local then client spawns the plugin and creates a gRPC connection. If registrySpec is gRPC then clients creates a new connection
type Clients ¶
type Clients []*Client
func NewClients ¶
func NewClients(ctx context.Context, typ PluginType, specs []Config, opts ...Option) (Clients, error)
typ will be deprecated soon but now required for a transition period
func (Clients) ClientByName ¶
type LogReader ¶
type LogReader struct {
// contains filtered or unexported fields
}
logReader is a custom implementation similar to bufio.Scanner, but provides a way to handle lines (or tokens) that exceed the buffer size.
func NewLogReader ¶
func NewLogReader(reader io.ReadCloser) *LogReader
newLogReader creates a new logReader to read log lines from an io.ReadCloser
func (*LogReader) NextLine ¶
NextLine reads and returns the next log line from the reader. An io.EOF error is returned if the end of the stream has been reached. This implementation is different from bufio.Scanner as it also returns an error if a line is too long to fit into the buffer. In this case, an error is returned together with a limited prefix of the line.
type PluginType ¶
type PluginType int
PluginType specifies if a plugin is a source or a destination it actually doesn't really have any effect as plugins can serve both as source and as destinations but it is here for backward compatibility
const ( PluginSource PluginType = iota PluginDestination )
func (PluginType) String ¶
func (p PluginType) String() string
type Registry ¶
type Registry int