Always log version at startup.
[lightning.git] / cmd.go
1 // Copyright (C) The Lightning Authors. All rights reserved.
2 //
3 // SPDX-License-Identifier: AGPL-3.0
4
5 package lightning
6
7 import (
8         "fmt"
9         "io"
10         "io/ioutil"
11         "os"
12         "os/exec"
13         "strings"
14
15         "git.arvados.org/arvados.git/lib/cmd"
16         "github.com/mattn/go-isatty"
17         "github.com/sirupsen/logrus"
18 )
19
20 var (
21         handler = cmd.Multi(map[string]cmd.Handler{
22                 "version":   cmd.Version,
23                 "-version":  cmd.Version,
24                 "--version": cmd.Version,
25
26                 "ref2genome":         &ref2genome{},
27                 "vcf2fasta":          &vcf2fasta{},
28                 "import":             &importer{},
29                 "annotate":           &annotatecmd{},
30                 "export":             &exporter{},
31                 "export-numpy":       &exportNumpy{},
32                 "flake":              &flakecmd{},
33                 "slice":              &slicecmd{},
34                 "numpy-comvar":       &numpyComVar{},
35                 "filter":             &filtercmd{},
36                 "build-docker-image": &buildDockerImage{},
37                 "pca-go":             &goPCA{},
38                 "pca-py":             &pythonPCA{},
39                 "plot":               &pythonPlot{},
40                 "diff-fasta":         &diffFasta{},
41                 "stats":              &statscmd{},
42                 "merge":              &merger{},
43                 "dumpgob":            &dumpGob{},
44         })
45 )
46
47 func Main() {
48         if !isatty.IsTerminal(os.Stderr.Fd()) {
49                 logrus.StandardLogger().Formatter = &logrus.TextFormatter{DisableTimestamp: true}
50         }
51         if len(os.Args) >= 2 && !strings.HasSuffix(os.Args[1], "version") {
52                 cmd.Version.RunCommand("lightning", nil, nil, os.Stderr, os.Stderr)
53         }
54         os.Exit(handler.RunCommand(os.Args[0], os.Args[1:], os.Stdin, os.Stdout, os.Stderr))
55 }
56
57 type buildDockerImage struct{}
58
59 func (cmd *buildDockerImage) RunCommand(prog string, args []string, stdin io.Reader, stdout, stderr io.Writer) int {
60         tmpdir, err := ioutil.TempDir("", "")
61         if err != nil {
62                 fmt.Fprint(stderr, err)
63                 return 1
64         }
65         defer os.RemoveAll(tmpdir)
66         err = ioutil.WriteFile(tmpdir+"/Dockerfile", []byte(`FROM debian:bullseye
67 RUN DEBIAN_FRONTEND=noninteractive \
68   apt-get update && \
69   apt-get dist-upgrade -y && \
70   apt-get install -y --no-install-recommends bcftools bedtools samtools python2 python3-sklearn python3-matplotlib ca-certificates && \
71   apt-get clean
72 `), 0644)
73         if err != nil {
74                 fmt.Fprint(stderr, err)
75                 return 1
76         }
77         docker := exec.Command("docker", "build", "--tag=lightning-runtime", tmpdir)
78         docker.Stdout = stdout
79         docker.Stderr = stderr
80         err = docker.Run()
81         if err != nil {
82                 return 1
83         }
84         fmt.Fprintf(stderr, "built and tagged new docker image, lightning-runtime\n")
85         return 0
86 }