Synapse allows users to interact with the financial system. Originating transactions allows you to control the flow of funds directly whereas subnets allow users to transact using their Synapse managed accounts outside of your application.
Please note that originating certain types of transactions is not without risk. Transactions can be disputed or returned which can create opportunities for users to double spend.
Transactions are always created relative to a node
Most Transactions follow the pattern of sending node in the url and the receiving node in the payload
Certain Deposit Transactions (such as Check Deposits and GreenDot Cash Deposits) have the receiving node in the url.
Collect Recipient Details
Account number
Routing Number
Collect amount from User
Confirm the transaction with the User (including any Fees)
Verify User with 2 factor Authentication
Create Wire Confirmation PDF
Send confirmation email to user
Collect amount from User
Display Confirmation
Express authorization language (e.g., “I authorize <Platform> to debit my account")
Amount of transaction
The date of transaction
Account identifiers for both the accounts involved (account/routing, bank name with last 4 digits of account, etc.)
Revocation language (for payments scheduled in advance)
Collect Affirmative Consent from the User
Send confirmation email to user
Notes:
The ACH system allows users to Debit or Credit funds from their accounts
ACH transaction will settle within 2-3 business days
ACH transactions can return up to 60 days later
Collect Recipient Details
Account number
Swift Code
Collect amount from User
Confirm the transaction with the User (including any Fees)
Verify User with 2 factor Authentication
Send confirmation email to user
Notes:
Beneficiary & Correspondent bank details must be added when creating a node
Certain countries require additional details when processing SWIFT transactions the can be added in the node or transaction details.
Collect Affirmative Consent from the User
Display Endorsement Instructions
Collect confirmation that the check has been endorsed
Take Pictures
Front
Back
Collect the amount from the user
Validate the check with a 3rd party check tool
Encode the images with Base64
Send the user a confirmation email that the check is being processed
Send user a confirmation email when the check transaction settles
Collect the recipient details from the user
Name
Address
Notes:
For regular payments, we recommend creating and reusing the CHECK-US node
Select the CHECK-US node
Collect the amount from the User
Display Transaction details to User
Collect Affirmative Consent from the User
Notes:
Checks are valid for 60 days
Recurring transactions are a part of everyday life, however due to the complexities of failure handling and customer communication, Synapse does not directly manage scheduled transactions outside of loan repayments.
Pick a task scheduler and runner
Record scheduled transactions and their current state (future, pending, executed, etc) in a datastore of some form
Make sure scheduled tasks are self healing (ie processes will automatically recover from intermittent failure)
Ensure background tasks are interruptible and atomic
Pick a priority:
Maximize success with fan out patterns (such as 1 scheduled transaction per task)
Minimize cost with batch transactions (such as all transactions in a single task)
Enforce idempotency within app and Synapse for scheduled transactions
Collect payment details
Nickname
Sender
Receiver
Amount
Frequency
Start Date
End Date
Display Transaction Disclosures
Express authorization language (e.g., “I authorize <Platform> to debit my account")
Amount of transaction
The date of transaction
Account identifiers for both the accounts involved (account/routing, bank name with last 4 digits of account, etc.)
Revocation language (for payments scheduled in advance)
Cancellation Details for future transactions
Frequency (daily, weekly, monthly) and timing of transactions (start/end date)
Store recurring transaction details in data store
Display list of Recurring Transactions (Platform DB)
Name
Amount
Frequency
Next transaction Date
Select recurring transaction
Display full recurring transaction details
Name
Amount
Frequency
Start Date
End Date
Recipient
Sender
Next transaction date
Required Language: This is an authorized recurring debit from your account
Collect Affirmative Consent from the user
Delete the recurring transaction
Delete all upcoming transactions
Notify user of upcoming transaction 7 Days in advance
Transaction Date
Recurring Transaction Nickname
Amount
Recipient
Sending Account
Notify user of upcoming transaction 24 hours prior to executing the transaction
Transaction Date
Recurring Transaction Nickname
Amount
Recipient
Sending Account
Current Account Balance
If the transaction exceeds the current balance
Get Account Balance (if external account) immediately before creating the transaction
Pull from 3rd party aggregator
Notify user via email that the scheduled transaction was executed
Transaction Date
Recurring Transaction Nickname
Amount
Recipient
Sent Account
Current Account Balance
Notes:
To reduce ACH returns, always check the balance before initiating a scheduled ACH debit request
Collect Recipient Details
Name
Address
Phone
Notes:
3rd party payment users ensures that transactions are not rejected due to incorrect recipient name
Select Transaction
Collect Confirmation from the User:
Notes:
Once the transaction is in the Synapse system, it can only be canceled while in the Pending state
Most transactions are only pending for a few seconds
If users need to have a quick “Undo” transaction functionality, we recommend adding a delay on the server side before creating the transaction in Synapse
Create a transaction that exceeds the users daily/monthly/yearly limit
Synapse will cancel the transaction
Collect information from the user around the purpose of the transaction
Create a ticket with Synapse Support to allow the transaction
Synapse Support will process Transaction
Notes:
Automated limits are intended to support regular user operations
Occasional transactions that exceed limits are managed as exceptions