You can not select more than 25 topics
Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
59 lines
1.4 KiB
59 lines
1.4 KiB
package main
|
|
|
|
import (
|
|
"log"
|
|
"os"
|
|
"os/signal"
|
|
|
|
"github.com/shiena/ansicolor"
|
|
"github.com/sirupsen/logrus"
|
|
"github.com/spf13/viper"
|
|
|
|
"github.com/maxibanki/golang-url-shortener/handlers"
|
|
"github.com/maxibanki/golang-url-shortener/store"
|
|
"github.com/maxibanki/golang-url-shortener/util"
|
|
"github.com/pkg/errors"
|
|
)
|
|
|
|
func main() {
|
|
stop := make(chan os.Signal, 1)
|
|
signal.Notify(stop, os.Interrupt)
|
|
logrus.SetFormatter(&logrus.TextFormatter{
|
|
ForceColors: true,
|
|
})
|
|
logrus.SetOutput(ansicolor.NewAnsiColorWriter(os.Stdout))
|
|
close, err := initShortener()
|
|
if err != nil {
|
|
logrus.Fatalf("could not init shortener: %v", err)
|
|
}
|
|
<-stop
|
|
logrus.Println("Shutting down...")
|
|
close()
|
|
}
|
|
|
|
func initShortener() (func(), error) {
|
|
if err := util.ReadInConfig(); err != nil {
|
|
return nil, errors.Wrap(err, "could not reload config file")
|
|
}
|
|
if viper.GetBool("General.EnableDebugMode") {
|
|
logrus.SetLevel(logrus.DebugLevel)
|
|
}
|
|
store, err := store.New()
|
|
if err != nil {
|
|
return nil, errors.Wrap(err, "could not create store")
|
|
}
|
|
handler, err := handlers.New(*store, false)
|
|
if err != nil {
|
|
return nil, errors.Wrap(err, "could not create handlers")
|
|
}
|
|
go func() {
|
|
if err := handler.Listen(); err != nil {
|
|
log.Fatalf("could not listen to http handlers: %v", err)
|
|
}
|
|
}()
|
|
return func() {
|
|
if err = handler.CloseStore(); err != nil {
|
|
log.Printf("failed to stop the handlers: %v", err)
|
|
}
|
|
}, nil
|
|
}
|
|
|