2020-06-18 16:13:24 +02:00
|
|
|
/*
|
2020-09-22 12:13:00 +02:00
|
|
|
Copyright 2020 Docker Compose CLI authors
|
2020-06-18 16:13:24 +02:00
|
|
|
|
|
|
|
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
|
|
|
|
|
|
|
|
http://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.
|
|
|
|
*/
|
|
|
|
|
2020-05-03 13:41:45 +02:00
|
|
|
package cmd
|
|
|
|
|
|
|
|
import (
|
|
|
|
"context"
|
2020-07-02 11:49:39 +02:00
|
|
|
"io"
|
|
|
|
"os"
|
2020-05-03 13:41:45 +02:00
|
|
|
|
2020-07-01 19:04:24 +02:00
|
|
|
"github.com/containerd/console"
|
2020-05-03 13:41:45 +02:00
|
|
|
"github.com/pkg/errors"
|
|
|
|
"github.com/spf13/cobra"
|
2020-05-04 16:38:02 +02:00
|
|
|
|
2020-09-07 13:23:06 +02:00
|
|
|
"github.com/docker/compose-cli/api/client"
|
2020-09-07 13:22:08 +02:00
|
|
|
"github.com/docker/compose-cli/api/containers"
|
2020-05-03 13:41:45 +02:00
|
|
|
)
|
|
|
|
|
|
|
|
type logsOpts struct {
|
|
|
|
Follow bool
|
2020-05-04 16:38:02 +02:00
|
|
|
Tail string
|
2020-05-03 13:41:45 +02:00
|
|
|
}
|
|
|
|
|
2020-05-04 23:00:21 +02:00
|
|
|
// LogsCommand fetches and shows logs of a container
|
2020-05-03 13:41:45 +02:00
|
|
|
func LogsCommand() *cobra.Command {
|
|
|
|
var opts logsOpts
|
|
|
|
cmd := &cobra.Command{
|
|
|
|
Use: "logs",
|
|
|
|
Short: "Fetch the logs of a container",
|
|
|
|
Args: cobra.ExactArgs(1),
|
|
|
|
RunE: func(cmd *cobra.Command, args []string) error {
|
|
|
|
return runLogs(cmd.Context(), args[0], opts)
|
|
|
|
},
|
|
|
|
}
|
|
|
|
|
|
|
|
cmd.Flags().BoolVarP(&opts.Follow, "follow", "f", false, "Follow log outut")
|
2020-05-04 16:38:02 +02:00
|
|
|
cmd.Flags().StringVar(&opts.Tail, "tail", "all", "Number of lines to show from the end of the logs")
|
2020-05-03 13:41:45 +02:00
|
|
|
|
|
|
|
return cmd
|
|
|
|
}
|
|
|
|
|
2020-05-04 16:38:02 +02:00
|
|
|
func runLogs(ctx context.Context, containerName string, opts logsOpts) error {
|
2020-05-03 13:41:45 +02:00
|
|
|
c, err := client.New(ctx)
|
|
|
|
if err != nil {
|
|
|
|
return errors.Wrap(err, "cannot connect to backend")
|
|
|
|
}
|
|
|
|
|
2020-05-04 16:38:02 +02:00
|
|
|
req := containers.LogsRequest{
|
|
|
|
Follow: opts.Follow,
|
|
|
|
Tail: opts.Tail,
|
|
|
|
}
|
|
|
|
|
2020-07-09 10:50:48 +02:00
|
|
|
var con io.Writer = os.Stdout
|
|
|
|
if c, err := console.ConsoleFromFile(os.Stdout); err == nil {
|
|
|
|
size, err := c.Size()
|
|
|
|
if err != nil {
|
|
|
|
return err
|
|
|
|
}
|
|
|
|
req.Width = int(size.Width)
|
|
|
|
con = c
|
|
|
|
}
|
|
|
|
|
|
|
|
req.Writer = con
|
|
|
|
|
2020-05-04 16:38:02 +02:00
|
|
|
return c.ContainerService().Logs(ctx, containerName, req)
|
2020-05-03 13:41:45 +02:00
|
|
|
}
|