Albirew/nyaa-pantsu
Archivé
1
0
Bifurcation 0
Ce dépôt a été archivé le 2022-05-07. Vous pouvez voir ses fichiers ou le cloner, mais pas ouvrir de ticket ou de demandes d'ajout, ni soumettre de changements.
nyaa-pantsu/main.go

179 lignes
4,2 Kio
Go
Brut Vue normale Historique

2017-05-02 12:39:53 +02:00
package main
import (
"bufio"
"flag"
2017-05-10 19:29:35 +02:00
"context"
"net/http"
"os"
"time"
2017-05-09 17:07:42 +02:00
2017-05-17 07:58:40 +02:00
"github.com/NyaaPantsu/nyaa/cache"
"github.com/NyaaPantsu/nyaa/config"
"github.com/NyaaPantsu/nyaa/db"
"github.com/NyaaPantsu/nyaa/network"
"github.com/NyaaPantsu/nyaa/router"
"github.com/NyaaPantsu/nyaa/service/scraper"
"github.com/NyaaPantsu/nyaa/service/torrent/metainfoFetcher"
"github.com/NyaaPantsu/nyaa/service/user"
"github.com/NyaaPantsu/nyaa/util/log"
"github.com/NyaaPantsu/nyaa/util/publicSettings"
2017-05-17 07:58:40 +02:00
"github.com/NyaaPantsu/nyaa/util/search"
"github.com/NyaaPantsu/nyaa/util/signals"
2017-05-02 12:39:53 +02:00
)
var buildversion string
2017-05-10 19:29:35 +02:00
// RunServer runs webapp mainloop
func RunServer(conf *config.Config) {
// TODO Use config from cli
os.Mkdir(router.DatabaseDumpPath, 700)
// TODO Use config from cli
os.Mkdir(router.GPGPublicKeyPath, 700)
http.Handle("/", router.CSRFRouter)
2017-05-02 12:39:53 +02:00
// Set up server,
srv := &http.Server{
WriteTimeout: 30 * time.Second,
ReadTimeout: 10 * time.Second,
2017-05-02 12:39:53 +02:00
}
2017-05-07 21:51:37 +02:00
l, err := network.CreateHTTPListener(conf)
log.CheckError(err)
if err != nil {
return
}
log.Infof("listening on %s", l.Addr())
// http.Server.Shutdown closes associated listeners/clients.
// context.Background causes srv to indefinitely try to
// gracefully shutdown. add a timeout if this becomes a problem.
signals.OnInterrupt(func() {
srv.Shutdown(context.Background())
})
err = srv.Serve(l)
2017-05-07 21:51:37 +02:00
if err == nil {
log.Panic("http.Server.Serve never returns nil")
2017-05-07 21:51:37 +02:00
}
if err == http.ErrServerClosed {
return
}
log.CheckError(err)
2017-05-02 12:39:53 +02:00
}
2017-05-10 19:29:35 +02:00
// RunScraper runs tracker scraper mainloop
func RunScraper(conf *config.Config) {
// bind to network
pc, err := network.CreateScraperSocket(conf)
if err != nil {
log.Fatalf("failed to bind udp socket for scraper: %s", err)
}
// configure tracker scraperv
var scraper *scraperService.Scraper
scraper, err = scraperService.New(&conf.Scrape)
if err != nil {
pc.Close()
log.Fatalf("failed to configure scraper: %s", err)
}
workers := conf.Scrape.NumWorkers
if workers < 1 {
workers = 1
}
signals.OnInterrupt(func() {
pc.Close()
scraper.Close()
})
2017-05-10 19:29:35 +02:00
// run udp scraper worker
for workers > 0 {
log.Infof("starting up worker %d", workers)
2017-05-10 19:29:35 +02:00
go scraper.RunWorker(pc)
workers--
}
// run scraper
go scraper.Run()
scraper.Wait()
}
2017-05-14 13:20:34 +02:00
// RunMetainfoFetcher runs the database filesize fetcher main loop
func RunMetainfoFetcher(conf *config.Config) {
fetcher, err := metainfoFetcher.New(&conf.MetainfoFetcher)
2017-05-13 19:58:48 +02:00
if err != nil {
log.Fatalf("failed to start fetcher, %s", err)
return
}
signals.OnInterrupt(func() {
fetcher.Close()
})
2017-05-13 21:07:39 +02:00
fetcher.RunAsync()
fetcher.Wait()
2017-05-13 19:58:48 +02:00
}
func main() {
conf := config.Conf
if buildversion != "" {
conf.Build = buildversion
} else {
conf.Build = "unknown"
}
processFlags := conf.BindFlags()
defaults := flag.Bool("print-defaults", false, "print the default configuration file on stdout")
2017-05-17 00:47:55 +02:00
mode := flag.String("mode", "webapp", "which mode to run daemon in, either webapp, scraper or metainfo_fetcher")
flag.Float64Var(&conf.Cache.Size, "c", config.Conf.Cache.Size, "size of the search cache in MB")
flag.Parse()
if *defaults {
stdout := bufio.NewWriter(os.Stdout)
err := conf.Pretty(stdout)
if err != nil {
log.Fatal(err.Error())
}
err = stdout.Flush()
if err != nil {
log.Fatal(err.Error())
}
os.Exit(0)
} else {
err := processFlags()
2017-05-06 20:27:26 +02:00
if err != nil {
log.CheckError(err)
}
db.ORM, err = db.GormInit(conf, db.DefaultLogger)
2017-05-09 19:23:21 +02:00
if err != nil {
log.Fatal(err.Error())
}
db.ElasticSearchClient, _ = db.ElasticSearchInit()
err = publicSettings.InitI18n(conf.I18n, userService.NewCurrentUserRetriever())
if err != nil {
log.Fatal(err.Error())
}
err = cache.Configure(&conf.Cache)
if err != nil {
log.Fatal(err.Error())
}
err = search.Configure(&conf.Search)
2017-05-11 15:01:53 +02:00
if err != nil {
log.Fatal(err.Error())
}
signals.Handle()
if len(config.Conf.Torrents.FileStorage) > 0 {
err := os.MkdirAll(config.Conf.Torrents.FileStorage, 0700)
if err != nil {
log.Fatal(err.Error())
}
}
2017-05-10 19:29:35 +02:00
if *mode == "scraper" {
RunScraper(conf)
} else if *mode == "webapp" {
RunServer(conf)
2017-05-14 13:20:34 +02:00
} else if *mode == "metainfo_fetcher" {
RunMetainfoFetcher(conf)
2017-05-10 19:29:35 +02:00
} else {
log.Fatalf("invalid runtime mode: %s", *mode)
}
}
}