logout: add support of logout flow
This commit is contained in:
@ -3,8 +3,6 @@ Copyright (C) JSC iCore - All Rights Reserved
|
||||
|
||||
Unauthorized copying of this file, via any medium is strictly prohibited
|
||||
Proprietary and confidential
|
||||
|
||||
Written by Konstantin Lepa <klepa@i-core.ru>, July 2018
|
||||
*/
|
||||
|
||||
package main // import "gopkg.i-core.ru/werther/cmd/werther"
|
||||
@ -15,17 +13,35 @@ import (
|
||||
"net/http"
|
||||
"os"
|
||||
|
||||
"github.com/justinas/nosurf"
|
||||
"github.com/kelseyhightower/envconfig"
|
||||
"go.uber.org/zap"
|
||||
"gopkg.i-core.ru/werther/internal/server"
|
||||
"gopkg.i-core.ru/httputil"
|
||||
"gopkg.i-core.ru/logutil"
|
||||
"gopkg.i-core.ru/werther/internal/identp"
|
||||
"gopkg.i-core.ru/werther/internal/ldapclient"
|
||||
"gopkg.i-core.ru/werther/internal/stat"
|
||||
"gopkg.i-core.ru/werther/internal/web"
|
||||
)
|
||||
|
||||
// Version will be filled at compile time.
|
||||
var Version = ""
|
||||
|
||||
// Config is a server's configuration.
|
||||
type Config struct {
|
||||
DevMode bool `envconfig:"dev_mode" default:"false" desc:"a development mode"`
|
||||
Listen string `default:":8080" desc:"a host and port to listen on (<host>:<port>)"`
|
||||
Web web.Config
|
||||
Identp identp.Config
|
||||
LDAP ldapclient.Config
|
||||
}
|
||||
|
||||
func main() {
|
||||
flag.Usage = func() {
|
||||
fmt.Fprintf(flag.CommandLine.Output(), "Usage of %s:\n", os.Args[0])
|
||||
flag.PrintDefaults()
|
||||
fmt.Fprintf(flag.CommandLine.Output(), "\n")
|
||||
if err := envconfig.Usagef("werther", &server.Config{}, flag.CommandLine.Output(), envconfig.DefaultListFormat); err != nil {
|
||||
if err := envconfig.Usagef("werther", &Config{}, flag.CommandLine.Output(), envconfig.DefaultListFormat); err != nil {
|
||||
panic(err)
|
||||
}
|
||||
}
|
||||
@ -33,11 +49,11 @@ func main() {
|
||||
flag.Parse()
|
||||
|
||||
if *verflag {
|
||||
fmt.Println("werther", server.Version)
|
||||
fmt.Println("werther", Version)
|
||||
os.Exit(0)
|
||||
}
|
||||
|
||||
var cnf server.Config
|
||||
var cnf Config
|
||||
if err := envconfig.Process("werther", &cnf); err != nil {
|
||||
fmt.Fprintf(os.Stderr, "Invalid configuration: %s\n", err)
|
||||
os.Exit(1)
|
||||
@ -53,13 +69,20 @@ func main() {
|
||||
os.Exit(1)
|
||||
}
|
||||
|
||||
srv, err := server.New(cnf, log)
|
||||
htmlRenderer, err := web.NewHTMLRenderer(cnf.Web)
|
||||
if err != nil {
|
||||
fmt.Fprintf(os.Stderr, "Failed to start the server: %s\n", err)
|
||||
os.Exit(1)
|
||||
}
|
||||
|
||||
ldap := ldapclient.New(cnf.LDAP)
|
||||
|
||||
router := httputil.NewRouter(nosurf.NewPure, logutil.RequestLog(log))
|
||||
router.AddRoutes(web.NewStaticHandler(cnf.Web), "/static")
|
||||
router.AddRoutes(identp.NewHandler(cnf.Identp, ldap, htmlRenderer), "/auth")
|
||||
router.AddRoutes(stat.NewHandler(Version), "/stat")
|
||||
|
||||
log = log.Named("main")
|
||||
log.Info("Werther started", zap.Any("config", cnf), zap.String("version", server.Version))
|
||||
log.Fatal("Werther finished", zap.Error(http.ListenAndServe(cnf.Listen, srv)))
|
||||
log.Info("Werther started", zap.Any("config", cnf), zap.String("version", Version))
|
||||
log.Fatal("Werther finished", zap.Error(http.ListenAndServe(cnf.Listen, router)))
|
||||
}
|
||||
|
@ -5,8 +5,6 @@ Copyright (C) JSC iCore - All Rights Reserved
|
||||
|
||||
Unauthorized copying of this file, via any medium is strictly prohibited
|
||||
Proprietary and confidential
|
||||
|
||||
Written by Konstantin Lepa <klepa@i-core.ru>, February 2019
|
||||
*/
|
||||
|
||||
package main
|
||||
|
Reference in New Issue
Block a user