Skip to content

Commit

Permalink
refactor: refactor handlers
Browse files Browse the repository at this point in the history
  • Loading branch information
djnovin committed Jan 16, 2025
1 parent 4f87aa7 commit a9caba1
Show file tree
Hide file tree
Showing 5 changed files with 434 additions and 55 deletions.
31 changes: 27 additions & 4 deletions cmd/main.go
Original file line number Diff line number Diff line change
Expand Up @@ -5,12 +5,33 @@ import (
"droneshield/internal/handlers"
"droneshield/internal/middleware"
"fmt"
"log"
"net/http"

ddhttp "gopkg.in/DataDog/dd-trace-go.v1/contrib/net/http"
"gopkg.in/DataDog/dd-trace-go.v1/ddtrace/tracer"

"go.uber.org/zap"
)

type contextKey string

const dbContextKey contextKey = "db"

func main() {
db := config.InitDB()
tracer.Start(
tracer.WithServiceName("droneshield-api"),
tracer.WithEnv("production"), // Replace with "staging" or "development" as needed
tracer.WithAgentAddr("127.0.0.1:8126"), // Default Datadog Agent address
)
defer tracer.Stop()

logger, _ := zap.NewProduction()
defer logger.Sync()

db, err := config.InitDB()
if err != nil {
logger.Fatal("Failed to initialize database", zap.Error(err))
}
defer db.Close()

mux := http.NewServeMux()
Expand All @@ -21,11 +42,13 @@ func main() {

mux.HandleFunc("/api/v1/geofences", handlers.GeoFenceHandler)

wrappedMux := middleware.ErrorLoggingMiddleware(mux)
tracedMux := ddhttp.WrapHandler(mux, "droneshield-api", "production")

wrappedMux := middleware.ErrorLoggingMiddleware(tracedMux)

port := "8000"
fmt.Printf("Server started on port %s\n", port)
if err := http.ListenAndServe(":"+port, wrappedMux); err != nil {
log.Fatalf("Failed to start server: %v", err)
logger.Fatal("Failed to start server", zap.Error(err))
}
}
18 changes: 8 additions & 10 deletions config/config.go
Original file line number Diff line number Diff line change
Expand Up @@ -10,7 +10,7 @@ import (
_ "github.com/lib/pq"
)

func InitDB() *sql.DB {
func InitDB() (*sql.DB, error) {
user := getEnv("DB_USER", "neondb_owner")
password := getEnv("DB_PASSWORD", "your_default_password")
host := getEnv("DB_HOST", "ep-tight-union-a7q3zgwi.ap-southeast-2.aws.neon.tech")
Expand All @@ -21,22 +21,20 @@ func InitDB() *sql.DB {
connStr := fmt.Sprintf("postgresql://%s:%s@%s:%s/%s?sslmode=%s",
user, password, host, port, dbName, sslMode)

db, err := sql.Open("postgres", connStr)
db, err := sqlx.Connect("postgres", connStr)
if err != nil {
log.Fatalf("Error opening database: %v", err)
return nil, fmt.Errorf("error opening database: %w", err)
}

// Set connection pool parameters
db.SetMaxOpenConns(10)
db.SetMaxIdleConns(5)
db.SetConnMaxLifetime(5 * time.Minute)
db.SetMaxOpenConns(10)
db.SetMaxIdleConns(5)
db.SetConnMaxLifetime(5 * time.Minute)

if err := db.Ping(); err != nil {
log.Fatalf("Error pinging database: %v", err)
return nil, fmt.Errorf("error pinging database: %w", err)
}

log.Println("Successfully connected to database")
return db
return db, nil
}

func getEnv(key, defaultValue string) string {
Expand Down
73 changes: 73 additions & 0 deletions go.mod
Original file line number Diff line number Diff line change
Expand Up @@ -3,3 +3,76 @@ module droneshield
go 1.23.2

require github.com/lib/pq v1.10.9

require (
github.com/DataDog/appsec-internal-go v1.9.0 // indirect
github.com/DataDog/datadog-agent/pkg/obfuscate v0.58.0 // indirect
github.com/DataDog/datadog-agent/pkg/proto v0.58.0 // indirect
github.com/DataDog/datadog-agent/pkg/remoteconfig/state v0.58.0 // indirect
github.com/DataDog/datadog-agent/pkg/trace v0.58.0 // indirect
github.com/DataDog/datadog-agent/pkg/util/log v0.58.0 // indirect
github.com/DataDog/datadog-agent/pkg/util/scrubber v0.58.0 // indirect
github.com/DataDog/datadog-go/v5 v5.5.0 // indirect
github.com/DataDog/go-libddwaf/v3 v3.5.1 // indirect
github.com/DataDog/go-runtime-metrics-internal v0.0.0-20241106155157-194426bbbd59 // indirect
github.com/DataDog/go-sqllexer v0.0.14 // indirect
github.com/DataDog/go-tuf v1.1.0-0.5.2 // indirect
github.com/DataDog/opentelemetry-mapping-go/pkg/otlp/attributes v0.20.0 // indirect
github.com/DataDog/sketches-go v1.4.5 // indirect
github.com/Microsoft/go-winio v0.6.1 // indirect
github.com/cespare/xxhash/v2 v2.3.0 // indirect
github.com/cihub/seelog v0.0.0-20170130134532-f561c5e57575 // indirect
github.com/dustin/go-humanize v1.0.1 // indirect
github.com/eapache/queue/v2 v2.0.0-20230407133247-75960ed334e4 // indirect
github.com/ebitengine/purego v0.6.0-alpha.5 // indirect
github.com/go-ole/go-ole v1.2.6 // indirect
github.com/gogo/protobuf v1.3.2 // indirect
github.com/golang/protobuf v1.5.4 // indirect
github.com/google/uuid v1.6.0 // indirect
github.com/hashicorp/go-secure-stdlib/parseutil v0.1.7 // indirect
github.com/hashicorp/go-secure-stdlib/strutil v0.1.2 // indirect
github.com/hashicorp/go-sockaddr v1.0.2 // indirect
github.com/jmoiron/sqlx v1.4.0 // indirect
github.com/json-iterator/go v1.1.12 // indirect
github.com/lufia/plan9stats v0.0.0-20220913051719-115f729f3c8c // indirect
github.com/mitchellh/mapstructure v1.5.1-0.20231216201459-8508981c8b6c // indirect
github.com/modern-go/concurrent v0.0.0-20180306012644-bacd9c7ef1dd // indirect
github.com/modern-go/reflect2 v1.0.2 // indirect
github.com/outcaste-io/ristretto v0.2.3 // indirect
github.com/philhofer/fwd v1.1.3-0.20240612014219-fbbf4953d986 // indirect
github.com/pkg/errors v0.9.1 // indirect
github.com/power-devops/perfstat v0.0.0-20220216144756-c35f1ee13d7c // indirect
github.com/ryanuber/go-glob v1.0.0 // indirect
github.com/secure-systems-lab/go-securesystemslib v0.7.0 // indirect
github.com/shirou/gopsutil/v3 v3.24.4 // indirect
github.com/shoenig/go-m1cpu v0.1.6 // indirect
github.com/tinylib/msgp v1.2.1 // indirect
github.com/tklauser/go-sysconf v0.3.12 // indirect
github.com/tklauser/numcpus v0.6.1 // indirect
github.com/yusufpapurcu/wmi v1.2.4 // indirect
go.opentelemetry.io/collector/component v0.104.0 // indirect
go.opentelemetry.io/collector/config/configtelemetry v0.104.0 // indirect
go.opentelemetry.io/collector/pdata v1.11.0 // indirect
go.opentelemetry.io/collector/pdata/pprofile v0.104.0 // indirect
go.opentelemetry.io/collector/semconv v0.104.0 // indirect
go.opentelemetry.io/otel v1.27.0 // indirect
go.opentelemetry.io/otel/metric v1.27.0 // indirect
go.opentelemetry.io/otel/trace v1.27.0 // indirect
go.uber.org/atomic v1.11.0 // indirect
go.uber.org/multierr v1.11.0 // indirect
go.uber.org/zap v1.27.0 // indirect
golang.org/x/mod v0.20.0 // indirect
golang.org/x/net v0.28.0 // indirect
golang.org/x/sync v0.8.0 // indirect
golang.org/x/sys v0.24.0 // indirect
golang.org/x/text v0.17.0 // indirect
golang.org/x/time v0.6.0 // indirect
golang.org/x/tools v0.24.0 // indirect
golang.org/x/xerrors v0.0.0-20231012003039-104605ab7028 // indirect
google.golang.org/genproto/googleapis/rpc v0.0.0-20240520151616-dc85e6b867a5 // indirect
google.golang.org/grpc v1.64.0 // indirect
google.golang.org/protobuf v1.34.2 // indirect
gopkg.in/DataDog/dd-trace-go.v1 v1.70.3 // indirect
gopkg.in/ini.v1 v1.67.0 // indirect
gopkg.in/yaml.v2 v2.4.0 // indirect
)
Loading

0 comments on commit a9caba1

Please sign in to comment.