2. Input Validation
You may remember that in the integration description we provided an example input that included a required email field and optional limitQuery and limitEmail fields. If the requestor doesn't provide an email address in their input, how would we know where to send the digest? Or, what if the requestor provides invalid limit values (which should be positive integers)?
In this case we want the integration to fail gracefully and respond to the requestor with a failure status and indicate which field(s) need to be fixed. This is where Validation Rules (VRs) come in to play.
Adding Validation Rules to the integration
- On the Build page, with Integration selected under Component at the top, right-click the row with - hackernews_email_digestand select Go To > Validation Rule.
- Click the [➕ADD ROW] button 2 times to add 2 new rows. Enter the following values for each row: - First row: - Type: - INPUT
- Field: - input.payload.email
- Rule: (copy and paste the below Python code) - import re pattern = r"^\w[\w&'\+\-\.]*\b@[a-zA-Z\d][a-zA-Z\d\-]*\b\.[a-zA-Z\d]+[a-zA-Z\d\-]*[a-zA-Z\d]$" retvalue = _ and isinstance(_, str) and re.match(pattern, _)
 
- Second row: - Type: - INPUT
- Field: - input.payload.limitQuery
- Rule: (copy and paste the below Python code) - not _ or (isinstance(_, int) and _ > 0)
 
- Select the second row and click the [DUPLICATE ROW] button at the bottom and make the following edits to the new row: - Field: - input.payload.limitEmail
 
- Click the [💾 Save] button at the bottom. 
 
Testing the Validation Rules
Now we’re going to validate that our new Validation Rules work correctly.
- Navigate to the Run History page. Select our most recent run, and click the curved arrow symbol on it. The Run Integration dialog window should appear. - Copy and paste this into the PAYLOAD: - { "email": "[email protected]", "limitQuery": 10 }
- Click RUN INTEGRATION at the bottom. It should run successfully. 
 
- On the Run History page, click the most recent integration and then the curved arrow again. - This time, provide some invalid values in our payload: - { "email": "invalid%email###@@123", "limitEmail": -1 }
- Re-run the integration again. It should fail. 
- Click the most recent run (once it appears- it may take a couple seconds). There should be two VALIDATION FAILURE records in the middle STEPS column. Clicking on them will provide information. 
 
Last updated
Was this helpful?
