Skip to content

Commit

Permalink
feat(SPV-1345): get webhooks (#835)
Browse files Browse the repository at this point in the history
  • Loading branch information
chris-4chain authored Jan 3, 2025
1 parent ee07ac5 commit 993421a
Show file tree
Hide file tree
Showing 10 changed files with 195 additions and 7 deletions.
3 changes: 2 additions & 1 deletion actions/admin/routes.go
Original file line number Diff line number Diff line change
Expand Up @@ -36,7 +36,7 @@ func RegisterRoutes(handlersManager *handlers.Manager) {
adminGroupOld.POST("/xpubs/count", handlers.AsAdmin(xpubsCount))
adminGroupOld.POST("/webhooks/subscriptions", handlers.AsAdmin(subscribeWebhookOld))
adminGroupOld.DELETE("/webhooks/subscriptions", handlers.AsAdmin(unsubscribeWebhookOld))
adminGroupOld.GET("/webhooks/subscriptions", handlers.AsAdmin(getAllWebhooks))
adminGroupOld.GET("/webhooks/subscriptions", handlers.AsAdmin(getAllWebhooksOld))

adminGroupOld.GET("/transactions/:id", handlers.AsAdmin(getTxAdminByIDOld))
adminGroupOld.GET("/transactions", handlers.AsAdmin(getTransactionsOld))
Expand Down Expand Up @@ -71,6 +71,7 @@ func RegisterRoutes(handlersManager *handlers.Manager) {
adminGroup.GET("/utxos", handlers.AsAdmin(utxosSearch))

// webhooks
adminGroup.GET("/webhooks/subscriptions", handlers.AsAdmin(getAllWebhooks))
adminGroup.POST("/webhooks/subscriptions", handlers.AsAdmin(subscribeWebhook))
adminGroup.DELETE("/webhooks/subscriptions", handlers.AsAdmin(unsubscribeWebhook))

Expand Down
25 changes: 25 additions & 0 deletions actions/admin/webhooks.go
Original file line number Diff line number Diff line change
Expand Up @@ -4,6 +4,7 @@ import (
"net/http"

"github.com/bitcoin-sv/spv-wallet/engine/spverrors"
"github.com/bitcoin-sv/spv-wallet/mappings"
"github.com/bitcoin-sv/spv-wallet/models"
"github.com/bitcoin-sv/spv-wallet/server/reqctx"
"github.com/gin-gonic/gin"
Expand Down Expand Up @@ -61,3 +62,27 @@ func unsubscribeWebhook(c *gin.Context, _ *reqctx.AdminContext) {

c.Status(http.StatusOK)
}

// getAllWebhooks will return all the stored webhooks
// @Summary Get All Webhooks
// @Description Get All Webhooks currently subscribed to
// @Tags Admin
// @Produce json
// @Success 200 {object} []models.Webhook "List of webhooks"
// @Failure 500 "Internal server error - Error while getting all webhooks"
// @Router /api/v1/admin/webhooks/subscriptions [get]
// @Security x-auth-xpub
func getAllWebhooks(c *gin.Context, _ *reqctx.AdminContext) {
wh, err := reqctx.Engine(c).GetWebhooks(c.Request.Context())
if err != nil {
spverrors.ErrorResponse(c, err, reqctx.Logger(c))
return
}

webhookDTOs := make([]*models.Webhook, len(wh))
for i, w := range wh {
webhookDTOs[i] = mappings.MapToWebhookContract(w)
}

c.JSON(http.StatusOK, webhookDTOs)
}
4 changes: 2 additions & 2 deletions actions/admin/webhooks_old.go
Original file line number Diff line number Diff line change
Expand Up @@ -64,7 +64,7 @@ func unsubscribeWebhookOld(c *gin.Context, _ *reqctx.AdminContext) {
c.JSON(http.StatusOK, true)
}

// getAllWebhooks will return all the stored webhooks
// getAllWebhooksOld will return all the stored webhooks
// @DeprecatedRouter /v1/admin/webhooks/subscriptions [get]
// @Summary Get All Webhooks
// @Description Get All Webhooks currently subscribed to
Expand All @@ -74,7 +74,7 @@ func unsubscribeWebhookOld(c *gin.Context, _ *reqctx.AdminContext) {
// @Failure 500 "Internal server error - Error while getting all webhooks"
// @Router /v1/admin/webhooks/subscriptions [get]
// @Security x-auth-xpub
func getAllWebhooks(c *gin.Context, _ *reqctx.AdminContext) {
func getAllWebhooksOld(c *gin.Context, _ *reqctx.AdminContext) {
wh, err := reqctx.Engine(c).GetWebhooks(c.Request.Context())
if err != nil {
spverrors.ErrorResponse(c, err, reqctx.Logger(c))
Expand Down
72 changes: 72 additions & 0 deletions actions/admin/webhooks_test.go
Original file line number Diff line number Diff line change
@@ -0,0 +1,72 @@
package admin_test

import (
"testing"

"github.com/bitcoin-sv/spv-wallet/actions/testabilities"
testengine "github.com/bitcoin-sv/spv-wallet/engine/testabilities"
)

func TestAdminWebhooks(t *testing.T) {
t.Run("subscribe, get and unsubscribe webhook", func(t *testing.T) {
// given:
given, then := testabilities.New(t)
cleanup := given.StartedSPVWalletWithConfiguration(testengine.WithNotificationsEnabled())
defer cleanup()

// and:
client := given.HttpClient().ForAdmin()

// and:
webhook := map[string]string{
"url": "http://localhost:8080",
"tokenHeader": "Authorization",
"tokenValue": "123",
}

// when:
res, _ := client.R().Get("/api/v1/admin/webhooks/subscriptions")

// then:
then.Response(res).
IsOK().
WithJSONf(`[]`)

// when:
res, _ = client.
R().
SetBody(webhook).
Post("/api/v1/admin/webhooks/subscriptions")

// then:
then.Response(res).IsOK()

// when:
res, _ = client.R().Get("/api/v1/admin/webhooks/subscriptions")

// then:
then.Response(res).
IsOK().
WithJSONf(`[{
"url": "http://localhost:8080",
"banned": false
}]`)

// when:
res, _ = client.
R().
SetBody(map[string]string{"url": webhook["url"]}).
Delete("/api/v1/admin/webhooks/subscriptions")

// then:
then.Response(res).IsOK()

// when:
res, _ = client.R().Get("/api/v1/admin/webhooks/subscriptions")

// then:
then.Response(res).
IsOK().
WithJSONf(`[]`)
})
}
29 changes: 29 additions & 0 deletions docs/docs.go
Original file line number Diff line number Diff line change
Expand Up @@ -803,6 +803,35 @@ const docTemplate = `{
}
},
"/api/v1/admin/webhooks/subscriptions": {
"get": {
"security": [
{
"x-auth-xpub": []
}
],
"description": "Get All Webhooks currently subscribed to",
"produces": [
"application/json"
],
"tags": [
"Admin"
],
"summary": "Get All Webhooks",
"responses": {
"200": {
"description": "List of webhooks",
"schema": {
"type": "array",
"items": {
"$ref": "#/definitions/models.Webhook"
}
}
},
"500": {
"description": "Internal server error - Error while getting all webhooks"
}
}
},
"post": {
"security": [
{
Expand Down
29 changes: 29 additions & 0 deletions docs/swagger.json
Original file line number Diff line number Diff line change
Expand Up @@ -794,6 +794,35 @@
}
},
"/api/v1/admin/webhooks/subscriptions": {
"get": {
"security": [
{
"x-auth-xpub": []
}
],
"description": "Get All Webhooks currently subscribed to",
"produces": [
"application/json"
],
"tags": [
"Admin"
],
"summary": "Get All Webhooks",
"responses": {
"200": {
"description": "List of webhooks",
"schema": {
"type": "array",
"items": {
"$ref": "#/definitions/models.Webhook"
}
}
},
"500": {
"description": "Internal server error - Error while getting all webhooks"
}
}
},
"post": {
"security": [
{
Expand Down
18 changes: 18 additions & 0 deletions docs/swagger.yaml
Original file line number Diff line number Diff line change
Expand Up @@ -3277,6 +3277,24 @@ paths:
summary: Unsubscribe to a webhook
tags:
- Admin
get:
description: Get All Webhooks currently subscribed to
produces:
- application/json
responses:
"200":
description: List of webhooks
schema:
items:
$ref: '#/definitions/models.Webhook'
type: array
"500":
description: Internal server error - Error while getting all webhooks
security:
- x-auth-xpub: []
summary: Get All Webhooks
tags:
- Admin
post:
description: Subscribe to a webhook to receive notifications
parameters:
Expand Down
8 changes: 4 additions & 4 deletions engine/client.go
Original file line number Diff line number Diff line change
Expand Up @@ -208,6 +208,10 @@ func (c *Client) Cluster() cluster.ClientInterface {

// Close will safely close any open connections (cache, datastore, etc.)
func (c *Client) Close(ctx context.Context) error {
// Close WebhookManager
if c.options.notifications != nil && c.options.notifications.webhookManager != nil {
c.options.notifications.webhookManager.Stop()
}

// Close Datastore
ds := c.Datastore()
Expand All @@ -226,10 +230,6 @@ func (c *Client) Close(ctx context.Context) error {
}
c.options.taskManager.TaskEngine = nil
}

if c.options.notifications != nil && c.options.notifications.webhookManager != nil {
c.options.notifications.webhookManager.Stop()
}
return nil
}

Expand Down
8 changes: 8 additions & 0 deletions engine/datastore/sql.go
Original file line number Diff line number Diff line change
Expand Up @@ -128,6 +128,14 @@ func openSQLiteDatabase(optionalLogger glogger.Interface, config *SQLiteConfig)
); err != nil {
return
}
sqlDB, err := db.DB()
if err != nil {
return
}
sqlDB.SetMaxIdleConns(config.MaxIdleConnections)
sqlDB.SetMaxOpenConns(config.MaxOpenConnections)
sqlDB.SetConnMaxLifetime(config.MaxConnectionTime)
sqlDB.SetConnMaxIdleTime(config.MaxConnectionIdleTime)

// Return the connection
return
Expand Down
6 changes: 6 additions & 0 deletions engine/testabilities/fixture_configopts.go
Original file line number Diff line number Diff line change
Expand Up @@ -9,3 +9,9 @@ func WithNewTransactionFlowEnabled() ConfigOpts {
c.ExperimentalFeatures.NewTransactionFlowEnabled = true
}
}

func WithNotificationsEnabled() ConfigOpts {
return func(c *config.AppConfig) {
c.Notifications.Enabled = true
}
}

0 comments on commit 993421a

Please sign in to comment.