All checks were successful
		
		
	
	continuous-integration/drone/push Build is passing
				
			See #627
		
			
				
	
	
		
			114 lines
		
	
	
		
			2.4 KiB
		
	
	
	
		
			Go
		
	
	
	
	
	
			
		
		
	
	
			114 lines
		
	
	
		
			2.4 KiB
		
	
	
	
		
			Go
		
	
	
	
	
	
package app
 | 
						|
 | 
						|
import (
 | 
						|
	"context"
 | 
						|
	"strings"
 | 
						|
 | 
						|
	"coopcloud.tech/abra/cli/internal"
 | 
						|
	appPkg "coopcloud.tech/abra/pkg/app"
 | 
						|
	"coopcloud.tech/abra/pkg/autocomplete"
 | 
						|
	"coopcloud.tech/abra/pkg/client"
 | 
						|
	"coopcloud.tech/abra/pkg/i18n"
 | 
						|
	"coopcloud.tech/abra/pkg/log"
 | 
						|
	"coopcloud.tech/abra/pkg/logs"
 | 
						|
	"coopcloud.tech/abra/pkg/upstream/stack"
 | 
						|
	"github.com/spf13/cobra"
 | 
						|
)
 | 
						|
 | 
						|
// translators: `abra app logs` aliases. use a comma separated list of aliases with
 | 
						|
// no spaces in between
 | 
						|
var appLogsAliases = i18n.G("l")
 | 
						|
 | 
						|
var AppLogsCommand = &cobra.Command{
 | 
						|
	// translators: `app logs` command
 | 
						|
	Use:     i18n.G("logs <domain> [service] [flags]"),
 | 
						|
	Aliases: strings.Split(appLogsAliases, ","),
 | 
						|
	// translators: Short description for `app logs` command
 | 
						|
	Short: i18n.G("Tail app logs"),
 | 
						|
	Args:  cobra.RangeArgs(1, 2),
 | 
						|
	ValidArgsFunction: func(
 | 
						|
		cmd *cobra.Command,
 | 
						|
		args []string,
 | 
						|
		toComplete string) ([]string, cobra.ShellCompDirective) {
 | 
						|
		switch l := len(args); l {
 | 
						|
		case 0:
 | 
						|
			return autocomplete.AppNameComplete()
 | 
						|
		case 1:
 | 
						|
			app, err := appPkg.Get(args[0])
 | 
						|
			if err != nil {
 | 
						|
				return []string{i18n.G("autocomplete failed: %s", err)}, cobra.ShellCompDirectiveError
 | 
						|
			}
 | 
						|
			return autocomplete.ServiceNameComplete(app.Name)
 | 
						|
		default:
 | 
						|
			return nil, cobra.ShellCompDirectiveDefault
 | 
						|
		}
 | 
						|
	},
 | 
						|
	Run: func(cmd *cobra.Command, args []string) {
 | 
						|
		app := internal.ValidateApp(args)
 | 
						|
		stackName := app.StackName()
 | 
						|
 | 
						|
		if err := app.Recipe.EnsureExists(); err != nil {
 | 
						|
			log.Fatal(err)
 | 
						|
		}
 | 
						|
 | 
						|
		cl, err := client.New(app.Server)
 | 
						|
		if err != nil {
 | 
						|
			log.Fatal(err)
 | 
						|
		}
 | 
						|
 | 
						|
		deployMeta, err := stack.IsDeployed(context.Background(), cl, stackName)
 | 
						|
		if err != nil {
 | 
						|
			log.Fatal(err)
 | 
						|
		}
 | 
						|
 | 
						|
		if !deployMeta.IsDeployed {
 | 
						|
			log.Fatal(i18n.G("%s is not deployed?", app.Name))
 | 
						|
		}
 | 
						|
 | 
						|
		var serviceNames []string
 | 
						|
		if len(args) == 2 {
 | 
						|
			serviceNames = []string{args[1]}
 | 
						|
		}
 | 
						|
 | 
						|
		f, err := app.Filters(true, false, serviceNames...)
 | 
						|
		if err != nil {
 | 
						|
			log.Fatal(err)
 | 
						|
		}
 | 
						|
 | 
						|
		opts := logs.TailOpts{
 | 
						|
			AppName:  app.Name,
 | 
						|
			Services: serviceNames,
 | 
						|
			StdErr:   stdErr,
 | 
						|
			Since:    sinceLogs,
 | 
						|
			Filters:  f,
 | 
						|
		}
 | 
						|
 | 
						|
		if err := logs.TailLogs(cl, opts); err != nil {
 | 
						|
			log.Fatal(err)
 | 
						|
		}
 | 
						|
	},
 | 
						|
}
 | 
						|
 | 
						|
var (
 | 
						|
	stdErr    bool
 | 
						|
	sinceLogs string
 | 
						|
)
 | 
						|
 | 
						|
func init() {
 | 
						|
	AppLogsCommand.Flags().BoolVarP(
 | 
						|
		&stdErr,
 | 
						|
		i18n.G("stderr"),
 | 
						|
		i18n.G("s"),
 | 
						|
		false,
 | 
						|
		i18n.G("only tail stderr"),
 | 
						|
	)
 | 
						|
 | 
						|
	AppLogsCommand.Flags().StringVarP(
 | 
						|
		&sinceLogs,
 | 
						|
		i18n.G("since"),
 | 
						|
		i18n.G("S"),
 | 
						|
		"",
 | 
						|
		i18n.G("tail logs since YYYY-MM-DDTHH:MM:SSZ"),
 | 
						|
	)
 | 
						|
}
 |