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

Validate HMAC key from Tito webhook request before adding user to customer.io #115

Closed

Conversation

courier-new
Copy link

This PR implements verification of the HMAC key header present on incoming webhook requests from Tito, based on the information provided in their docs.

Prior to this verification, event registration could be spoofed by simply hitting the webhook endpoint with a payload containing a first_name, last_name, and email. Granted, the negative implications of doing so were minimal, given this just adds users to the customer.io database and signs them up for the mailing list. But this added validation prevents abuse, eliminates potential spam/invalid data ending up in customer.io, and bolsters the site against denial of service attacks.

Prerequisites

The verification requires that an admin of the Begin deployment sets an additional environment variable, TITO_SECURITY_TOKEN, which matches the security token present on the Tito event settings page. This can be found by going to the event dashboard in Tito, then navigating to Settings > Webhook endpoints.

The annoying caveat to this is that presently, security tokens are uniquely generated per event. I've reached out to Tito to inquire about account-wide security tokens, or at least the ability to custom-set a token or copy a token from a previous event when you duplicate it. But until then, it will be necessary to rotate the security token each month when setting up the new Tito event. To that end, I've added an additional item to the meetup checklist to help with remembering to update this. 🙂

Test plan

Valid requests

  • Create a Tito testing account and test event
  • Add Tito event security token to .env
  • Comment out call to addToCustomerIO, add basic logging of first_name, last_name, and email instead (since we don't actually want to save a user for testing 😛)
  • Run server locally
  • Port forward/tunnel to get a public URL
  • Configure new webhook on Tito for the URL ${publicURL}/webhooks/tito, give it at least the registration.completed event
  • Register for test event
  • Observe request succeeds, user fields are logged out as expected

Invalid requests

Missing signature

  • Using a REST client of your choice, issue a POST request to ${publicURL}/webhooks/tito without any header, body doesn't matter
  • Observe request fails with "missing security signature header" error message

Invalid/mismatched signature

  • Copy the request payload and valid signature header for a real event from Tito
  • Using a REST client of your choice, build a POST request to ${publicURL}/webhooks/tito with the request payload body and signature header values you copied
  • Modify the signature header or payload body slightly
  • Observe request fails with "security signature does not match" error message

@andrewiggins
Copy link
Member

Thanks for looking into this :) The "new" site (#142) removes this web hook so we no longer need this fix.

@courier-new
Copy link
Author

Oh hey, I almost forgot about this lol! Congrats on the migration. I'll close this out then. 🙂

@courier-new courier-new closed this Jan 7, 2025
Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
None yet
Projects
None yet
Development

Successfully merging this pull request may close these issues.

2 participants