2023-03-12 07:33:08 +00:00
|
|
|
//go:generate go install github.com/valyala/quicktemplate/qtc@latest
|
|
|
|
//go:generate qtc -dir=web
|
|
|
|
//go:generate go install golang.org/x/text/cmd/gotext@latest
|
|
|
|
//go:generate gotext -srclang=en update -out=catalog_gen.go -lang=en,ru
|
|
|
|
package main
|
|
|
|
|
|
|
|
import (
|
2023-03-13 22:19:53 +00:00
|
|
|
"context"
|
2023-03-12 07:33:08 +00:00
|
|
|
"embed"
|
|
|
|
"io/fs"
|
|
|
|
"log"
|
|
|
|
"net/http"
|
|
|
|
"os"
|
|
|
|
"path/filepath"
|
|
|
|
"time"
|
|
|
|
|
2023-12-19 00:08:50 +00:00
|
|
|
"github.com/caarlos0/env/v10"
|
2023-12-20 01:29:09 +00:00
|
|
|
"github.com/jmoiron/sqlx"
|
2023-03-12 07:33:08 +00:00
|
|
|
"golang.org/x/text/language"
|
|
|
|
"golang.org/x/text/message"
|
2023-12-20 01:29:09 +00:00
|
|
|
_ "modernc.org/sqlite"
|
2023-03-12 07:33:08 +00:00
|
|
|
|
|
|
|
"source.toby3d.me/toby3d/hub/internal/domain"
|
|
|
|
hubhttprelivery "source.toby3d.me/toby3d/hub/internal/hub/delivery/http"
|
|
|
|
hubucase "source.toby3d.me/toby3d/hub/internal/hub/usecase"
|
|
|
|
"source.toby3d.me/toby3d/hub/internal/middleware"
|
2023-12-20 01:29:09 +00:00
|
|
|
subscriptionsqliterepo "source.toby3d.me/toby3d/hub/internal/subscription/repository/sqlite"
|
2023-03-12 07:33:08 +00:00
|
|
|
subscriptionucase "source.toby3d.me/toby3d/hub/internal/subscription/usecase"
|
2023-12-20 01:29:09 +00:00
|
|
|
topicsqliterepo "source.toby3d.me/toby3d/hub/internal/topic/repository/sqlite"
|
2023-03-13 22:19:53 +00:00
|
|
|
topicucase "source.toby3d.me/toby3d/hub/internal/topic/usecase"
|
2023-03-12 07:33:08 +00:00
|
|
|
"source.toby3d.me/toby3d/hub/internal/urlutil"
|
|
|
|
)
|
|
|
|
|
2023-12-19 00:08:50 +00:00
|
|
|
var logger = log.New(os.Stdout, "hub\t", log.LstdFlags)
|
2023-03-12 07:33:08 +00:00
|
|
|
|
|
|
|
//go:embed web/static/*
|
|
|
|
var static embed.FS
|
|
|
|
|
|
|
|
func main() {
|
2023-03-13 22:19:53 +00:00
|
|
|
ctx := context.Background()
|
|
|
|
|
2023-12-20 01:29:09 +00:00
|
|
|
static, err := fs.Sub(static, filepath.Join("web"))
|
|
|
|
if err != nil {
|
|
|
|
logger.Fatalln(err)
|
|
|
|
}
|
|
|
|
|
2023-03-12 07:33:08 +00:00
|
|
|
config := new(domain.Config)
|
2023-12-20 01:29:09 +00:00
|
|
|
if err = env.ParseWithOptions(config, env.Options{
|
2023-03-15 00:20:52 +00:00
|
|
|
Prefix: "HUB_",
|
|
|
|
UseFieldNameByDefault: true,
|
|
|
|
}); err != nil {
|
2023-03-12 07:33:08 +00:00
|
|
|
logger.Fatalln(err)
|
|
|
|
}
|
|
|
|
|
2023-12-20 01:29:09 +00:00
|
|
|
db, err := sqlx.Open("sqlite", config.DB)
|
|
|
|
if err != nil {
|
|
|
|
logger.Fatalf("cannot open database on path %s: %s", config.DB, err)
|
|
|
|
}
|
|
|
|
|
|
|
|
topics, err := topicsqliterepo.NewSQLiteTopicRepository(db)
|
|
|
|
if err != nil {
|
|
|
|
logger.Fatalln(err)
|
|
|
|
}
|
|
|
|
|
|
|
|
subscriptions, err := subscriptionsqliterepo.NewSQLiteSubscriptionRepository(db)
|
2023-03-12 07:33:08 +00:00
|
|
|
if err != nil {
|
|
|
|
logger.Fatalln(err)
|
|
|
|
}
|
|
|
|
|
2023-03-13 22:19:53 +00:00
|
|
|
client := &http.Client{Timeout: 5 * time.Second}
|
2023-03-12 07:33:08 +00:00
|
|
|
matcher := language.NewMatcher(message.DefaultCatalog.Languages())
|
2023-03-13 22:19:53 +00:00
|
|
|
topicService := topicucase.NewTopicUseCase(topics, client)
|
|
|
|
subscriptionService := subscriptionucase.NewSubscriptionUseCase(subscriptions, topics, client)
|
|
|
|
hubService := hubucase.NewHubUseCase(topics, subscriptions, client, config.BaseURL)
|
|
|
|
|
|
|
|
handler := hubhttprelivery.NewHandler(hubhttprelivery.NewHandlerParams{
|
|
|
|
Hub: hubService,
|
|
|
|
Subscriptions: subscriptionService,
|
|
|
|
Topics: topicService,
|
2023-03-12 07:33:08 +00:00
|
|
|
Matcher: matcher,
|
|
|
|
Name: config.Name,
|
|
|
|
})
|
|
|
|
|
|
|
|
server := &http.Server{
|
2023-03-13 22:19:53 +00:00
|
|
|
Addr: config.Bind,
|
2023-03-12 07:33:08 +00:00
|
|
|
Handler: http.HandlerFunc(middleware.HandlerFunc(func(w http.ResponseWriter, r *http.Request) {
|
|
|
|
head, _ := urlutil.ShiftPath(r.URL.Path)
|
|
|
|
|
|
|
|
switch head {
|
|
|
|
case "":
|
2023-03-13 22:19:53 +00:00
|
|
|
handler.ServeHTTP(w, r)
|
2023-03-12 07:33:08 +00:00
|
|
|
case "static":
|
|
|
|
http.FileServer(http.FS(static)).ServeHTTP(w, r)
|
|
|
|
}
|
|
|
|
}).Intercept(middleware.LogFmt())),
|
2023-03-13 22:19:53 +00:00
|
|
|
ReadTimeout: 5 * time.Second,
|
|
|
|
WriteTimeout: 5 * time.Second,
|
2023-03-12 07:33:08 +00:00
|
|
|
ErrorLog: logger,
|
|
|
|
}
|
|
|
|
|
2023-03-13 22:19:53 +00:00
|
|
|
go hubService.ListenAndServe(ctx)
|
|
|
|
|
2023-03-14 23:17:14 +00:00
|
|
|
logger.Printf("started %s on %s: %s", config.Name, config.Bind, config.BaseURL.String())
|
2023-03-12 07:33:08 +00:00
|
|
|
if err = server.ListenAndServe(); err != nil {
|
|
|
|
logger.Fatalln(err)
|
|
|
|
}
|
|
|
|
}
|