Skip to content

Commit

Permalink
feat: use db
Browse files Browse the repository at this point in the history
  • Loading branch information
im-adithya committed Feb 16, 2024
1 parent 9f45cdf commit d5b3a12
Show file tree
Hide file tree
Showing 11 changed files with 332 additions and 114 deletions.
78 changes: 30 additions & 48 deletions cmd/server/main.go
Original file line number Diff line number Diff line change
@@ -1,72 +1,54 @@
package main

import (
"context"
"fmt"
"net/http"
"time"

"http-nostr/internal/nostr"
"time"

"github.com/joho/godotenv"
"github.com/kelseyhightower/envconfig"
echologrus "github.com/davrux/echo-logrus/v4"
"github.com/labstack/echo/v4"
"github.com/sirupsen/logrus"
ddEcho "gopkg.in/DataDog/dd-trace-go.v1/contrib/labstack/echo.v4"
"gopkg.in/DataDog/dd-trace-go.v1/ddtrace/tracer"

"github.com/getsentry/sentry-go"
)


func main() {
logrus.SetFormatter(&logrus.JSONFormatter{})
// Load env file as env variables
err := godotenv.Load(".env")
ctx := context.Background()
svc, err := nostr.NewService(ctx)
if err != nil {
logrus.Errorf("Error loading environment variables: %v", err)
}
//load global config
type config struct {
SentryDSN string `envconfig:"SENTRY_DSN"`
DatadogAgentUrl string `envconfig:"DATADOG_AGENT_URL"`
DefaultRelayURL string `envconfig:"DEFAULT_RELAY_URL"`
Port int `default:"8080"`
}
globalConf := &config{}
err = envconfig.Process("", globalConf)
if err != nil {
logrus.Fatal(err)
}

// Setup exception tracking with Sentry if configured
if globalConf.SentryDSN != "" {
if err = sentry.Init(sentry.ClientOptions{
Dsn: globalConf.SentryDSN,
IgnoreErrors: []string{"401"},
}); err != nil {
logrus.Errorf("sentry init error: %v", err)
}
defer sentry.Flush(2 * time.Second)
logrus.Fatalf("Failed to initialize service: %v", err)
}

echologrus.Logger = svc.Logger
e := echo.New()
if globalConf.DatadogAgentUrl != "" {
tracer.Start(tracer.WithAgentAddr(globalConf.DatadogAgentUrl))
if svc.Cfg.DatadogAgentUrl != "" {
tracer.Start(tracer.WithAgentAddr(svc.Cfg.DatadogAgentUrl))
defer tracer.Stop()
e.Use(ddEcho.Middleware(ddEcho.WithServiceName("http-nostr")))
}

service, err := nostr.NewNostrService(&nostr.Config{
DefaultRelayURL: globalConf.DefaultRelayURL,
})
if err != nil {
logrus.Fatalf("Failed to initialize NostrService: %v", err)
}
e.GET("/info", svc.InfoHandler)
e.POST("/nip47", svc.NIP47Handler)
e.Use(echologrus.Middleware())

e.GET("/info", service.InfoHandler)
e.POST("/nip47", service.NIP47Handler)
// r.Use(loggingMiddleware)

logrus.Infof("Server starting on port %d", globalConf.Port)
if err := e.Start(fmt.Sprintf(":%d", globalConf.Port)); err != nil {
logrus.Fatalf("Server failed to start: %v", err)
}
//start Echo server
go func() {
if err := e.Start(fmt.Sprintf(":%v", svc.Cfg.Port)); err != nil && err != http.ErrServerClosed {
svc.Logger.Fatalf("Shutting down the server: %v", err)
}
}()
//handle graceful shutdown
<-svc.Ctx.Done()
svc.Logger.Infof("Shutting down echo server...")
ctx, cancel := context.WithTimeout(context.Background(), 10*time.Second)
defer cancel()
e.Shutdown(ctx)
svc.Logger.Info("Echo server exited")
svc.Logger.Info("Waiting for service to exit...")
svc.Wg.Wait()
svc.Logger.Info("Service exited")
}
16 changes: 15 additions & 1 deletion go.mod
Original file line number Diff line number Diff line change
Expand Up @@ -3,7 +3,6 @@ module http-nostr
go 1.21.3

require (
github.com/getsentry/sentry-go v0.25.0
github.com/joho/godotenv v1.5.1
github.com/kelseyhightower/envconfig v1.4.0
github.com/labstack/echo/v4 v4.11.1
Expand All @@ -12,6 +11,17 @@ require (
gopkg.in/DataDog/dd-trace-go.v1 v1.58.0
)

require (
github.com/glebarez/go-sqlite v1.21.2 // indirect
github.com/jinzhu/inflection v1.0.0 // indirect
github.com/jinzhu/now v1.1.5 // indirect
github.com/remyoudompheng/bigfft v0.0.0-20230129092748-24d4a6f8daec // indirect
modernc.org/libc v1.22.5 // indirect
modernc.org/mathutil v1.5.0 // indirect
modernc.org/memory v1.5.0 // indirect
modernc.org/sqlite v1.23.1 // indirect
)

require (
github.com/DataDog/appsec-internal-go v1.0.2 // indirect
github.com/DataDog/datadog-agent/pkg/obfuscate v0.48.0 // indirect
Expand All @@ -24,11 +34,14 @@ require (
github.com/btcsuite/btcd/btcec/v2 v2.3.2 // indirect
github.com/btcsuite/btcd/chaincfg/chainhash v1.0.2 // indirect
github.com/cespare/xxhash/v2 v2.2.0 // indirect
github.com/davrux/echo-logrus/v4 v4.0.3
github.com/decred/dcrd/crypto/blake256 v1.0.1 // indirect
github.com/decred/dcrd/dcrec/secp256k1/v4 v4.2.0 // indirect
github.com/dgraph-io/ristretto v0.1.1 // indirect
github.com/dustin/go-humanize v1.0.1 // indirect
github.com/ebitengine/purego v0.5.0 // indirect
github.com/glebarez/sqlite v1.10.0
github.com/go-gormigrate/gormigrate/v2 v2.1.1
github.com/gobwas/httphead v0.1.0 // indirect
github.com/gobwas/pool v0.2.1 // indirect
github.com/gobwas/ws v1.2.0 // indirect
Expand Down Expand Up @@ -64,5 +77,6 @@ require (
golang.org/x/tools v0.12.1-0.20230815132531-74c255bcf846 // indirect
golang.org/x/xerrors v0.0.0-20220907171357-04be3eba64a2 // indirect
google.golang.org/protobuf v1.30.0 // indirect
gorm.io/gorm v1.25.7
inet.af/netaddr v0.0.0-20230525184311-b8eac61e914a // indirect
)
Loading

0 comments on commit d5b3a12

Please sign in to comment.