mirror of
https://github.com/getAlby/lndhub.go.git
synced 2025-12-21 14:44:45 +01:00
subscribe grpc server to incoming invoices
This commit is contained in:
@@ -4,6 +4,7 @@ import (
|
|||||||
"context"
|
"context"
|
||||||
"strconv"
|
"strconv"
|
||||||
|
|
||||||
|
"github.com/getAlby/lndhub.go/common"
|
||||||
"github.com/getAlby/lndhub.go/db/models"
|
"github.com/getAlby/lndhub.go/db/models"
|
||||||
"github.com/getAlby/lndhub.go/lib/service"
|
"github.com/getAlby/lndhub.go/lib/service"
|
||||||
"github.com/getAlby/lndhub.go/lndhubrpc"
|
"github.com/getAlby/lndhub.go/lndhubrpc"
|
||||||
@@ -19,13 +20,17 @@ type Server struct {
|
|||||||
ctx context.Context
|
ctx context.Context
|
||||||
}
|
}
|
||||||
|
|
||||||
func NewGrpcServer(svc *service.LndhubService, ctx context.Context) *Server {
|
func NewGrpcServer(svc *service.LndhubService, ctx context.Context) (*Server, error) {
|
||||||
incomingInvoices := make(chan models.Invoice)
|
incomingInvoices := make(chan models.Invoice)
|
||||||
|
_, err := svc.InvoicePubSub.Subscribe(common.InvoiceTypeIncoming, incomingInvoices)
|
||||||
|
if err != nil {
|
||||||
|
return nil, err
|
||||||
|
}
|
||||||
return &Server{
|
return &Server{
|
||||||
svc: svc,
|
svc: svc,
|
||||||
incomingInvoices: incomingInvoices,
|
incomingInvoices: incomingInvoices,
|
||||||
ctx: ctx,
|
ctx: ctx,
|
||||||
}
|
}, nil
|
||||||
}
|
}
|
||||||
|
|
||||||
func (s *Server) SubsribeInvoices(req *lndhubrpc.SubsribeInvoicesRequest, srv lndhubrpc.InvoiceSubscription_SubsribeInvoicesServer) error {
|
func (s *Server) SubsribeInvoices(req *lndhubrpc.SubsribeInvoicesRequest, srv lndhubrpc.InvoiceSubscription_SubsribeInvoicesServer) error {
|
||||||
|
|||||||
8
main.go
8
main.go
@@ -188,10 +188,14 @@ func main() {
|
|||||||
port := 10009
|
port := 10009
|
||||||
lis, err := net.Listen("tcp", fmt.Sprintf(":%d", port))
|
lis, err := net.Listen("tcp", fmt.Sprintf(":%d", port))
|
||||||
if err != nil {
|
if err != nil {
|
||||||
log.Fatalf("failed to listen: %v", err)
|
log.Fatalf("Failed to start grpc server: %v", err)
|
||||||
}
|
}
|
||||||
s := grpc.NewServer()
|
s := grpc.NewServer()
|
||||||
lndhubrpc.RegisterInvoiceSubscriptionServer(s, grpcserver.NewGrpcServer(svc, context.TODO()))
|
grpcServer, err := grpcserver.NewGrpcServer(svc, context.TODO())
|
||||||
|
if err != nil {
|
||||||
|
log.Fatalf("Failed to init grpc server, %s", err.Error())
|
||||||
|
}
|
||||||
|
lndhubrpc.RegisterInvoiceSubscriptionServer(s, grpcServer)
|
||||||
log.Printf("grpc server listening at %v", lis.Addr())
|
log.Printf("grpc server listening at %v", lis.Addr())
|
||||||
if err := s.Serve(lis); err != nil {
|
if err := s.Serve(lis); err != nil {
|
||||||
log.Fatalf("failed to serve: %v", err)
|
log.Fatalf("failed to serve: %v", err)
|
||||||
|
|||||||
Reference in New Issue
Block a user