Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

WebHook Related Issues #1259

Open
Xor-el opened this issue Mar 6, 2025 · 2 comments
Open

WebHook Related Issues #1259

Xor-el opened this issue Mar 6, 2025 · 2 comments
Assignees
Labels

Comments

@Xor-el
Copy link

Xor-el commented Mar 6, 2025

Describe the bug

Bug 1 (WebHook does not support Local Requests)

When trying to use the WebHook functionality to initiate a webhook, for online webhook URLs it works but for local ones, the receiving service receives no request.

Expected behavior:

It should work the same both for online and local webhooks.

Test to reproduce

  • 1 Clone Both Repos this and this, and build both projects.
  • 2 Go to the Online WebHook Url
  • 3 Run the Dummy Api project followed by the "WireMockBug001" project. (In case you get an error the first time you run the Demo, close it and run again.).
  • 4 Notice that the Online WebHook URL received our WebHook payload, but our Dummy service did not receive any request.

Bug 2 (WebHook does not post request body when using Body instead of BodyAsJson)

When trying to use the WebHook functionality to initiate a webhook, BodyAsJson works but Body doesn't.

Expected behavior:

It should work the same both for Body and BodyAsJson.

Test to reproduce

  • 1 Clone Both Repos this and this, and build both projects.
  • 2 Go to the Online WebHook Url
  • 3 Go to post-transaction-online.json mapping and comment BodyAsJson and uncomment Body. do same for post-transaction-local.json
  • 4 Build and run the Dummy Api project followed by the "WireMockBug001" project. (In case you get an error the first time you run the Demo, close it and run again.).
  • 5 Notice that the Online WebHook URL received our WebHook, but the payload body is null, but our Dummy service did not receive any request.

Other related info

Docker is needed to run the Demo as it uses WireMock.NET Test Container.

@Xor-el Xor-el added the bug label Mar 6, 2025
@Xor-el
Copy link
Author

Xor-el commented Mar 7, 2025

Additional Question.
Is it possible to define multiple WebHooks in a mapping as using the mapping below does not seem to work?

{
  "Request": {
    "Path": {
      "Matchers": [
        {
          "Name": "WildcardMatcher",
          "Pattern": "/api/transaction-online-multiple"
        }
      ]
    },
    "Methods": [
      "POST"
    ],
    "Body": {
      "Matcher": {
        "Name": "JsonPartialMatcher",
        "Pattern": {
          "transactions": [
            {
              "sourceBankCode": "99",
              "countryCode": "NG",
              "sourceAccount": "1234567890",
              "amountCurrency": "NGN"
            }
          ]
        }
      }
    }
  },
  "Response": {
    "StatusCode": 200,
    "BodyAsJson": {
      "statusCode": null,
      "statusMessage": null,
      "batchReferenceNo": "{{request.bodyAsJson.batchId}}",
      "eventID": "{{request.bodyAsJson.transferType}}"
    },
    "Headers": {
      "Content-Type": "application/json"
    },
    "UseTransformer": true
  },
  "Webhooks": [
    {
      "Request": {
        "Url": "https://webhook.site/e5b518cc-5fd3-4db8-8e51-c7a648cc42b5",
        "Method": "POST",
        "Headers": {
          "Content-Type": "application/json"
        },
        "BodyAsJson": {
          "message": "Webhook triggered!",
          "status": "success"
        },
        "UseTransformer": true,
        "TransformerType": "Handlebars",
        "TransformerReplaceNodeOptions": "EvaluateAndTryToConvert",
        "Delay": 1000
      }
    }
  ],
  "UseWebhooksFireAndForget": true
}

@StefH StefH self-assigned this Mar 7, 2025
@Xor-el
Copy link
Author

Xor-el commented Mar 7, 2025

Just made another discovery.
It seems like setting "UseWebhooksFireAndForget" to true causes the webhook not to fire.

see sample mapping below

{
  "Request": {
    "Path": {
      "Matchers": [
        {
          "Name": "WildcardMatcher",
          "Pattern": "/api/transaction-online"
        }
      ]
    },
    "Methods": [
      "POST"
    ],
    "Body": {
      "Matcher": {
        "Name": "JsonPartialMatcher",
        "Pattern": {
          "transactions": [
            {
              "sourceBankCode": "99",
              "countryCode": "NG",
              "sourceAccount": "1234567890",
              "amountCurrency": "NGN"
            }
          ]
        }
      }
    }
  },
  "Response": {
    "StatusCode": 200,
    "BodyAsJson": {
      "statusCode": null,
      "statusMessage": null,
      "batchReferenceNo": "{{request.bodyAsJson.batchId}}",
      "eventID": "{{request.bodyAsJson.transferType}}"
    },
    "Headers": {
      "Content-Type": "application/json"
    },
    "UseTransformer": true
  },
  "Webhook": {
    "Request": {
      "Url": "https://webhook.site/e5b518cc-5fd3-4db8-8e51-c7a648cc42b5",
      "Method": "POST",
      "Headers": {
        "Content-Type": "application/json"
      },
      "BodyAsJson": {
        "message": "Webhook triggered!",
        "status": "success"
      },
      "UseTransformer": true,
      "TransformerType": "Handlebars",
      "TransformerReplaceNodeOptions": "EvaluateAndTryToConvert",
      "Delay": 1000
    }
  },
  "UseWebhooksFireAndForget": true
}

Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
Projects
None yet
Development

No branches or pull requests

2 participants