45 lines
		
	
	
		
			1016 B
		
	
	
	
		
			Go
		
	
	
	
	
	
			
		
		
	
	
			45 lines
		
	
	
		
			1016 B
		
	
	
	
		
			Go
		
	
	
	
	
	
| //3456789112345676892123456789312345678941234567895123456789612345678971234567898
 | |
| package main
 | |
| 
 | |
| import "os"
 | |
| import "time"
 | |
| import "github.com/rs/zerolog"
 | |
| import "github.com/rs/zerolog/log"
 | |
| import "golang.org/x/crypto/ssh/terminal"
 | |
| 
 | |
| var Version string
 | |
| var Buildtime string
 | |
| var Builduser string
 | |
| var Buildarch string
 | |
| var Appname string = "pooteeweet"
 | |
| 
 | |
| func main() {
 | |
| 	initLogging()
 | |
| 	identify()
 | |
| 	serve()
 | |
| }
 | |
| 
 | |
| func identify() {
 | |
| 	log.Info().
 | |
| 		Str("app", Appname).
 | |
| 		Str("version", Version).
 | |
| 		Str("buildarch", Buildarch).
 | |
| 		Str("buildtime", Buildtime).
 | |
| 		Str("builduser", Builduser).
 | |
| 		Msg("starting")
 | |
| }
 | |
| 
 | |
| func initLogging() {
 | |
| 	log.Logger = log.With().Caller().Stack().Logger()
 | |
| 
 | |
| 	if terminal.IsTerminal(int(os.Stdout.Fd())) {
 | |
| 		output := zerolog.ConsoleWriter{Out: os.Stdout, TimeFormat: time.RFC3339}
 | |
| 		log.Logger = zerolog.New(output).With().Caller().Stack().Logger().With().Timestamp().Logger()
 | |
| 	}
 | |
| 
 | |
| 	zerolog.SetGlobalLevel(zerolog.InfoLevel)
 | |
| 	if os.Getenv("DEBUG") != "" {
 | |
| 		zerolog.SetGlobalLevel(zerolog.DebugLevel)
 | |
| 	}
 | |
| }
 |