-
Notifications
You must be signed in to change notification settings - Fork 8
/
Copy pathmain.go
71 lines (57 loc) · 2.26 KB
/
main.go
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
/*
Copyright 2020 The cert-manager Authors.
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.
*/
package main
import (
"context"
"fmt"
"os"
"runtime"
"strings"
logf "github.com/cert-manager/cert-manager/pkg/logs"
cmdutil "k8s.io/kubectl/pkg/cmd/util"
ctrl "sigs.k8s.io/controller-runtime"
ctlcmd "github.com/cert-manager/cmctl/v2/cmd"
"github.com/cert-manager/cmctl/v2/internal/util"
"github.com/cert-manager/cmctl/v2/pkg/build"
)
func main() {
ctx, exit := util.SetupExitHandler(context.Background(), util.AlwaysErrCode)
defer exit() // This function might call os.Exit, so defer last
ctlName, isKubectlPlugin := build.DetectCtlInfo(os.Args)
logf.InitLogs()
defer logf.FlushLogs()
ctrl.SetLogger(logf.Log)
ctx = logf.NewContext(ctx, logf.Log, ctlName)
ctx = build.WithCtlInfo(ctx, ctlName, isKubectlPlugin)
// In cmctl, we are using cmdutil.CheckErr, a kubectl utility function that creates human readable
// error messages from errors. By default, this function will call os.Exit(1) if it receives an error.
// Instead, we want to do a soft exit, and use SetExitCode to set the correct exit code.
// Additionally, we make sure to output the final error message to stdout, as we do not want this
// message to be mixed with other log outputs from the execution of the command.
// To do this, we need to set a custom error handler.
cmdutil.BehaviorOnFatal(func(msg string, code int) {
if len(msg) > 0 {
// add newline if needed
if !strings.HasSuffix(msg, "\n") {
msg += "\n"
}
fmt.Fprint(os.Stdout, msg)
}
util.SetExitCodeValue(code)
runtime.Goexit() // Do soft exit (handle all defers, that should set correct exit code)
})
cmd := ctlcmd.NewCertManagerCtlCommand(ctx, os.Stdin, os.Stdout, os.Stderr)
if err := cmd.ExecuteContext(ctx); err != nil {
cmdutil.CheckErr(err)
}
}