underbbs/underbbs.go

74 lines
1.2 KiB
Go
Raw Normal View History

2024-05-10 04:14:40 +00:00
package main
import (
"context"
"fmt"
"log"
"net"
"net/http"
"os"
"os/signal"
2024-09-28 17:39:03 +00:00
"path/filepath"
"strconv"
"time"
2024-05-19 20:42:28 +00:00
2024-12-07 02:30:41 +00:00
"forge.lightcrystal.systems/nilix/underbbs/cli"
"forge.lightcrystal.systems/nilix/underbbs/server"
)
2024-05-10 04:14:40 +00:00
func main() {
2024-09-28 17:39:03 +00:00
args := os.Args
var err error = nil
progname := filepath.Base(args[0])
switch progname {
2024-09-28 17:39:03 +00:00
case "underbbs-cli":
err = run_cli(args[1:]...)
default:
err = run_srvr()
}
if err != nil {
fmt.Println(err.Error())
}
}
2024-09-28 17:39:03 +00:00
func run_cli(args ...string) error {
return cli.Process(args...)
2024-09-28 17:39:03 +00:00
}
func run_srvr() error {
2024-05-19 20:42:28 +00:00
l, err := net.Listen("tcp", ":"+strconv.FormatInt(int64(9090), 10))
if err != nil {
return err
}
2024-05-19 20:42:28 +00:00
bbsServer := server.New()
s := &http.Server{
2024-05-19 20:42:28 +00:00
Handler: bbsServer,
ReadTimeout: time.Second * 10,
WriteTimeout: time.Second * 10,
}
errc := make(chan error, 1)
go func() {
errc <- s.Serve(l)
}()
sigs := make(chan os.Signal, 1)
signal.Notify(sigs, os.Interrupt)
select {
case err := <-errc:
log.Printf("failed to serve: %v", err)
case sig := <-sigs:
log.Printf("terminating: %v", sig)
}
ctx, cancel := context.WithTimeout(context.Background(), time.Second*10)
defer cancel()
return s.Shutdown(ctx)
2024-05-10 04:14:40 +00:00
}