2019-09-24 19:32:35 +02:00
|
|
|
package runtime
|
|
|
|
|
2019-09-24 20:00:11 +02:00
|
|
|
import (
|
2020-04-23 14:53:42 +02:00
|
|
|
"context"
|
2019-09-24 20:00:11 +02:00
|
|
|
"io"
|
2020-05-11 18:09:28 +02:00
|
|
|
|
2021-10-12 13:55:53 +02:00
|
|
|
"go-micro.dev/v4/client"
|
2022-09-29 16:44:53 +02:00
|
|
|
"go-micro.dev/v4/logger"
|
2019-09-24 20:00:11 +02:00
|
|
|
)
|
|
|
|
|
2019-11-02 15:25:10 +02:00
|
|
|
type Option func(o *Options)
|
|
|
|
|
2022-09-30 16:27:07 +02:00
|
|
|
// Options configure runtime.
|
2019-11-02 15:25:10 +02:00
|
|
|
type Options struct {
|
2020-01-16 15:34:04 +02:00
|
|
|
// Scheduler for updates
|
|
|
|
Scheduler Scheduler
|
2019-11-29 13:35:00 +02:00
|
|
|
// Service type to manage
|
|
|
|
Type string
|
2020-02-05 15:59:35 +02:00
|
|
|
// Source of the services repository
|
|
|
|
Source string
|
2020-03-13 20:39:59 +02:00
|
|
|
// Base image to use
|
|
|
|
Image string
|
2020-05-11 18:09:28 +02:00
|
|
|
// Client to use when making requests
|
|
|
|
Client client.Client
|
2022-09-29 16:44:53 +02:00
|
|
|
// Logger underline logger
|
|
|
|
Logger logger.Logger
|
|
|
|
}
|
|
|
|
|
|
|
|
func NewOptions(opts ...Option) *Options {
|
|
|
|
options := &Options{
|
|
|
|
Logger: logger.DefaultLogger,
|
|
|
|
}
|
|
|
|
|
|
|
|
for _, o := range opts {
|
|
|
|
o(options)
|
|
|
|
}
|
|
|
|
|
|
|
|
return options
|
2020-02-05 15:59:35 +02:00
|
|
|
}
|
|
|
|
|
2022-09-30 16:27:07 +02:00
|
|
|
// WithSource sets the base image / repository.
|
2020-02-05 15:59:35 +02:00
|
|
|
func WithSource(src string) Option {
|
|
|
|
return func(o *Options) {
|
|
|
|
o.Source = src
|
|
|
|
}
|
2019-11-02 15:25:10 +02:00
|
|
|
}
|
|
|
|
|
2022-09-30 16:27:07 +02:00
|
|
|
// WithScheduler specifies a scheduler for updates.
|
2020-01-16 15:34:04 +02:00
|
|
|
func WithScheduler(n Scheduler) Option {
|
2019-11-02 15:25:10 +02:00
|
|
|
return func(o *Options) {
|
2020-01-16 15:34:04 +02:00
|
|
|
o.Scheduler = n
|
2019-11-02 15:25:10 +02:00
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2022-09-30 16:27:07 +02:00
|
|
|
// WithType sets the service type to manage.
|
2019-11-29 13:35:00 +02:00
|
|
|
func WithType(t string) Option {
|
|
|
|
return func(o *Options) {
|
|
|
|
o.Type = t
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2022-09-30 16:27:07 +02:00
|
|
|
// WithImage sets the image to use.
|
2020-03-13 20:39:59 +02:00
|
|
|
func WithImage(t string) Option {
|
|
|
|
return func(o *Options) {
|
|
|
|
o.Image = t
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2022-09-30 16:27:07 +02:00
|
|
|
// WithClient sets the client to use.
|
2020-05-11 18:09:28 +02:00
|
|
|
func WithClient(c client.Client) Option {
|
|
|
|
return func(o *Options) {
|
|
|
|
o.Client = c
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2022-09-30 16:27:07 +02:00
|
|
|
// WithLogger sets the underline logger.
|
2022-09-29 16:44:53 +02:00
|
|
|
func WithLogger(l logger.Logger) Option {
|
|
|
|
return func(o *Options) {
|
|
|
|
o.Logger = l
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2019-09-24 19:32:35 +02:00
|
|
|
type CreateOption func(o *CreateOptions)
|
|
|
|
|
2019-11-29 13:35:00 +02:00
|
|
|
type ReadOption func(o *ReadOptions)
|
|
|
|
|
2022-09-30 16:27:07 +02:00
|
|
|
// CreateOptions configure runtime services.
|
2019-09-24 19:32:35 +02:00
|
|
|
type CreateOptions struct {
|
2020-03-13 20:39:59 +02:00
|
|
|
// Command to execut
|
2019-09-24 19:32:35 +02:00
|
|
|
Command []string
|
2020-03-13 20:39:59 +02:00
|
|
|
// Args to pass into command
|
|
|
|
Args []string
|
2019-09-24 19:32:35 +02:00
|
|
|
// Environment to configure
|
|
|
|
Env []string
|
2019-09-24 20:00:11 +02:00
|
|
|
// Log output
|
|
|
|
Output io.Writer
|
2019-11-29 13:35:00 +02:00
|
|
|
// Type of service to create
|
|
|
|
Type string
|
2020-02-07 14:02:41 +02:00
|
|
|
// Retries before failing deploy
|
|
|
|
Retries int
|
2020-03-13 20:39:59 +02:00
|
|
|
// Specify the image to use
|
|
|
|
Image string
|
2020-04-23 14:53:42 +02:00
|
|
|
// Namespace to create the service in
|
|
|
|
Namespace string
|
|
|
|
// Specify the context to use
|
|
|
|
Context context.Context
|
2019-11-29 13:35:00 +02:00
|
|
|
}
|
|
|
|
|
2022-09-30 16:27:07 +02:00
|
|
|
// ReadOptions queries runtime services.
|
2019-11-29 13:35:00 +02:00
|
|
|
type ReadOptions struct {
|
|
|
|
// Service name
|
|
|
|
Service string
|
|
|
|
// Version queries services with given version
|
|
|
|
Version string
|
|
|
|
// Type of service
|
|
|
|
Type string
|
2020-04-23 14:53:42 +02:00
|
|
|
// Namespace the service is running in
|
|
|
|
Namespace string
|
|
|
|
// Specify the context to use
|
|
|
|
Context context.Context
|
2019-09-24 19:32:35 +02:00
|
|
|
}
|
|
|
|
|
2022-09-30 16:27:07 +02:00
|
|
|
// CreateType sets the type of service to create.
|
2020-01-17 16:14:47 +02:00
|
|
|
func CreateType(t string) CreateOption {
|
|
|
|
return func(o *CreateOptions) {
|
|
|
|
o.Type = t
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2022-09-30 16:27:07 +02:00
|
|
|
// CreateImage sets the image to use.
|
2020-03-13 20:39:59 +02:00
|
|
|
func CreateImage(img string) CreateOption {
|
2020-02-24 19:47:47 +02:00
|
|
|
return func(o *CreateOptions) {
|
2020-03-13 20:39:59 +02:00
|
|
|
o.Image = img
|
2020-02-24 19:47:47 +02:00
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2022-09-30 16:27:07 +02:00
|
|
|
// CreateNamespace sets the namespace.
|
2020-04-23 14:53:42 +02:00
|
|
|
func CreateNamespace(ns string) CreateOption {
|
|
|
|
return func(o *CreateOptions) {
|
|
|
|
o.Namespace = ns
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2022-09-30 16:27:07 +02:00
|
|
|
// CreateContext sets the context.
|
2020-04-23 14:53:42 +02:00
|
|
|
func CreateContext(ctx context.Context) CreateOption {
|
|
|
|
return func(o *CreateOptions) {
|
|
|
|
o.Context = ctx
|
2020-04-23 13:27:36 +02:00
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2022-09-30 16:27:07 +02:00
|
|
|
// WithCommand specifies the command to execute.
|
2020-03-13 20:39:59 +02:00
|
|
|
func WithCommand(cmd ...string) CreateOption {
|
|
|
|
return func(o *CreateOptions) {
|
|
|
|
// set command
|
|
|
|
o.Command = cmd
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2022-09-30 16:27:07 +02:00
|
|
|
// WithArgs specifies the command to execute.
|
2020-03-13 20:39:59 +02:00
|
|
|
func WithArgs(args ...string) CreateOption {
|
2019-09-24 19:32:35 +02:00
|
|
|
return func(o *CreateOptions) {
|
|
|
|
// set command
|
2020-03-13 20:39:59 +02:00
|
|
|
o.Args = args
|
2019-09-24 19:32:35 +02:00
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2020-02-07 14:02:41 +02:00
|
|
|
func WithRetries(retries int) CreateOption {
|
|
|
|
return func(o *CreateOptions) {
|
|
|
|
o.Retries = retries
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2022-09-30 16:27:07 +02:00
|
|
|
// WithEnv sets the created service environment.
|
2019-09-24 19:32:35 +02:00
|
|
|
func WithEnv(env []string) CreateOption {
|
|
|
|
return func(o *CreateOptions) {
|
|
|
|
o.Env = env
|
|
|
|
}
|
|
|
|
}
|
2019-09-24 20:00:11 +02:00
|
|
|
|
2022-09-30 16:27:07 +02:00
|
|
|
// WithOutput sets the arg output.
|
2019-09-24 20:00:11 +02:00
|
|
|
func WithOutput(out io.Writer) CreateOption {
|
|
|
|
return func(o *CreateOptions) {
|
|
|
|
o.Output = out
|
|
|
|
}
|
|
|
|
}
|
2019-11-15 15:41:40 +02:00
|
|
|
|
2022-09-30 16:27:07 +02:00
|
|
|
// ReadService returns services with the given name.
|
2019-11-29 13:35:00 +02:00
|
|
|
func ReadService(service string) ReadOption {
|
|
|
|
return func(o *ReadOptions) {
|
|
|
|
o.Service = service
|
|
|
|
}
|
2019-11-15 15:41:40 +02:00
|
|
|
}
|
|
|
|
|
2022-09-30 16:27:07 +02:00
|
|
|
// ReadVersion confifgures service version.
|
2019-11-29 13:35:00 +02:00
|
|
|
func ReadVersion(version string) ReadOption {
|
2019-11-25 18:31:14 +02:00
|
|
|
return func(o *ReadOptions) {
|
2019-11-15 15:41:40 +02:00
|
|
|
o.Version = version
|
|
|
|
}
|
|
|
|
}
|
2019-11-29 13:35:00 +02:00
|
|
|
|
2022-09-30 16:27:07 +02:00
|
|
|
// ReadType returns services of the given type.
|
2019-11-29 13:35:00 +02:00
|
|
|
func ReadType(t string) ReadOption {
|
|
|
|
return func(o *ReadOptions) {
|
|
|
|
o.Type = t
|
|
|
|
}
|
|
|
|
}
|
2020-04-01 15:40:15 +02:00
|
|
|
|
2022-09-30 16:27:07 +02:00
|
|
|
// ReadNamespace sets the namespace.
|
2020-04-23 14:53:42 +02:00
|
|
|
func ReadNamespace(ns string) ReadOption {
|
|
|
|
return func(o *ReadOptions) {
|
|
|
|
o.Namespace = ns
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2022-09-30 16:27:07 +02:00
|
|
|
// ReadContext sets the context.
|
2020-04-23 14:53:42 +02:00
|
|
|
func ReadContext(ctx context.Context) ReadOption {
|
|
|
|
return func(o *ReadOptions) {
|
|
|
|
o.Context = ctx
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
type UpdateOption func(o *UpdateOptions)
|
|
|
|
|
|
|
|
type UpdateOptions struct {
|
|
|
|
// Namespace the service is running in
|
|
|
|
Namespace string
|
|
|
|
// Specify the context to use
|
|
|
|
Context context.Context
|
|
|
|
}
|
|
|
|
|
2022-09-30 16:27:07 +02:00
|
|
|
// UpdateNamespace sets the namespace.
|
2020-04-23 14:53:42 +02:00
|
|
|
func UpdateNamespace(ns string) UpdateOption {
|
|
|
|
return func(o *UpdateOptions) {
|
|
|
|
o.Namespace = ns
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2022-09-30 16:27:07 +02:00
|
|
|
// UpdateContext sets the context.
|
2020-04-23 14:53:42 +02:00
|
|
|
func UpdateContext(ctx context.Context) UpdateOption {
|
|
|
|
return func(o *UpdateOptions) {
|
|
|
|
o.Context = ctx
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
type DeleteOption func(o *DeleteOptions)
|
|
|
|
|
|
|
|
type DeleteOptions struct {
|
|
|
|
// Namespace the service is running in
|
|
|
|
Namespace string
|
|
|
|
// Specify the context to use
|
|
|
|
Context context.Context
|
|
|
|
}
|
|
|
|
|
2022-09-30 16:27:07 +02:00
|
|
|
// DeleteNamespace sets the namespace.
|
2020-04-23 14:53:42 +02:00
|
|
|
func DeleteNamespace(ns string) DeleteOption {
|
|
|
|
return func(o *DeleteOptions) {
|
|
|
|
o.Namespace = ns
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2022-09-30 16:27:07 +02:00
|
|
|
// DeleteContext sets the context.
|
2020-04-23 14:53:42 +02:00
|
|
|
func DeleteContext(ctx context.Context) DeleteOption {
|
|
|
|
return func(o *DeleteOptions) {
|
|
|
|
o.Context = ctx
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2022-09-30 16:27:07 +02:00
|
|
|
// LogsOption configures runtime logging.
|
2020-04-01 15:40:15 +02:00
|
|
|
type LogsOption func(o *LogsOptions)
|
|
|
|
|
2022-09-30 16:27:07 +02:00
|
|
|
// LogsOptions configure runtime logging.
|
2020-04-01 15:40:15 +02:00
|
|
|
type LogsOptions struct {
|
|
|
|
// How many existing lines to show
|
|
|
|
Count int64
|
|
|
|
// Stream new lines?
|
|
|
|
Stream bool
|
2020-04-23 14:53:42 +02:00
|
|
|
// Namespace the service is running in
|
|
|
|
Namespace string
|
|
|
|
// Specify the context to use
|
|
|
|
Context context.Context
|
2020-04-01 15:40:15 +02:00
|
|
|
}
|
|
|
|
|
2022-09-30 16:27:07 +02:00
|
|
|
// LogsExistingCount confiures how many existing lines to show.
|
2020-04-01 15:40:15 +02:00
|
|
|
func LogsCount(count int64) LogsOption {
|
|
|
|
return func(l *LogsOptions) {
|
|
|
|
l.Count = count
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2022-09-30 16:27:07 +02:00
|
|
|
// LogsStream configures whether to stream new lines.
|
2020-04-01 15:40:15 +02:00
|
|
|
func LogsStream(stream bool) LogsOption {
|
|
|
|
return func(l *LogsOptions) {
|
|
|
|
l.Stream = stream
|
|
|
|
}
|
|
|
|
}
|
2020-04-23 14:53:42 +02:00
|
|
|
|
2022-09-30 16:27:07 +02:00
|
|
|
// LogsNamespace sets the namespace.
|
2020-04-23 14:53:42 +02:00
|
|
|
func LogsNamespace(ns string) LogsOption {
|
|
|
|
return func(o *LogsOptions) {
|
|
|
|
o.Namespace = ns
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2022-09-30 16:27:07 +02:00
|
|
|
// LogsContext sets the context.
|
2020-04-23 14:53:42 +02:00
|
|
|
func LogsContext(ctx context.Context) LogsOption {
|
|
|
|
return func(o *LogsOptions) {
|
|
|
|
o.Context = ctx
|
|
|
|
}
|
|
|
|
}
|