52 lines
1.0 KiB
Go
52 lines
1.0 KiB
Go
package gapi
|
|
|
|
import (
|
|
"fmt"
|
|
"log/slog"
|
|
"os"
|
|
|
|
db "github.com/itsscb/df/bff/db/sqlc"
|
|
"github.com/itsscb/df/bff/pb"
|
|
"github.com/itsscb/df/bff/token"
|
|
"github.com/itsscb/df/bff/util"
|
|
)
|
|
|
|
// Server serves gRPC requests for df service
|
|
type Server struct {
|
|
pb.UnimplementedDfServer
|
|
store db.Store
|
|
config util.Config
|
|
tokenMaker token.Maker
|
|
}
|
|
|
|
func NewServer(config util.Config, store db.Store) (*Server, error) {
|
|
tokenMaker, err := token.NewPasetoMaker(config.TokenPrivateKeyHex)
|
|
if err != nil {
|
|
return nil, fmt.Errorf("cannot create token maker: %w", err)
|
|
}
|
|
|
|
server := &Server{
|
|
store: store,
|
|
config: config,
|
|
tokenMaker: tokenMaker,
|
|
}
|
|
|
|
logLevel := slog.LevelError
|
|
if config.Environment == "development" {
|
|
logLevel = slog.LevelDebug
|
|
}
|
|
|
|
opts := slog.HandlerOptions{
|
|
Level: logLevel,
|
|
}
|
|
logger := slog.New(slog.NewTextHandler(os.Stdout, &opts))
|
|
|
|
if config.LogOutput == "json" {
|
|
logger = slog.New(slog.NewJSONHandler(os.Stdout, &opts))
|
|
}
|
|
|
|
slog.SetDefault(logger)
|
|
|
|
return server, nil
|
|
}
|