147 lines
3.3 KiB
Go
Raw Normal View History

2015-03-25 08:16:52 +01:00
// Copyright (C) 2014-2015 Jakob Borg and Contributors (see the CONTRIBUTORS file).
2014-06-01 22:50:14 +02:00
2013-12-22 21:35:05 -05:00
package main
import (
2015-09-13 11:44:33 +02:00
"crypto/tls"
2015-03-25 08:16:52 +01:00
"database/sql"
2014-02-20 17:40:15 +01:00
"flag"
"fmt"
2013-12-22 21:35:05 -05:00
"log"
2014-02-20 17:40:15 +01:00
"os"
"runtime"
"strconv"
"time"
2013-12-22 21:35:05 -05:00
"github.com/syncthing/syncthing/lib/protocol"
"github.com/syncthing/syncthing/lib/tlsutil"
2015-03-25 08:16:52 +01:00
"github.com/thejerf/suture"
2013-12-22 21:35:05 -05:00
)
2015-11-13 10:14:19 +01:00
const (
minNegCache = 60 // seconds
maxNegCache = 3600 // seconds
maxDeviceAge = 7 * 86400 // one week, in seconds
)
var (
Version string
BuildStamp string
BuildUser string
BuildHost string
BuildDate time.Time
LongVersion string
)
func init() {
stamp, _ := strconv.Atoi(BuildStamp)
BuildDate = time.Unix(int64(stamp), 0)
date := BuildDate.UTC().Format("2006-01-02 15:04:05 MST")
LongVersion = fmt.Sprintf(`stdiscosrv %s (%s %s-%s) %s@%s %s`, Version, runtime.Version(), runtime.GOOS, runtime.GOARCH, BuildUser, BuildHost, date)
}
2013-12-22 21:35:05 -05:00
var (
2015-03-25 08:16:52 +01:00
lruSize = 10240
limitAvg = 5
limitBurst = 20
globalStats stats
2015-05-31 13:31:28 +02:00
statsFile string
2015-07-21 23:56:27 +01:00
backend = "ql"
dsn = getEnvDefault("STDISCOSRV_DB_DSN", "memory://stdiscosrv")
2015-09-13 11:44:33 +02:00
certFile = "cert.pem"
keyFile = "key.pem"
debug = false
useHTTP = false
2013-12-22 21:35:05 -05:00
)
func main() {
2015-03-25 08:16:52 +01:00
const (
cleanIntv = 1 * time.Hour
statsIntv = 5 * time.Minute
)
2014-02-20 17:40:15 +01:00
var listen string
2015-03-25 08:16:52 +01:00
log.SetOutput(os.Stdout)
log.SetFlags(0)
2014-02-20 17:40:15 +01:00
2015-09-13 11:44:33 +02:00
flag.StringVar(&listen, "listen", ":8443", "Listen address")
2014-06-27 22:39:03 +02:00
flag.IntVar(&lruSize, "limit-cache", lruSize, "Limiter cache entries")
flag.IntVar(&limitAvg, "limit-avg", limitAvg, "Allowed average package rate, per 10 s")
flag.IntVar(&limitBurst, "limit-burst", limitBurst, "Allowed burst size, packets")
2015-05-31 13:31:28 +02:00
flag.StringVar(&statsFile, "stats-file", statsFile, "File to write periodic operation stats to")
2015-07-21 23:56:27 +01:00
flag.StringVar(&backend, "db-backend", backend, "Database backend to use")
flag.StringVar(&dsn, "db-dsn", dsn, "Database DSN")
2015-09-13 11:44:33 +02:00
flag.StringVar(&certFile, "cert", certFile, "Certificate file")
flag.StringVar(&keyFile, "key", keyFile, "Key file")
flag.BoolVar(&debug, "debug", debug, "Debug")
flag.BoolVar(&useHTTP, "http", useHTTP, "Listen on HTTP (behind an HTTPS proxy)")
2014-02-20 17:40:15 +01:00
flag.Parse()
log.Println(LongVersion)
var cert tls.Certificate
var err error
if !useHTTP {
cert, err = tls.LoadX509KeyPair(certFile, keyFile)
if err != nil {
log.Println("Failed to load keypair. Generating one, this might take a while...")
cert, err = tlsutil.NewCertificate(certFile, keyFile, "stdiscosrv", 3072)
if err != nil {
log.Fatalln("Failed to generate X509 key pair:", err)
}
}
2013-12-22 21:35:05 -05:00
devID := protocol.NewDeviceID(cert.Certificate[0])
log.Println("Server device ID is", devID)
}
2015-07-21 23:56:27 +01:00
db, err := sql.Open(backend, dsn)
2014-09-08 11:48:26 +02:00
if err != nil {
2015-07-21 23:56:27 +01:00
log.Fatalln("sql.Open:", err)
2014-09-08 11:48:26 +02:00
}
2015-07-21 23:56:27 +01:00
prep, err := setup(backend, db)
2014-09-08 11:48:26 +02:00
if err != nil {
2015-03-25 08:16:52 +01:00
log.Fatalln("Setup:", err)
2014-04-19 23:14:56 +02:00
}
2015-03-25 08:16:52 +01:00
main := suture.NewSimple("main")
2014-04-03 23:38:32 +02:00
2015-03-25 08:16:52 +01:00
main.Add(&querysrv{
2015-09-13 11:44:33 +02:00
addr: listen,
cert: cert,
2015-03-25 08:16:52 +01:00
db: db,
prep: prep,
})
2014-04-03 23:38:32 +02:00
2015-03-25 08:16:52 +01:00
main.Add(&cleansrv{
intv: cleanIntv,
db: db,
prep: prep,
})
2014-04-03 23:38:32 +02:00
2015-03-25 08:16:52 +01:00
main.Add(&statssrv{
intv: statsIntv,
2015-05-31 13:31:28 +02:00
file: statsFile,
db: db,
2015-03-25 08:16:52 +01:00
})
2013-12-22 21:35:05 -05:00
2015-03-25 08:16:52 +01:00
globalStats.Reset()
main.Serve()
2014-04-03 22:44:40 +02:00
}
2014-02-20 17:40:15 +01:00
2015-03-25 08:16:52 +01:00
func getEnvDefault(key, def string) string {
if val := os.Getenv(key); val != "" {
return val
}
2015-03-25 08:16:52 +01:00
return def
2014-04-03 22:44:40 +02:00
}
2015-03-25 08:16:52 +01:00
func next(intv time.Duration) time.Duration {
2014-04-19 23:14:56 +02:00
t0 := time.Now()
2015-03-25 08:16:52 +01:00
t1 := t0.Add(intv).Truncate(intv)
return t1.Sub(t0)
2014-09-08 11:48:26 +02:00
}