2024-05-10 04:14:40 +00:00
|
|
|
package main
|
|
|
|
|
2024-05-11 02:54:51 +00:00
|
|
|
import (
|
|
|
|
"context"
|
2024-11-02 01:13:21 +00:00
|
|
|
"fmt"
|
2024-05-11 02:54:51 +00:00
|
|
|
"log"
|
|
|
|
"net"
|
|
|
|
"net/http"
|
|
|
|
"os"
|
|
|
|
"os/signal"
|
2024-09-28 17:39:03 +00:00
|
|
|
"path/filepath"
|
2024-05-11 02:54:51 +00:00
|
|
|
"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-11 02:54:51 +00:00
|
|
|
)
|
|
|
|
|
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
|
|
|
|
|
2024-11-02 01:13:21 +00:00
|
|
|
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()
|
|
|
|
}
|
|
|
|
|
2024-05-11 02:54:51 +00:00
|
|
|
if err != nil {
|
2024-11-02 01:13:21 +00:00
|
|
|
fmt.Println(err.Error())
|
2024-05-11 02:54:51 +00:00
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2024-09-28 17:39:03 +00:00
|
|
|
func run_cli(args ...string) error {
|
2024-11-02 01:13:21 +00:00
|
|
|
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))
|
2024-05-11 02:54:51 +00:00
|
|
|
if err != nil {
|
|
|
|
return err
|
|
|
|
}
|
|
|
|
|
2024-05-19 20:42:28 +00:00
|
|
|
bbsServer := server.New()
|
2024-05-11 02:54:51 +00:00
|
|
|
s := &http.Server{
|
2024-05-19 20:42:28 +00:00
|
|
|
Handler: bbsServer,
|
2024-05-11 02:54:51 +00:00
|
|
|
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
|
|
|
}
|