khatru-pyramid/main.go

70 lines
1.9 KiB
Go
Raw Normal View History

2023-09-06 20:49:18 +02:00
package main
import (
"net/http"
"os"
"github.com/fiatjaf/khatru"
"github.com/fiatjaf/khatru/plugins/storage/badgern"
2023-10-16 23:09:12 -03:00
"github.com/kelseyhightower/envconfig"
"github.com/rs/zerolog"
2023-09-06 20:49:18 +02:00
)
2023-10-16 23:09:12 -03:00
type Settings struct {
2023-10-18 11:58:09 -03:00
Port string `envconfig:"PORT" default:"3334"`
2023-10-16 23:09:12 -03:00
RelayName string `envconfig:"RELAY_NAME" required:"true"`
RelayPubkey string `envconfig:"RELAY_PUBKEY" required:"true"`
RelayDescription string `envconfig:"RELAY_DESCRIPTION"`
RelayContact string `envconfig:"RELAY_CONTACT"`
}
var (
2023-10-16 23:09:12 -03:00
db badgern.BadgerBackend
s Settings
log = zerolog.New(os.Stderr).Output(zerolog.ConsoleWriter{Out: os.Stdout}).With().Timestamp().Logger()
)
2023-09-13 19:48:24 +02:00
2023-09-06 20:49:18 +02:00
func main() {
2023-10-16 23:09:12 -03:00
err := envconfig.Process("", &s)
if err != nil {
log.Fatal().Err(err).Msg("couldn't process envconfig")
return
}
2023-09-06 20:49:18 +02:00
// init relay
relay := khatru.NewRelay()
2023-10-16 23:09:12 -03:00
relay.Name = s.RelayName
relay.PubKey = s.RelayPubkey
relay.Description = s.RelayDescription
relay.Contact = s.RelayContact
2023-09-13 19:48:24 +02:00
2023-09-06 20:49:18 +02:00
// load whitelist storage
if err := loadWhitelist(); err != nil {
panic(err)
}
// load db
2023-09-18 19:18:24 +00:00
db = badgern.BadgerBackend{Path: "./khatru-badgern-db"}
2023-09-06 20:49:18 +02:00
if err := db.Init(); err != nil {
panic(err)
}
relay.StoreEvent = append(relay.StoreEvent, db.SaveEvent)
relay.QueryEvents = append(relay.QueryEvents, db.QueryEvents)
relay.CountEvents = append(relay.CountEvents, db.CountEvents)
relay.DeleteEvent = append(relay.DeleteEvent, db.DeleteEvent)
relay.RejectEvent = append(relay.RejectEvent, whitelistRejecter)
relay.Router().HandleFunc("/reports", reportsViewerHandler)
2023-10-28 20:21:15 -03:00
relay.Router().HandleFunc("/add-to-whitelist", addToWhitelistHandler)
relay.Router().HandleFunc("/remove-from-whitelist", removeFromWhitelistHandler)
relay.Router().HandleFunc("/users", inviteTreeHandler)
2023-10-18 11:58:09 -03:00
relay.Router().HandleFunc("/", homePageHandler)
2023-09-06 20:49:18 +02:00
2023-10-18 11:58:09 -03:00
log.Info().Msg("running on http://0.0.0.0:" + s.Port)
if err := http.ListenAndServe(":"+s.Port, relay); err != nil {
log.Fatal().Err(err).Msg("failed to serve")
}
2023-09-06 20:49:18 +02:00
}