Response samples
- 200
{- "categories": [
- {
- "analytics_group": "revenue",
- "created": "2025-01-16T10:27:09.302124",
- "description": "Rent for offices, workspaces or storage facilities",
- "heron_id": "ctg_btJFzxZK8YUQiVASoBsdso",
- "label": "Rent"
}
]
}
Response samples
- 200
{- "crm_integrations": [
- {
- "config": {
- "data_source_accounts_config": null,
- "default_id": null,
- "object_configs": [ ],
- "policy_evaluation_config": null,
- "sync_file_classes": { },
- "value_mappings": [ ]
}, - "failure_notification_channel": null,
- "heron_id": "string",
- "is_enabled": true,
- "is_live": true,
- "provider": "salesforce"
}
]
}
Create a CRM integration
Create a CRM integration, e.g., with Salesforce
Authorizations:
Request Body schema: application/json
auth required | object Authentication details for the CRM integration |
required | object The configuration for the CRM integration |
failure_notification_channel | string or null^\# Default: null The channel to send failure notifications to |
instance_url required | string <url> Base URL of the CRM integration |
is_enabled | boolean Default: true Whether the integration is enabled |
is_live | boolean Default: true Whether the integration is live |
provider required | string Enum: "salesforce" "lendsmart" "orgmeter" "centrex" "lendsaas" "quickbase" "zoho" "origami" "dynamics" "in_memory" The CRM provider |
secret required | string A secret key for the CRM integration |
property name* additional property | any |
Responses
Request samples
- Payload
{- "auth": { },
- "config": {
- "data_source_accounts_config": null,
- "default_id": null,
- "object_configs": [ ],
- "policy_evaluation_config": null,
- "sync_file_classes": { },
- "value_mappings": [ ]
}, - "failure_notification_channel": null,
- "is_enabled": true,
- "is_live": true,
- "provider": "salesforce",
- "secret": "string"
}
Response samples
- 201
{- "crm_integration": {
- "config": {
- "data_source_accounts_config": null,
- "default_id": null,
- "object_configs": [ ],
- "policy_evaluation_config": null,
- "sync_file_classes": { },
- "value_mappings": [ ]
}, - "failure_notification_channel": null,
- "heron_id": "string",
- "is_enabled": true,
- "is_live": true,
- "provider": "salesforce"
}
}
Patch a CRM integration
patch a CRM integration
Authorizations:
path Parameters
heron_id required | string |
Request Body schema: application/json
auth | object Authentication details for the CRM integration |
object The configuration for the CRM integration | |
failure_notification_channel | string or null^\# Default: null The channel to send failure notifications to |
instance_url | string <url> Base URL of the CRM integration |
is_enabled | boolean Default: true Whether the integration is enabled |
is_live | boolean Default: true Whether the integration is live |
provider | string Enum: "salesforce" "lendsmart" "orgmeter" "centrex" "lendsaas" "quickbase" "zoho" "origami" "dynamics" "in_memory" The CRM provider |
secret | string A secret key for the CRM integration |
property name* additional property | any |
Responses
Request samples
- Payload
{- "auth": { },
- "config": {
- "data_source_accounts_config": null,
- "default_id": null,
- "object_configs": [ ],
- "policy_evaluation_config": null,
- "sync_file_classes": { },
- "value_mappings": [ ]
}, - "failure_notification_channel": null,
- "is_enabled": true,
- "is_live": true,
- "provider": "salesforce",
- "secret": "string"
}
Response samples
- 200
{- "config": {
- "data_source_accounts_config": null,
- "default_id": null,
- "object_configs": [ ],
- "policy_evaluation_config": null,
- "sync_file_classes": { },
- "value_mappings": [ ]
}, - "failure_notification_channel": null,
- "heron_id": "string",
- "is_enabled": true,
- "is_live": true,
- "provider": "salesforce"
}
Update a data source account's account number
Update a data source account's account number
Authorizations:
path Parameters
dsa_heron_id_to_update required | string |
Request Body schema: application/json
source_dsa_heron_id required | string The Heron ID of the data source account containing the number we want to update to |
Responses
Request samples
- Payload
{- "source_dsa_heron_id": "dsa_8w6V5CuRESc7G5yx3mXF54"
}
Response samples
- 200
{- "account_id": "202348",
- "anomaly_score": 200,
- "balances": [
- {
- "closing_amount": 25000.45,
- "currency": "USD",
- "date": "2022-01-01"
}
], - "currency": "USD",
- "end_date": "2022-01-31",
- "heron_id": "dso_98xKHY3ciUkcL9ypYif3JH",
- "institution_name": "Chase",
- "is_enabled": true,
- "max_date": "2022-01-31",
- "min_date": "2022-01-01",
- "name": "Checking Account",
- "num_transactions": 120,
- "number": "123456789",
- "owner_name": "John Doe",
- "reference_id": "account-202348",
- "start_date": "2022-01-01",
- "transactions_match_balances": true,
- "type": "Checking"
}
Update a data source account
Update a data source account
Authorizations:
path Parameters
heron_id required | string |
Request Body schema: application/json
is_enabled | boolean Whether or not the account is enabled. If disabled, hides related transactions from analytics |
Responses
Request samples
- Payload
{- "is_enabled": true
}
Response samples
- 200
{- "account_id": "202348",
- "anomaly_score": 200,
- "balances": [
- {
- "closing_amount": 25000.45,
- "currency": "USD",
- "date": "2022-01-01"
}
], - "currency": "USD",
- "end_date": "2022-01-31",
- "heron_id": "dso_98xKHY3ciUkcL9ypYif3JH",
- "institution_name": "Chase",
- "is_enabled": true,
- "max_date": "2022-01-31",
- "min_date": "2022-01-01",
- "name": "Checking Account",
- "num_transactions": 120,
- "number": "123456789",
- "owner_name": "John Doe",
- "reference_id": "account-202348",
- "start_date": "2022-01-01",
- "transactions_match_balances": true,
- "type": "Checking"
}
Update a data source
Update a data source
Authorizations:
path Parameters
heron_id required | string |
Request Body schema: application/json
is_enabled | boolean Default: true Whether or not the data source is enabled. If disabled, hides related transactions from analytics |
Responses
Request samples
- Payload
{- "is_enabled": true
}
Response samples
- 200
{- "created": "2024-12-05T10:27:11.685019",
- "data_source_accounts": [
- {
- "account_id": "202348",
- "anomaly_score": 200,
- "enabled": true,
- "max_date": "2022-01-31",
- "min_date": "2022-01-01",
- "num_transactions": 120,
- "transactions_match_balances": true
}
], - "heron_id": "dso_fBPQ8RB5QLNbAkhNT9zSDF",
- "is_enabled": true,
- "last_updated": "2025-01-16T10:27:11.685041",
- "metadata": {
- "filename": "202348_JAN_2022.pdf",
- "status": "processed"
}, - "reference_id": "pdf_Ex6Ue5EEuyPSGSWGTundMP",
- "status": "new",
- "type": "pdf"
}
Get data source account summary
Get a list of data sources accounts & their summarised information for a company
Authorizations:
path Parameters
end_user_id_or_heron_id required | string |
Responses
Response samples
- 200
[- {
- "data_source_account_summaries": [
- {
- "account": {
- "account_id": "202348",
- "anomaly_score": 200,
- "balances": [
- {
- "closing_amount": 25000.45,
- "currency": "USD",
- "date": "2022-01-01"
}
], - "currency": "USD",
- "end_date": "2022-01-31",
- "heron_id": "dso_98xKHY3ciUkcL9ypYif3JH",
- "institution_name": "Chase",
- "is_enabled": true,
- "max_date": "2022-01-31",
- "min_date": "2022-01-01",
- "name": "Checking Account",
- "num_transactions": 120,
- "number": "123456789",
- "owner_name": "John Doe",
- "reference_id": "account-202348",
- "start_date": "2022-01-01",
- "transactions_match_balances": true,
- "type": "Checking"
}, - "summary": {
- "average_balance": {
- "amount": "1234.56",
- "currency": "USD"
}, - "average_balance_to_revenue_ratio": 0,
- "ending_balance": {
- "amount": "1234.56",
- "currency": "USD"
}, - "holdback_percentage": 0,
- "mca_debits": {
- "amount": "1234.56",
- "currency": "USD"
}, - "negative_balance_days": 0,
- "no_deposits": 0,
- "no_od_nsf": 0,
- "no_revenue": 0,
- "no_withdrawals": 0,
- "non_revenue": {
- "amount": "1234.56",
- "currency": "USD"
}, - "starting_balance": {
- "amount": "1234.56",
- "currency": "USD"
}, - "total_deposits": {
- "amount": "1234.56",
- "currency": "USD"
}, - "total_revenue": {
- "amount": "1234.56",
- "currency": "USD"
}, - "total_withdrawals": {
- "amount": "1234.56",
- "currency": "USD"
}
}
}
], - "end_user": {
- "end_user_id": "5fc7873a-11d5-4892-8a32-0f0d8d14f94c",
- "heron_id": "eus_ZUqkYBeBJ7i95px73nqyDR",
- "name": "Company Name Inc."
}
}
]
Get data sources
Get a list of data sources for a company
Authorizations:
path Parameters
end_user_id_or_heron_id required | string |
Responses
Response samples
- 200
[- {
- "created": "2024-12-05T10:27:11.685019",
- "data_source_accounts": [
- {
- "account_id": "202348",
- "anomaly_score": 200,
- "enabled": true,
- "max_date": "2022-01-31",
- "min_date": "2022-01-01",
- "num_transactions": 120,
- "transactions_match_balances": true
}
], - "heron_id": "dso_fBPQ8RB5QLNbAkhNT9zSDF",
- "is_enabled": true,
- "last_updated": "2025-01-16T10:27:11.685041",
- "metadata": {
- "filename": "202348_JAN_2022.pdf",
- "status": "processed"
}, - "reference_id": "pdf_Ex6Ue5EEuyPSGSWGTundMP",
- "status": "new",
- "type": "pdf"
}
]
Create an email template
Create an email template used to send emails conditional on events like policy evaluation
Authorizations:
Request Body schema: application/json
cc_address | string or null Default: null The email address to CC |
html_body required | string The body of the email to send. |
name required | string [ 3 .. 50 ] characters ^[a-zA-Z0-9_-]+$ Unique name of the email template. Used to match which email template to send. Only alphanumeric characters, underscores, and dashes are allowed. |
reply_to_address | string or null Default: null The email address to reply to |
to_address | string or null Default: null The email address to send the email to |
property name* additional property | any |
Responses
Request samples
- Payload
{- "cc_address": null,
- "html_body": "string",
- "name": "string",
- "reply_to_address": null,
- "to_address": null
}
Response samples
- 201
{- "email_template": {
- "cc_address": null,
- "heron_id": "string",
- "html_body": "string",
- "name": "string",
- "reply_to_address": null,
- "to_address": null
}
}
Patch an email template
Update an email template
Authorizations:
path Parameters
heron_id required | string |
Request Body schema: application/json
cc_address | string or null Default: null The email address to CC |
html_body | string The body of the email to send. |
name | string [ 3 .. 50 ] characters ^[a-zA-Z0-9_-]+$ Unique name of the email template. Used to match which email template to send. Only alphanumeric characters, underscores, and dashes are allowed. |
reply_to_address | string or null Default: null The email address to reply to |
to_address | string or null Default: null The email address to send the email to |
property name* additional property | any |
Responses
Request samples
- Payload
{- "cc_address": null,
- "html_body": "string",
- "name": "string",
- "reply_to_address": null,
- "to_address": null
}
Response samples
- 201
{- "email_template": {
- "cc_address": null,
- "heron_id": "string",
- "html_body": "string",
- "name": "string",
- "reply_to_address": null,
- "to_address": null
}
}
Get EndUser emails
Get all emails for all end users associate with this user
Authorizations:
query Parameters
page required | integer >= 0 |
limit required | integer >= 1 |
Responses
Response samples
- 200
{- "_meta": {
- "count": 0,
- "has_more": true,
- "page": 0,
- "total_pages": 0
}, - "emails": [
- {
- "email": {
- "created": "2019-08-24T14:15:22Z",
- "date_sent": "2019-08-24T14:15:22Z",
- "date_sent_string": "string",
- "from_address": "string",
- "from_address_domain": "string",
- "from_name": "string",
- "heron_id": "string",
- "html_body": "string",
- "html_or_text_body": "string",
- "is_reply": true,
- "processing_status": "new",
- "subject": "string",
- "subject_cleaned": "string",
- "text_body": "string"
}, - "end_user_heron_id": "string"
}
]
}
List EndUsers
Get a list of EndUsers
Authorizations:
query Parameters
page | integer >= 1 Default: 1 Pagination page number |
include_scorecard_metrics | boolean Default: false Example: include_scorecard_metrics=true Whether to include scorecard metrics for each end user (under field criteria) |
heron_id | string or null Default: null Example: heron_id=eus_T5mcMzKpQtJNXQ4tFDLJzf Unique ID generated by Heron |
is_portfolio | boolean or null Default: null Example: is_portfolio=true Whether the end user is part of a lending portfolio |
status | string or null Default: null Enum: "new" "ready" "processed" "reviewed" "review_requested" "failed" Example: status=reviewed Filter by status of end user |
name | string or null Default: null Example: name=your_end_user_name Filter by name associated with end user |
end_user_id | string or null Default: null Example: end_user_id=your_end_user_id Filter by ID associated with end_user_id field in transactions |
include_data_sources | boolean Default: false Example: include_data_sources=true Whether the to include data sources for each end user |
limit | integer [ 1 .. 10000 ] Default: 1000 Pagination limit per page |
order_by | string Default: "last_updated_desc" Enum: "last_updated_desc" "last_updated_asc" "created_desc" "created_asc" Order to return end users by |
Responses
Response samples
- 200
{- "_meta": {
- "limit": 1000,
- "next_url": "string",
- "page": 1,
- "pages": 3,
- "prev_url": "string",
- "total": 3500
}, - "end_users": [
- {
- "confidence": 0.42,
- "created": "2024-12-05T10:27:11.750362",
- "criteria": [
- {
- "context": "higher_is_better",
- "currency": "string",
- "date_range": "last_180_days",
- "description": "The number of unique transactions with a timestamp",
- "group": "data_quality",
- "label": "unique_transactions",
- "status": "not_available",
- "unit": "n",
- "value": 42.42
}
], - "data_sources": [
- {
- "status": "new",
- "type": "pdf"
}
], - "end_user_id": "5fc7873a-11d5-4892-8a32-0f0d8d14f94c",
- "heron_id": "eus_ZUqkYBeBJ7i95px73nqyDR",
- "is_portfolio": true,
- "last_processed_at": "2025-01-16T10:27:11.750667",
- "last_updated": "2025-01-16T10:27:11.750430",
- "name": "Company Name Inc.",
- "profit_and_loss_layout": null,
- "status": "ready"
}
]
}
Create EndUser
Create a new end user. If transactions have previously been sent for this end_user_id
, use PUT end_users
to update instead.
Authorizations:
Request Body schema: application/json
object (EndUserPostParams) | |||||||||
|
Responses
Request samples
- Payload
{- "end_user": {
- "end_user_id": "5fc7873a-11d5-4892-8a32-0f0d8d14f94c",
- "is_portfolio": true,
- "name": "Company Name Inc.",
- "profit_and_loss_layout": null
}
}
Response samples
- 201
{- "end_user": {
- "confidence": 0.42,
- "created": "2024-12-05T10:27:11.750362",
- "criteria": [
- {
- "context": "higher_is_better",
- "currency": "string",
- "date_range": "last_180_days",
- "description": "The number of unique transactions with a timestamp",
- "group": "data_quality",
- "label": "unique_transactions",
- "status": "not_available",
- "unit": "n",
- "value": 42.42
}
], - "data_sources": [
- {
- "status": "new",
- "type": "pdf"
}
], - "end_user_id": "5fc7873a-11d5-4892-8a32-0f0d8d14f94c",
- "heron_id": "eus_ZUqkYBeBJ7i95px73nqyDR",
- "is_portfolio": true,
- "last_processed_at": "2025-01-16T10:27:11.750667",
- "last_updated": "2025-01-16T10:27:11.750430",
- "name": "Company Name Inc.",
- "profit_and_loss_layout": null,
- "status": "ready"
}
}
Update EndUser
Confirm an end user is ready for async procesing by sending a status of "ready". The end_user_id
must have previously been sent with at least one Transaction if attempting to update the status.
Authorizations:
Request Body schema: application/json
Dictionary representing an EndUser
object (EndUser) | |||||||||||
|
Responses
Callbacks
Request samples
- Payload
{- "end_user": {
- "end_user_id": "5fc7873a-11d5-4892-8a32-0f0d8d14f94c",
- "is_portfolio": true,
- "name": "Company Name Inc.",
- "profit_and_loss_layout": null,
- "status": "ready"
}
}
Response samples
- 200
{- "end_user": {
- "confidence": 0.42,
- "created": "2024-12-05T10:27:11.750362",
- "criteria": [
- {
- "context": "higher_is_better",
- "currency": "string",
- "date_range": "last_180_days",
- "description": "The number of unique transactions with a timestamp",
- "group": "data_quality",
- "label": "unique_transactions",
- "status": "not_available",
- "unit": "n",
- "value": 42.42
}
], - "data_sources": [
- {
- "status": "new",
- "type": "pdf"
}
], - "end_user_id": "5fc7873a-11d5-4892-8a32-0f0d8d14f94c",
- "heron_id": "eus_ZUqkYBeBJ7i95px73nqyDR",
- "is_portfolio": true,
- "last_processed_at": "2025-01-16T10:27:11.750667",
- "last_updated": "2025-01-16T10:27:11.750430",
- "name": "Company Name Inc.",
- "profit_and_loss_layout": null,
- "status": "ready"
}
}
Callback payload samples
{- "created": "2019-08-24T14:15:22Z",
- "data": {
- "end_user_id": "myenduser",
- "heron_id": "eus_Eqio3Y4dhyNiMphrXwG58p",
- "status": "processed"
}, - "meta": { },
- "topic": "string"
}
Get EndUser by heron_id or end_user_id
Get an end user using its end_user_id or heron_id
Authorizations:
path Parameters
end_user_id_or_heron_id required | string |
Responses
Response samples
- 200
{- "end_user": {
- "confidence": 0.42,
- "created": "2024-12-05T10:27:11.750362",
- "criteria": [
- {
- "context": "higher_is_better",
- "currency": "string",
- "date_range": "last_180_days",
- "description": "The number of unique transactions with a timestamp",
- "group": "data_quality",
- "label": "unique_transactions",
- "status": "not_available",
- "unit": "n",
- "value": 42.42
}
], - "data_sources": [
- {
- "status": "new",
- "type": "pdf"
}
], - "end_user_id": "5fc7873a-11d5-4892-8a32-0f0d8d14f94c",
- "heron_id": "eus_ZUqkYBeBJ7i95px73nqyDR",
- "is_portfolio": true,
- "last_processed_at": "2025-01-16T10:27:11.750667",
- "last_updated": "2025-01-16T10:27:11.750430",
- "name": "Company Name Inc.",
- "profit_and_loss_layout": null,
- "status": "ready"
}
}
Get EndUser emails
Get the emails associated with an end user
Authorizations:
path Parameters
end_user_id_or_heron_id required | string |
Responses
Response samples
- 200
[- {
- "created": "2019-08-24T14:15:22Z",
- "date_sent": "2019-08-24T14:15:22Z",
- "date_sent_string": "string",
- "from_address": "string",
- "from_address_domain": "string",
- "from_name": "string",
- "heron_id": "string",
- "html_body": "string",
- "html_or_text_body": "string",
- "is_reply": true,
- "processing_status": "new",
- "subject": "string",
- "subject_cleaned": "string",
- "text_body": "string"
}
]
Get EndUser information
Get the company details of an end user including loan information
Authorizations:
path Parameters
end_user_id_or_heron_id required | string |
Responses
Response samples
- 200
{- "amount_requested": 0,
- "annual_revenue": 0,
- "business_start_date": "2019-08-24",
- "company_billing_address": {
- "city": "string",
- "line_1": "string",
- "line_2": "string",
- "state": "string",
- "zip": "string"
}, - "company_email": "string",
- "company_legal_business_name": "string",
- "company_phone_number": "string",
- "company_physical_address": {
- "city": "string",
- "line_1": "string",
- "line_2": "string",
- "state": "string",
- "zip": "string"
}, - "company_website": "string",
- "dba": "string",
- "federal_tax_id": "string",
- "industry_type": "string",
- "loan_purpose": "string",
- "monthly_revenue": 0,
- "naics": "string",
- "owner_1": {
- "date_of_birth": "1990-01-01",
- "email_address": "string",
- "first_name": "string",
- "home_address": {
- "city": "string",
- "line_1": "string",
- "line_2": "string",
- "state": "string",
- "zip": "string"
}, - "home_phone": "string",
- "last_name": "string",
- "mobile_phone": "string",
- "ownership_percentage": 100,
- "social_security_number": "string"
}, - "owner_2": {
- "date_of_birth": "1990-01-01",
- "email_address": "string",
- "first_name": "string",
- "home_address": {
- "city": "string",
- "line_1": "string",
- "line_2": "string",
- "state": "string",
- "zip": "string"
}, - "home_phone": "string",
- "last_name": "string",
- "mobile_phone": "string",
- "ownership_percentage": 100,
- "social_security_number": "string"
}, - "predicted_industry_probability": 0,
- "source_type": "iso_application_form",
- "state_of_incorporation": "string",
- "type_of_business_entity": "string"
}
Patch EndUser information
Update the end user information
Authorizations:
path Parameters
end_user_id_or_heron_id required | string |
Request Body schema: application/json
amount_requested | number |
annual_revenue | number |
business_start_date | string <date> |
object (Address) | |
company_email | string |
company_legal_business_name | string |
company_phone_number | string |
object (Address) | |
company_website | string |
dba | string Doing business as |
federal_tax_id | string |
industry_type | string |
loan_purpose | string |
monthly_revenue | number |
naics | string |
object (Owner) | |
object (Owner) | |
predicted_industry_probability | number |
source_type | string Enum: "api" "iso_application_form" "heron_industry_classifier" "rel6_industry_classifier" Source of the end user information |
state_of_incorporation | string |
type_of_business_entity | string |
Responses
Request samples
- Payload
{- "amount_requested": 0,
- "annual_revenue": 0,
- "business_start_date": "2019-08-24",
- "company_billing_address": {
- "city": "string",
- "line_1": "string",
- "line_2": "string",
- "state": "string",
- "zip": "string"
}, - "company_email": "string",
- "company_legal_business_name": "string",
- "company_phone_number": "string",
- "company_physical_address": {
- "city": "string",
- "line_1": "string",
- "line_2": "string",
- "state": "string",
- "zip": "string"
}, - "company_website": "string",
- "dba": "string",
- "federal_tax_id": "string",
- "industry_type": "string",
- "loan_purpose": "string",
- "monthly_revenue": 0,
- "naics": "string",
- "owner_1": {
- "date_of_birth": "1990-01-01",
- "email_address": "string",
- "first_name": "string",
- "home_address": {
- "city": "string",
- "line_1": "string",
- "line_2": "string",
- "state": "string",
- "zip": "string"
}, - "home_phone": "string",
- "last_name": "string",
- "mobile_phone": "string",
- "ownership_percentage": 100,
- "social_security_number": "string"
}, - "owner_2": {
- "date_of_birth": "1990-01-01",
- "email_address": "string",
- "first_name": "string",
- "home_address": {
- "city": "string",
- "line_1": "string",
- "line_2": "string",
- "state": "string",
- "zip": "string"
}, - "home_phone": "string",
- "last_name": "string",
- "mobile_phone": "string",
- "ownership_percentage": 100,
- "social_security_number": "string"
}, - "predicted_industry_probability": 0,
- "source_type": "iso_application_form",
- "state_of_incorporation": "string",
- "type_of_business_entity": "string"
}
Response samples
- 200
{- "amount_requested": 0,
- "annual_revenue": 0,
- "business_start_date": "2019-08-24",
- "company_billing_address": {
- "city": "string",
- "line_1": "string",
- "line_2": "string",
- "state": "string",
- "zip": "string"
}, - "company_email": "string",
- "company_legal_business_name": "string",
- "company_phone_number": "string",
- "company_physical_address": {
- "city": "string",
- "line_1": "string",
- "line_2": "string",
- "state": "string",
- "zip": "string"
}, - "company_website": "string",
- "dba": "string",
- "federal_tax_id": "string",
- "industry_type": "string",
- "loan_purpose": "string",
- "monthly_revenue": 0,
- "naics": "string",
- "owner_1": {
- "date_of_birth": "1990-01-01",
- "email_address": "string",
- "first_name": "string",
- "home_address": {
- "city": "string",
- "line_1": "string",
- "line_2": "string",
- "state": "string",
- "zip": "string"
}, - "home_phone": "string",
- "last_name": "string",
- "mobile_phone": "string",
- "ownership_percentage": 100,
- "social_security_number": "string"
}, - "owner_2": {
- "date_of_birth": "1990-01-01",
- "email_address": "string",
- "first_name": "string",
- "home_address": {
- "city": "string",
- "line_1": "string",
- "line_2": "string",
- "state": "string",
- "zip": "string"
}, - "home_phone": "string",
- "last_name": "string",
- "mobile_phone": "string",
- "ownership_percentage": 100,
- "social_security_number": "string"
}, - "predicted_industry_probability": 0,
- "source_type": "iso_application_form",
- "state_of_incorporation": "string",
- "type_of_business_entity": "string"
}
Enrich transactions of EndUser
Enriches transactions of an end user identified by its end_user_id or heron_id. There is an optional priority
parameter that can be set to high
to prioritize the enrichment over normal
(default) priority. High priority enrichment is only enabled for enterprise-level accounts. Please contact support@herondata.io to upgrade your account.
Authorizations:
path Parameters
end_user_id_or_heron_id required | string |
query Parameters
priority | string Default: "normal" Enum: "normal" "high" Priority for async enrichment |
Responses
Response samples
- 200
{- "end_user": {
- "confidence": 0.42,
- "created": "2024-12-05T10:27:11.750362",
- "criteria": [
- {
- "context": "higher_is_better",
- "currency": "string",
- "date_range": "last_180_days",
- "description": "The number of unique transactions with a timestamp",
- "group": "data_quality",
- "label": "unique_transactions",
- "status": "not_available",
- "unit": "n",
- "value": 42.42
}
], - "data_sources": [
- {
- "status": "new",
- "type": "pdf"
}
], - "end_user_id": "5fc7873a-11d5-4892-8a32-0f0d8d14f94c",
- "heron_id": "eus_ZUqkYBeBJ7i95px73nqyDR",
- "is_portfolio": true,
- "last_processed_at": "2025-01-16T10:27:11.750667",
- "last_updated": "2025-01-16T10:27:11.750430",
- "name": "Company Name Inc.",
- "profit_and_loss_layout": null,
- "status": "ready"
}
}
Get recent files by file class
Retrieve the most recent files for the specified file class.
Authorizations:
query Parameters
file_class required | string The file class to filter by. |
limit | integer The maximum number of files to return, defaults to 20 |
Responses
Response samples
- 200
[- {
- "bank_statement": null,
- "created": "2019-08-24T14:15:22Z",
- "email": null,
- "file_class": "other",
- "filename": "string",
- "heron_id": "string",
- "iso_application": {
- "heron_id": "iso_6hBjQT9k6KP2rLCXwjUJff",
- "processing_status": "processed"
}, - "page_classes": {
- "property1": {
- "confidence": 1,
- "file_class": "other"
}, - "property2": {
- "confidence": 1,
- "file_class": "other"
}
}, - "parent_heron_id": "string",
- "parsed_results": [ ],
- "reference_id": "string",
- "renamed_filename": "string"
}
]
Get file rename rules
Retrieve all file rename rules for the current user.
Authorizations:
Responses
Response samples
- 200
[- {
- "end_user_file_class": "other",
- "file_name_template": "string",
- "heron_id": "string",
- "is_enabled": true,
- "variables": [
- {
- "description": "string",
- "examples": [
- "string"
], - "key": "string",
- "name": "string"
}
]
}
]
Create a file rename rule
Add a new rename rule for files.
Authorizations:
Request Body schema: application/json
end_user_file_class required | any Enum: "other" "iso_application_form" "bank_statement" "debt_summary" "email" "invoice" "identity_card" "passport" "trade_license" "registration_certificate" "disclosure_certificate" "drivers_licence_front" "acord_125" "loss_run_report" "driver_list" "fleet_list" "fuel_tax_return" "motor_vehicle_record" "ifta_report" "cab_report" "acord_127" "utility_bill" "supplemental_application" "insurance_policy" "schedule_of_values" "statement_of_values" "acord_825" "acord_838" "acord_137" "acord_other" "market_reform_contract" "quote_slip" "pnl_statement" "balance_sheet" "tax_return" "void_check" "brokerage_statement" "inspection_report" "inspection_report_confirmation" "premium_audit" "combined" "money_market_statement" "commercial_financing_contract" "financing_repayment_history" "ucc_filing" "finicity_cashflow_report" "finicity_voe_transactions_report" "salesforce_object_export" "finicity_failed_statement_report" "claims_report" |
file_name_template required | string |
is_enabled required | boolean |
required | Array of objects (VariableDefinition) |
Responses
Request samples
- Payload
{- "end_user_file_class": "other",
- "file_name_template": "string",
- "is_enabled": true,
- "variables": [
- {
- "description": "string",
- "examples": [
- "string"
], - "key": "string",
- "name": "string"
}
]
}
Response samples
- 200
{- "end_user_file_class": "other",
- "file_name_template": "string",
- "heron_id": "string",
- "is_enabled": true,
- "variables": [
- {
- "description": "string",
- "examples": [
- "string"
], - "key": "string",
- "name": "string"
}
]
}
Update a file rename rule
Update an existing rename rule identified by its heron_id
.
Authorizations:
path Parameters
heron_id required | string The unique identifier of the rename rule. |
Request Body schema: application/json
file_name_template required | string |
is_enabled required | boolean |
required | Array of objects (VariableDefinition) |
Responses
Request samples
- Payload
{- "file_name_template": "string",
- "is_enabled": true,
- "variables": [
- {
- "description": "string",
- "examples": [
- "string"
], - "key": "string",
- "name": "string"
}
]
}
Response samples
- 200
{- "end_user_file_class": "other",
- "file_name_template": "string",
- "heron_id": "string",
- "is_enabled": true,
- "variables": [
- {
- "description": "string",
- "examples": [
- "string"
], - "key": "string",
- "name": "string"
}
]
}
Update the end user file's class
Use this endpoint to change the end user file's class. The file will be reprocessed as the new type.
Authorizations:
path Parameters
heron_id required | string |
Request Body schema: application/json
file_class | any Enum: "other" "iso_application_form" "bank_statement" "debt_summary" "email" "invoice" "identity_card" "passport" "trade_license" "registration_certificate" "disclosure_certificate" "drivers_licence_front" "acord_125" "loss_run_report" "driver_list" "fleet_list" "fuel_tax_return" "motor_vehicle_record" "ifta_report" "cab_report" "acord_127" "utility_bill" "supplemental_application" "insurance_policy" "schedule_of_values" "statement_of_values" "acord_825" "acord_838" "acord_137" "acord_other" "market_reform_contract" "quote_slip" "pnl_statement" "balance_sheet" "tax_return" "void_check" "brokerage_statement" "inspection_report" "inspection_report_confirmation" "premium_audit" "combined" "money_market_statement" "commercial_financing_contract" "financing_repayment_history" "ucc_filing" "finicity_cashflow_report" "finicity_voe_transactions_report" "salesforce_object_export" "finicity_failed_statement_report" "claims_report" |
object or null | |
reference_id | string |
Responses
Request samples
- Payload
{- "file_class": "other",
- "page_classes": {
- "property1": {
- "confidence": 1,
- "file_class": "other"
}, - "property2": {
- "confidence": 1,
- "file_class": "other"
}
}, - "reference_id": "string"
}
Response samples
- 200
{- "bank_statement": null,
- "created": "2019-08-24T14:15:22Z",
- "email": null,
- "file_class": "other",
- "filename": "string",
- "heron_id": "string",
- "iso_application": {
- "heron_id": "iso_6hBjQT9k6KP2rLCXwjUJff",
- "processing_status": "processed"
}, - "page_classes": {
- "property1": {
- "confidence": 1,
- "file_class": "other"
}, - "property2": {
- "confidence": 1,
- "file_class": "other"
}
}, - "parent_heron_id": "string",
- "parsed_results": [ ],
- "reference_id": "string",
- "renamed_filename": "string"
}
Trigger async parsing of an end user file
Authorizations:
path Parameters
heron_id required | string The file's heron_id |
Request Body schema: application/json
parser_id required | string Enum: "DebtPositionEmailParser" "DriversLicenceFrontParser" "LossRunParser" "PnLStatementParser" "BalanceSheetParser" "TaxReturnParser" "VoidCheckParser" "InspectionReportParser" "MoneyMarketStatementParser" "SalesforceObjectJsonParser" |
Responses
Request samples
- Payload
{- "parser_id": "DebtPositionEmailParser"
}
Get parsed results from uploaded files
Authorizations:
path Parameters
heron_id required | string The file's heron_id |
query Parameters
parser_id | string or null |
Responses
Response samples
- 200
[- {
- "attribute_values": [
- { }
], - "created": "2019-08-24T14:15:22Z",
- "field_validations": [
- {
- "failure_reason": "string",
- "field_name": "string",
- "result": "pass",
- "validation_type": "string"
}
], - "heron_id": "string",
- "id": 0,
- "parser_id": "string",
- "parsing_status": "succeeded",
- "result": { }
}
]
Trigger file's rename rule
Authorizations:
path Parameters
heron_id required | string The file's heron_id |
Responses
Response samples
- 200
{- "bank_statement": null,
- "created": "2019-08-24T14:15:22Z",
- "email": null,
- "file_class": "other",
- "filename": "string",
- "heron_id": "string",
- "iso_application": {
- "heron_id": "iso_6hBjQT9k6KP2rLCXwjUJff",
- "processing_status": "processed"
}, - "page_classes": {
- "property1": {
- "confidence": 1,
- "file_class": "other"
}, - "property2": {
- "confidence": 1,
- "file_class": "other"
}
}, - "parent_heron_id": "string",
- "parsed_results": [ ],
- "reference_id": "string",
- "renamed_filename": "string"
}
Trigger splitting a combined end user file into its child files based on its page_classes
Authorizations:
path Parameters
heron_id required | string The file's heron_id |
Responses
Response samples
- 200
[- {
- "bank_statement": null,
- "created": "2019-08-24T14:15:22Z",
- "email": null,
- "file_class": "other",
- "filename": "string",
- "heron_id": "string",
- "iso_application": {
- "heron_id": "iso_6hBjQT9k6KP2rLCXwjUJff",
- "processing_status": "processed"
}, - "page_classes": {
- "property1": {
- "confidence": 1,
- "file_class": "other"
}, - "property2": {
- "confidence": 1,
- "file_class": "other"
}
}, - "parent_heron_id": "string",
- "parsed_results": [ ],
- "reference_id": "string",
- "renamed_filename": "string"
}
]
Get EndUserFiles
Get all files for an end user
Authorizations:
path Parameters
end_user_id_or_heron_id required | string |
Responses
Response samples
- 200
[- {
- "bank_statement": null,
- "created": "2019-08-24T14:15:22Z",
- "email": null,
- "file_class": "other",
- "filename": "string",
- "heron_id": "string",
- "iso_application": {
- "heron_id": "iso_6hBjQT9k6KP2rLCXwjUJff",
- "processing_status": "processed"
}, - "page_classes": {
- "property1": {
- "confidence": 1,
- "file_class": "other"
}, - "property2": {
- "confidence": 1,
- "file_class": "other"
}
}, - "parent_heron_id": "string",
- "parsed_results": [ ],
- "reference_id": "string",
- "renamed_filename": "string"
}
]
Post EndUserFile
Upload file to an end user & asynchronously classify its type
Authorizations:
path Parameters
end_user_id_or_heron_id required | string |
Request Body schema: application/json
file_base64 required | string |
file_class | string Enum: "other" "iso_application_form" "bank_statement" "debt_summary" "email" "invoice" "identity_card" "passport" "trade_license" "registration_certificate" "disclosure_certificate" "drivers_licence_front" "acord_125" "loss_run_report" "driver_list" "fleet_list" "fuel_tax_return" "motor_vehicle_record" "ifta_report" "cab_report" "acord_127" "utility_bill" "supplemental_application" "insurance_policy" "schedule_of_values" "statement_of_values" "acord_825" "acord_838" "acord_137" "acord_other" "market_reform_contract" "quote_slip" "pnl_statement" "balance_sheet" "tax_return" "void_check" "brokerage_statement" "inspection_report" "inspection_report_confirmation" "premium_audit" "combined" "money_market_statement" "commercial_financing_contract" "financing_repayment_history" "ucc_filing" "finicity_cashflow_report" "finicity_voe_transactions_report" "salesforce_object_export" "finicity_failed_statement_report" "claims_report" |
filename required | string |
reference_id | string or null |
Responses
Request samples
- Payload
{- "file_base64": "string",
- "file_class": "other",
- "filename": "string",
- "reference_id": "string"
}
Response samples
- 201
{- "bank_statement": null,
- "created": "2019-08-24T14:15:22Z",
- "email": null,
- "file_class": "other",
- "filename": "string",
- "heron_id": "string",
- "iso_application": {
- "heron_id": "iso_6hBjQT9k6KP2rLCXwjUJff",
- "processing_status": "processed"
}, - "page_classes": {
- "property1": {
- "confidence": 1,
- "file_class": "other"
}, - "property2": {
- "confidence": 1,
- "file_class": "other"
}
}, - "parent_heron_id": "string",
- "parsed_results": [ ],
- "reference_id": "string",
- "renamed_filename": "string"
}
Get EndUser balance
Get balance for given EndUser on a daily and account granularity
Authorizations:
query Parameters
date_min | string or null <date> Default: null Example: date_min=2025-01-16 Filter for transactions with timestamp after the input value (inclusive). It has precedence over timestamp_min |
timestamp_max | string or null <date-time> Default: null Example: timestamp_max=2025-01-15T10:27:11.669099 Deprecated (use date_max instead). Filter for transactions with timestamp earlier than the input value |
include_forecast | boolean Default: false If true, forecasts the balances of each account |
timestamp_min | string or null <date-time> Default: null Example: timestamp_min=2025-01-16T10:27:11.669051 Deprecated (use date_min instead). Filter for transactions with timestamp after the input value |
end_user_id | string or null Default: null Example: end_user_id=your_end_user_id end_user_id for statistics; either end_user_id or end_user_heron_id is required |
end_user_heron_id | string or null Default: null Example: end_user_heron_id=eus_Ea43tFNozQaB2DKnt3zjMf Heron-generated id for end user; either end_user_id or end_user_heron_id is required |
date_max | string or null <date> Default: null Example: date_max=2025-01-15 Filter for transactions with date earlier than the input value (inclusive). It has precedence over timestamp_max |
to_currency | string or null Enum: "GBP" "USD" "EUR" Example: to_currency=USD ISO 4217 currency code to convert to |
Responses
Response samples
- 200
{- "daily_balances": [
- {
- "accounts": [
- {
- "account_id": "string",
- "account_info": {
- "currency": "USD",
- "institution_name": "Chase",
- "name": "Checking Account",
- "number": "123456789",
- "owner_name": "John Doe",
- "type": "Checking"
}, - "balance": 0,
- "balance_converted": 0,
- "currency": "USD",
- "currency_converted": "USD",
- "is_computed": true,
- "is_latest": true,
- "timestamp": "2019-08-24T14:15:22Z"
}
], - "accounts_not_converted": [
- {
- "account_id": "string",
- "account_info": {
- "currency": "USD",
- "institution_name": "Chase",
- "name": "Checking Account",
- "number": "123456789",
- "owner_name": "John Doe",
- "type": "Checking"
}, - "balance": 0,
- "balance_converted": 0,
- "currency": "USD",
- "currency_converted": "USD",
- "is_computed": true,
- "is_latest": true,
- "timestamp": "2019-08-24T14:15:22Z"
}
], - "balance": 0,
- "currency": "USD",
- "date": "2019-08-24"
}
], - "forecasted": [
- {
- "account_id": "string",
- "balances": [
- {
- "date": "2025-01-16",
- "predicted": 42.42,
- "predicted_lower": 4.24,
- "predicted_upper": 420.42
}
], - "currency": "string"
}
], - "summary": {
- "accounts": [
- {
- "account_id": "string",
- "account_info": {
- "currency": "USD",
- "institution_name": "Chase",
- "name": "Checking Account",
- "number": "123456789",
- "owner_name": "John Doe",
- "type": "Checking"
}, - "balance": 0,
- "balance_converted": 0,
- "currency": "USD",
- "currency_converted": "USD",
- "is_computed": true,
- "is_latest": true,
- "timestamp": "2019-08-24T14:15:22Z"
}
], - "accounts_not_converted": [
- {
- "account_id": "string",
- "account_info": {
- "currency": "USD",
- "institution_name": "Chase",
- "name": "Checking Account",
- "number": "123456789",
- "owner_name": "John Doe",
- "type": "Checking"
}, - "balance": 0,
- "balance_converted": 0,
- "currency": "USD",
- "currency_converted": "USD",
- "is_computed": true,
- "is_latest": true,
- "timestamp": "2019-08-24T14:15:22Z"
}
], - "balance": 0,
- "currency": "USD",
- "date": "2019-08-24"
}
}
Get EndUser forecasts
Get forecast amounts for a given EndUser and category
Authorizations:
query Parameters
date_granularity | string Default: "month" Enum: "week" "month" Example: date_granularity=month Aggregate results over time, i.e., aggregate by week or by month |
from_date | string or null <date> Default: null Example: from_date=2022-01-01 The earliest transaction timestamp date to use in forecasting |
to_date | string or null <date> Default: null Example: to_date=2022-01-31 The latest transaction timestamp date to use in forecasting |
end_user_id | string or null Default: null Example: end_user_id=your_end_user_id end_user_id for statistics; either end_user_id or end_user_heron_id is required |
end_user_heron_id | string or null Default: null Example: end_user_heron_id=eus_Ea43tFNozQaB2DKnt3zjMf Heron-generated id for end user; either end_user_id or end_user_heron_id is required |
to_currency | string or null Enum: "GBP" "USD" "EUR" Example: to_currency=USD ISO 4217 currency code to convert to |
category_heron_id | string Example: category_heron_id=ctg_2VoxFk6HYRBy7yRJTmdNoC Heron ID of category to be forecasted; either category_heron_id or category_label must be present |
category_label | string Example: category_label=Revenue Label of category to be forecasted; either category_heron_id or category_label must be present |
Responses
Response samples
- 200
[- {
- "currency": "USD",
- "date": "2025-01-16",
- "predicted": 42.42,
- "predicted_lower": 4.24,
- "predicted_upper": 420.42
}
]
Get EndUser statistics
Get summarized statistics for a given EndUser
Authorizations:
query Parameters
merchant_heron_ids | Array of strings Default: [] Example: merchant_heron_ids=mrc_4op5835Y36oPDSPFxQ6YDn&merchant_heron_ids=mrc_iwL8ihznp3pVs7cUXQnx6y Filter by specific merchants |
date_granularity | string Default: "month" Enum: "day" "week" "month" "quarter" "year" Example: date_granularity=month Aggregate results over time, e.g., by week or by quarter |
group_by | string Default: "category" Enum: "category" "merchant" Example: group_by=category Pivot results by merchant or by category |
from_date | string or null <date> Default: null Example: from_date=2025-01-16 Filter for transactions with timestamp after the input value (as date) |
to_date | string or null <date> Default: null Example: to_date=2025-01-15 Filter for transactions with timestamp before the input value (as date) |
category_heron_ids | Array of strings Default: [] Example: category_heron_ids=ctg_ATPKrmv4uLwXRhNreYbVcK&category_heron_ids=ctg_KJfEVzBLd93EYShaSVEMyX Filter by specific categories |
end_user_id | string or null Default: null Example: end_user_id=your_end_user_id end_user_id for statistics; either end_user_id or end_user_heron_id is required |
end_user_heron_id | string or null Default: null Example: end_user_heron_id=eus_Ea43tFNozQaB2DKnt3zjMf Heron-generated id for end user; either end_user_id or end_user_heron_id is required |
to_currency | string or null Enum: "GBP" "USD" "EUR" Example: to_currency=USD ISO 4217 currency code to convert to |
Responses
Response samples
- 200
{- "statistics": [
- {
- "currency": "USD",
- "dt": "2025-01-16",
- "heron_id": "mrc_b968fK39HgShyAbiAmj2jw",
- "label": "Revenue",
- "metrics": {
- "inflow": {
- "amount": 42.42,
- "avg_amount": 1.01,
- "n": 42
}, - "net": {
- "amount": 42.42,
- "avg_amount": 1.01,
- "n": 42
}, - "outflow": {
- "amount": 42.42,
- "avg_amount": 1.01,
- "n": 42
}
}
}
]
}
Get EndUser anomalies
Get anomalies for given EndUser given a category label or heron id
Authorizations:
path Parameters
end_user_id_or_heron_id required | string The |
query Parameters
category_label_or_heron_id required | string Example: category_label_or_heron_id=Revenue Label or Heron ID of category to find anomalies for |
Responses
Response samples
- 200
[- {
- "amount": 42.42,
- "anomaly_score": 0.5,
- "currency": "USD",
- "heron_id": "txn_JLwCVeKVEeadDarMi2SFV7",
- "reference_id": "1342db06-feb7-4c33-a157-4351d74a98e9"
}
]
Get EndUser bank statement summary
Get the bank statement summary by month for an end user
Authorizations:
path Parameters
end_user_id_or_heron_id required | string |
query Parameters
account_ids | Array of strings or null Default: null Example: account_ids=1234 Account ids to include in the summary, if not provided, all accounts are included |
grouping | string Default: "by_month" Enum: "by_month" "by_data_source_account_heron_id" "rolling_30_days_from_last_txn" "rolling_30_days_from_today" "by_month_by_data_source_account_heron_id" Determines how to group transactions. It supports calendar month (by_month) or rolling 30-day period (from last txns with rolling_30_days_from_last_txn or from today with rolling_30_days_from_today) |
num_full_calendar_months | integer or null >= 1 Default: null Number of full calendar months to show in the summary |
Responses
Response samples
- 200
{- "average": {
- "average_balance": {
- "amount": "1234.56",
- "currency": "USD"
}, - "average_balance_to_revenue_ratio": 0,
- "ending_balance": {
- "amount": "1234.56",
- "currency": "USD"
}, - "holdback_percentage": 0,
- "mca_debits": {
- "amount": "1234.56",
- "currency": "USD"
}, - "negative_balance_days": 0,
- "no_deposits": 0,
- "no_od_nsf": 0,
- "no_revenue": 0,
- "no_withdrawals": 0,
- "non_revenue": {
- "amount": "1234.56",
- "currency": "USD"
}, - "starting_balance": {
- "amount": "1234.56",
- "currency": "USD"
}, - "total_deposits": {
- "amount": "1234.56",
- "currency": "USD"
}, - "total_revenue": {
- "amount": "1234.56",
- "currency": "USD"
}, - "total_withdrawals": {
- "amount": "1234.56",
- "currency": "USD"
}
}, - "by_data_source_account_heron_id": {
- "property1": {
- "average_balance": {
- "amount": "1234.56",
- "currency": "USD"
}, - "average_balance_to_revenue_ratio": 0,
- "ending_balance": {
- "amount": "1234.56",
- "currency": "USD"
}, - "holdback_percentage": 0,
- "mca_debits": {
- "amount": "1234.56",
- "currency": "USD"
}, - "negative_balance_days": 0,
- "no_deposits": 0,
- "no_od_nsf": 0,
- "no_revenue": 0,
- "no_withdrawals": 0,
- "non_revenue": {
- "amount": "1234.56",
- "currency": "USD"
}, - "starting_balance": {
- "amount": "1234.56",
- "currency": "USD"
}, - "total_deposits": {
- "amount": "1234.56",
- "currency": "USD"
}, - "total_revenue": {
- "amount": "1234.56",
- "currency": "USD"
}, - "total_withdrawals": {
- "amount": "1234.56",
- "currency": "USD"
}
}, - "property2": {
- "average_balance": {
- "amount": "1234.56",
- "currency": "USD"
}, - "average_balance_to_revenue_ratio": 0,
- "ending_balance": {
- "amount": "1234.56",
- "currency": "USD"
}, - "holdback_percentage": 0,
- "mca_debits": {
- "amount": "1234.56",
- "currency": "USD"
}, - "negative_balance_days": 0,
- "no_deposits": 0,
- "no_od_nsf": 0,
- "no_revenue": 0,
- "no_withdrawals": 0,
- "non_revenue": {
- "amount": "1234.56",
- "currency": "USD"
}, - "starting_balance": {
- "amount": "1234.56",
- "currency": "USD"
}, - "total_deposits": {
- "amount": "1234.56",
- "currency": "USD"
}, - "total_revenue": {
- "amount": "1234.56",
- "currency": "USD"
}, - "total_withdrawals": {
- "amount": "1234.56",
- "currency": "USD"
}
}
}, - "by_month": {
- "property1": {
- "average_balance": {
- "amount": "1234.56",
- "currency": "USD"
}, - "average_balance_to_revenue_ratio": 0,
- "ending_balance": {
- "amount": "1234.56",
- "currency": "USD"
}, - "holdback_percentage": 0,
- "mca_debits": {
- "amount": "1234.56",
- "currency": "USD"
}, - "negative_balance_days": 0,
- "no_deposits": 0,
- "no_od_nsf": 0,
- "no_revenue": 0,
- "no_withdrawals": 0,
- "non_revenue": {
- "amount": "1234.56",
- "currency": "USD"
}, - "starting_balance": {
- "amount": "1234.56",
- "currency": "USD"
}, - "total_deposits": {
- "amount": "1234.56",
- "currency": "USD"
}, - "total_revenue": {
- "amount": "1234.56",
- "currency": "USD"
}, - "total_withdrawals": {
- "amount": "1234.56",
- "currency": "USD"
}
}, - "property2": {
- "average_balance": {
- "amount": "1234.56",
- "currency": "USD"
}, - "average_balance_to_revenue_ratio": 0,
- "ending_balance": {
- "amount": "1234.56",
- "currency": "USD"
}, - "holdback_percentage": 0,
- "mca_debits": {
- "amount": "1234.56",
- "currency": "USD"
}, - "negative_balance_days": 0,
- "no_deposits": 0,
- "no_od_nsf": 0,
- "no_revenue": 0,
- "no_withdrawals": 0,
- "non_revenue": {
- "amount": "1234.56",
- "currency": "USD"
}, - "starting_balance": {
- "amount": "1234.56",
- "currency": "USD"
}, - "total_deposits": {
- "amount": "1234.56",
- "currency": "USD"
}, - "total_revenue": {
- "amount": "1234.56",
- "currency": "USD"
}, - "total_withdrawals": {
- "amount": "1234.56",
- "currency": "USD"
}
}
}, - "by_month_by_data_source_account_heron_id": {
- "property1": {
- "property1": {
- "average_balance": {
- "amount": "1234.56",
- "currency": "USD"
}, - "average_balance_to_revenue_ratio": 0,
- "ending_balance": {
- "amount": "1234.56",
- "currency": "USD"
}, - "holdback_percentage": 0,
- "mca_debits": {
- "amount": "1234.56",
- "currency": "USD"
}, - "negative_balance_days": 0,
- "no_deposits": 0,
- "no_od_nsf": 0,
- "no_revenue": 0,
- "no_withdrawals": 0,
- "non_revenue": {
- "amount": "1234.56",
- "currency": "USD"
}, - "starting_balance": {
- "amount": "1234.56",
- "currency": "USD"
}, - "total_deposits": {
- "amount": "1234.56",
- "currency": "USD"
}, - "total_revenue": {
- "amount": "1234.56",
- "currency": "USD"
}, - "total_withdrawals": {
- "amount": "1234.56",
- "currency": "USD"
}
}, - "property2": {
- "average_balance": {
- "amount": "1234.56",
- "currency": "USD"
}, - "average_balance_to_revenue_ratio": 0,
- "ending_balance": {
- "amount": "1234.56",
- "currency": "USD"
}, - "holdback_percentage": 0,
- "mca_debits": {
- "amount": "1234.56",
- "currency": "USD"
}, - "negative_balance_days": 0,
- "no_deposits": 0,
- "no_od_nsf": 0,
- "no_revenue": 0,
- "no_withdrawals": 0,
- "non_revenue": {
- "amount": "1234.56",
- "currency": "USD"
}, - "starting_balance": {
- "amount": "1234.56",
- "currency": "USD"
}, - "total_deposits": {
- "amount": "1234.56",
- "currency": "USD"
}, - "total_revenue": {
- "amount": "1234.56",
- "currency": "USD"
}, - "total_withdrawals": {
- "amount": "1234.56",
- "currency": "USD"
}
}
}, - "property2": {
- "property1": {
- "average_balance": {
- "amount": "1234.56",
- "currency": "USD"
}, - "average_balance_to_revenue_ratio": 0,
- "ending_balance": {
- "amount": "1234.56",
- "currency": "USD"
}, - "holdback_percentage": 0,
- "mca_debits": {
- "amount": "1234.56",
- "currency": "USD"
}, - "negative_balance_days": 0,
- "no_deposits": 0,
- "no_od_nsf": 0,
- "no_revenue": 0,
- "no_withdrawals": 0,
- "non_revenue": {
- "amount": "1234.56",
- "currency": "USD"
}, - "starting_balance": {
- "amount": "1234.56",
- "currency": "USD"
}, - "total_deposits": {
- "amount": "1234.56",
- "currency": "USD"
}, - "total_revenue": {
- "amount": "1234.56",
- "currency": "USD"
}, - "total_withdrawals": {
- "amount": "1234.56",
- "currency": "USD"
}
}, - "property2": {
- "average_balance": {
- "amount": "1234.56",
- "currency": "USD"
}, - "average_balance_to_revenue_ratio": 0,
- "ending_balance": {
- "amount": "1234.56",
- "currency": "USD"
}, - "holdback_percentage": 0,
- "mca_debits": {
- "amount": "1234.56",
- "currency": "USD"
}, - "negative_balance_days": 0,
- "no_deposits": 0,
- "no_od_nsf": 0,
- "no_revenue": 0,
- "no_withdrawals": 0,
- "non_revenue": {
- "amount": "1234.56",
- "currency": "USD"
}, - "starting_balance": {
- "amount": "1234.56",
- "currency": "USD"
}, - "total_deposits": {
- "amount": "1234.56",
- "currency": "USD"
}, - "total_revenue": {
- "amount": "1234.56",
- "currency": "USD"
}, - "total_withdrawals": {
- "amount": "1234.56",
- "currency": "USD"
}
}
}
}, - "grouping": "string",
- "rolling_30_days_from_last_txn": {
- "property1": {
- "average_balance": {
- "amount": "1234.56",
- "currency": "USD"
}, - "average_balance_to_revenue_ratio": 0,
- "ending_balance": {
- "amount": "1234.56",
- "currency": "USD"
}, - "holdback_percentage": 0,
- "mca_debits": {
- "amount": "1234.56",
- "currency": "USD"
}, - "negative_balance_days": 0,
- "no_deposits": 0,
- "no_od_nsf": 0,
- "no_revenue": 0,
- "no_withdrawals": 0,
- "non_revenue": {
- "amount": "1234.56",
- "currency": "USD"
}, - "starting_balance": {
- "amount": "1234.56",
- "currency": "USD"
}, - "total_deposits": {
- "amount": "1234.56",
- "currency": "USD"
}, - "total_revenue": {
- "amount": "1234.56",
- "currency": "USD"
}, - "total_withdrawals": {
- "amount": "1234.56",
- "currency": "USD"
}
}, - "property2": {
- "average_balance": {
- "amount": "1234.56",
- "currency": "USD"
}, - "average_balance_to_revenue_ratio": 0,
- "ending_balance": {
- "amount": "1234.56",
- "currency": "USD"
}, - "holdback_percentage": 0,
- "mca_debits": {
- "amount": "1234.56",
- "currency": "USD"
}, - "negative_balance_days": 0,
- "no_deposits": 0,
- "no_od_nsf": 0,
- "no_revenue": 0,
- "no_withdrawals": 0,
- "non_revenue": {
- "amount": "1234.56",
- "currency": "USD"
}, - "starting_balance": {
- "amount": "1234.56",
- "currency": "USD"
}, - "total_deposits": {
- "amount": "1234.56",
- "currency": "USD"
}, - "total_revenue": {
- "amount": "1234.56",
- "currency": "USD"
}, - "total_withdrawals": {
- "amount": "1234.56",
- "currency": "USD"
}
}
}, - "rolling_30_days_from_today": {
- "property1": {
- "average_balance": {
- "amount": "1234.56",
- "currency": "USD"
}, - "average_balance_to_revenue_ratio": 0,
- "ending_balance": {
- "amount": "1234.56",
- "currency": "USD"
}, - "holdback_percentage": 0,
- "mca_debits": {
- "amount": "1234.56",
- "currency": "USD"
}, - "negative_balance_days": 0,
- "no_deposits": 0,
- "no_od_nsf": 0,
- "no_revenue": 0,
- "no_withdrawals": 0,
- "non_revenue": {
- "amount": "1234.56",
- "currency": "USD"
}, - "starting_balance": {
- "amount": "1234.56",
- "currency": "USD"
}, - "total_deposits": {
- "amount": "1234.56",
- "currency": "USD"
}, - "total_revenue": {
- "amount": "1234.56",
- "currency": "USD"
}, - "total_withdrawals": {
- "amount": "1234.56",
- "currency": "USD"
}
}, - "property2": {
- "average_balance": {
- "amount": "1234.56",
- "currency": "USD"
}, - "average_balance_to_revenue_ratio": 0,
- "ending_balance": {
- "amount": "1234.56",
- "currency": "USD"
}, - "holdback_percentage": 0,
- "mca_debits": {
- "amount": "1234.56",
- "currency": "USD"
}, - "negative_balance_days": 0,
- "no_deposits": 0,
- "no_od_nsf": 0,
- "no_revenue": 0,
- "no_withdrawals": 0,
- "non_revenue": {
- "amount": "1234.56",
- "currency": "USD"
}, - "starting_balance": {
- "amount": "1234.56",
- "currency": "USD"
}, - "total_deposits": {
- "amount": "1234.56",
- "currency": "USD"
}, - "total_revenue": {
- "amount": "1234.56",
- "currency": "USD"
}, - "total_withdrawals": {
- "amount": "1234.56",
- "currency": "USD"
}
}
}, - "total": {
- "average_balance": {
- "amount": "1234.56",
- "currency": "USD"
}, - "average_balance_to_revenue_ratio": 0,
- "ending_balance": {
- "amount": "1234.56",
- "currency": "USD"
}, - "holdback_percentage": 0,
- "mca_debits": {
- "amount": "1234.56",
- "currency": "USD"
}, - "negative_balance_days": 0,
- "no_deposits": 0,
- "no_od_nsf": 0,
- "no_revenue": 0,
- "no_withdrawals": 0,
- "non_revenue": {
- "amount": "1234.56",
- "currency": "USD"
}, - "starting_balance": {
- "amount": "1234.56",
- "currency": "USD"
}, - "total_deposits": {
- "amount": "1234.56",
- "currency": "USD"
}, - "total_revenue": {
- "amount": "1234.56",
- "currency": "USD"
}, - "total_withdrawals": {
- "amount": "1234.56",
- "currency": "USD"
}
}
}
Get EndUser metric benchmarks
Get the benchmarks for each metric for an end user
Authorizations:
path Parameters
end_user_id_or_heron_id required | string |
Responses
Response samples
- 200
{- "benchmarks": [
- {
- "date_range": "last_180_days",
- "label": "unique_transactions",
- "percentile": 0.75,
- "rank": 22,
- "sample_size": 42,
- "scope": "user"
}
]
}
Get EndUser transactions grouped by counterparty or merchant
Get a report of transactions grouped by merchant or counterparty for an end user
Authorizations:
path Parameters
end_user_id_or_heron_id required | string |
Responses
Response samples
- 200
[- {
- "counterparty": "string",
- "merchant": {
- "categories": [
- {
- "code": "7311",
- "description": "Advertising services",
- "slug": "advertising_services"
}
], - "group_id": "Uber",
- "heron_id": "mrc_GBDaec5u8gWTRAHVvXjyBD",
- "icon_url": "string",
- "logo_url": "string",
- "name": "string"
}, - "transaction_groups": [
- {
- "frequency": "not_enough_data",
- "transactions": [
- {
- "amount": {
- "amount": "1234.56",
- "currency": "USD"
}, - "category": {
- "heron_id": "string",
- "label": "string"
}, - "description": "string",
- "heron_id": "string",
- "timestamp": "2019-08-24T14:15:22Z"
}
]
}
]
}
]
Get EndUser Heron Score (beta)
Get Heron Score for end user with a breakdown of the feature group contributions which resulted in the score. The score is calculated for the day of last transaction. This is a beta feature and is subject to change.
Authorizations:
path Parameters
end_user_id_or_heron_id required | string |
query Parameters
min_category_confidence | number or null Default: null Example: min_category_confidence=0.8 Minimum company categorisation confidence to calculate Heron Score |
date | string or null <date> Default: null Example: date=2023-01-19 Cut-off date to consider transactions to for calculating heron score (inclusive) |
Responses
Response samples
- 200
{- "data_quality_issues": [
- "transactions_without_timestamps"
], - "feature_groups_contributions": {
- "property1": {
- "relative_contribution": 0,
- "relative_population_avg": 0
}, - "property2": {
- "relative_contribution": 0,
- "relative_population_avg": 0
}
}, - "predicted_at": "2019-08-24T14:15:22Z",
- "reference_timestamp": "2019-08-24T14:15:22Z",
- "status": "not_available",
- "value": 0
}
Get EndUser industry
Predict the industry of the end user based on its name
Authorizations:
path Parameters
end_user_id_or_heron_id required | string The |
query Parameters
naics_code_min_digits | integer [ 2 .. 6 ] Example: naics_code_min_digits=2 Minimum number of digits in NAICS code |
naics_code_max_digits | integer [ 2 .. 6 ] Example: naics_code_max_digits=6 Maximum number of digits in NAICS code |
Responses
Response samples
- 200
{- "label": "Fruit and Vegetable Preserving and Specialty Food Manufacturing",
- "probability": 0.42,
- "taxonomy": "naics",
- "taxonomy_value": "3114"
}
Get EndUser merchant summary
Get the summary of transactions by merchant for an end user for given categories or analytics groups
Authorizations:
path Parameters
end_user_id_or_heron_id required | string |
query Parameters
group_by_counterparty_txn_clusters | boolean Default: false Whether to group by counterparty transaction clusters |
account_ids | Array of strings or null Default: null Example: account_ids=1234 Account ids to include in the summary, if not provided, all accounts are included |
category_label_or_heron_id | Array of strings or null non-empty |
analytics_group | Array of strings or null or null non-empty Enum: "revenue" "cost_of_goods_sold" "operational_expenses" "tax_expenses" "intra_company" "debt" "equity" "other_income" "special_items" "other" Example: analytics_group=debt |
Responses
Response samples
- 200
{- "by_merchant_summary": [
- {
- "group": "string",
- "heron_id": "string",
- "inflow_metrics": {
- "amount": {
- "amount": "1234.56",
- "currency": "USD"
}, - "changed_in_last_90_days": true,
- "count": 0,
- "duration_days": 0,
- "estimated_monthly_amount": {
- "amount": "1234.56",
- "currency": "USD"
}, - "frequency": "not_enough_data",
- "max_amount": {
- "amount": "1234.56",
- "currency": "USD"
}, - "max_timestamp": "2019-08-24T14:15:22Z",
- "mean_amount": {
- "amount": "1234.56",
- "currency": "USD"
}, - "mean_interval_days": 0,
- "median_amount": {
- "amount": "1234.56",
- "currency": "USD"
}, - "min_amount": {
- "amount": "1234.56",
- "currency": "USD"
}, - "min_timestamp": "2019-08-24T14:15:22Z",
- "mode_amount": {
- "amount": "1234.56",
- "currency": "USD"
}, - "mode_interval_days": 0,
- "std_dev_amount": {
- "amount": "1234.56",
- "currency": "USD"
}
}, - "name": "string",
- "net_metrics": {
- "amount": {
- "amount": "1234.56",
- "currency": "USD"
}, - "changed_in_last_90_days": true,
- "count": 0,
- "duration_days": 0,
- "estimated_monthly_amount": {
- "amount": "1234.56",
- "currency": "USD"
}, - "frequency": "not_enough_data",
- "max_amount": {
- "amount": "1234.56",
- "currency": "USD"
}, - "max_timestamp": "2019-08-24T14:15:22Z",
- "mean_amount": {
- "amount": "1234.56",
- "currency": "USD"
}, - "mean_interval_days": 0,
- "median_amount": {
- "amount": "1234.56",
- "currency": "USD"
}, - "min_amount": {
- "amount": "1234.56",
- "currency": "USD"
}, - "min_timestamp": "2019-08-24T14:15:22Z",
- "mode_amount": {
- "amount": "1234.56",
- "currency": "USD"
}, - "mode_interval_days": 0,
- "std_dev_amount": {
- "amount": "1234.56",
- "currency": "USD"
}
}, - "outflow_metrics": {
- "amount": {
- "amount": "1234.56",
- "currency": "USD"
}, - "changed_in_last_90_days": true,
- "count": 0,
- "duration_days": 0,
- "estimated_monthly_amount": {
- "amount": "1234.56",
- "currency": "USD"
}, - "frequency": "not_enough_data",
- "max_amount": {
- "amount": "1234.56",
- "currency": "USD"
}, - "max_timestamp": "2019-08-24T14:15:22Z",
- "mean_amount": {
- "amount": "1234.56",
- "currency": "USD"
}, - "mean_interval_days": 0,
- "median_amount": {
- "amount": "1234.56",
- "currency": "USD"
}, - "min_amount": {
- "amount": "1234.56",
- "currency": "USD"
}, - "min_timestamp": "2019-08-24T14:15:22Z",
- "mode_amount": {
- "amount": "1234.56",
- "currency": "USD"
}, - "mode_interval_days": 0,
- "std_dev_amount": {
- "amount": "1234.56",
- "currency": "USD"
}
}
}
]
}
Get EndUser named dates
Get the named dates associated with an end user, e.g., date of last transaction
Authorizations:
path Parameters
end_user_id_or_heron_id required | string |
Responses
Response samples
- 200
{- "named_dates": [
- {
- "date": "2025-01-16",
- "name": "last_transaction"
}
]
}
Get EndUser cashflow P&L
Calculates the cashflow profit & loss table for an end user, based on the layout defined (if any)
Authorizations:
path Parameters
end_user_id_or_heron_id required | string |
query Parameters
from_date | string or null <date> Default: null Example: from_date=2022-01-01 The earliest transaction timestamp date to use |
currency | string or null Enum: "GBP" "USD" "EUR" Example: currency=USD ISO 4217 currency code for balance |
dates_ascending | boolean Default: false If true, dates are sorted left to right by ascending order. False by default, i.e., by default sorted in descending date order so more recent dates are first |
to_date | string or null <date> Default: null Example: to_date=2022-01-31 The latest transaction timestamp date to use |
Responses
Response samples
- 200
{- "dates": [
- "2019-08-24"
], - "sections": [
- {
- "metrics": [
- {
- "confidence": 0,
- "indent": 0,
- "is_ratio": true,
- "name": "string",
- "values": [
- 0
]
}
], - "name": "string",
- "slug": "string"
}
]
}
Update EndUser P&L layout
Update the profit and loss layout for the end user, which determines how the profit and loss table is calculated
Authorizations:
path Parameters
end_user_id_or_heron_id required | string |
Request Body schema: application/json
category_labels required | Array of strings non-empty List of category labels to assign to a different section |
section_slug required | string Slug of section to assign labels to |
Responses
Request samples
- Payload
{- "category_labels": [
- "Postage"
], - "section_slug": "operational_expenses"
}
Response samples
- 200
{- "sections": [
- {
- "labels": [
- "string"
], - "metrics": [
- {
- "denominator": {
- "labels": [
- "string"
], - "sections": [
- "string"
]
}, - "indent": 0,
- "is_growth": true,
- "name": "string",
- "numerator": {
- "labels": [
- "string"
], - "sections": [
- "string"
]
}
}
], - "name": "string",
- "slug": "string"
}
]
}
Get EndUser recurring transactions report
Get a report of recurring transactions grouped by merchant or counterparty for an end user
Authorizations:
path Parameters
end_user_id_or_heron_id required | string |
query Parameters
account_ids | Array of strings or null Default: null Example: account_ids=1234 Account ids to include in the report, if not provided, all accounts are included |
Responses
Response samples
- 200
[- {
- "avg_amount": {
- "amount": "1234.56",
- "currency": "USD"
}, - "avg_confidence": 0,
- "counterparty": "string",
- "frequency": "not_enough_data",
- "merchant_name": "string",
- "transactions": [
- {
- "amount": {
- "amount": "1234.56",
- "currency": "USD"
}, - "category_confidence": 0,
- "category_heron_id": "string",
- "category_label": "string",
- "counterparty": "string",
- "description": "string",
- "heron_id": "string",
- "merchant_heron_id": "string",
- "merchant_name": "string",
- "timestamp": "2019-08-24T14:15:22Z"
}
]
}
]
Get EndUser scorecard
Get scorecard metrics and rule violations for a user
Authorizations:
path Parameters
end_user_id_or_heron_id required | string |
query Parameters
named_date | string or null Default: null Enum: "end_user_created" "end_user_last_updated" "last_transaction" "end_user_last_enriched" "last_data_source_end_date_or_transaction_timestamp" "custom_date" Example: named_date=end_user_created Qualitative description for date to calculate scorecard |
date | string or null <date> Default: null Example: date=2023-01-19 Cut-off date to consider transactions to for calculating scorecard (inclusive) |
Responses
Response samples
- 200
{- "metrics": [
- {
- "context": "higher_is_better",
- "currency": "string",
- "date_range": "last_180_days",
- "description": "The number of unique transactions with a timestamp",
- "group": "data_quality",
- "label": "unique_transactions",
- "status": "not_available",
- "unit": "n",
- "value": 42.42
}
], - "rule_violations": [
- {
- "metric": {
- "context": "higher_is_better",
- "currency": "string",
- "date_range": "last_180_days",
- "description": "The number of unique transactions with a timestamp",
- "group": "data_quality",
- "label": "unique_transactions",
- "status": "not_available",
- "unit": "n",
- "value": 42.42
}, - "rule": {
- "condition": "equal",
- "created": "2024-12-05T10:27:12.304883",
- "date_range": "last_180_days",
- "group": "data_quality_datasource",
- "heron_id": "rul_GHVbrAZFWmfDcszwjZsEBT",
- "last_updated": "2025-01-16T10:27:12.304927",
- "metric_label": "unique_transactions",
- "name": "notify_if_debt_investment_count_gt_0_last_180d",
- "selector": {
- "is_portfolio": true
}, - "value": 42.42,
- "value_str": "mrc_12345678ijwdd321d921"
}
}
]
}
Request EndUser scorecard
Request scorecard metrics for a date and end user
Authorizations:
path Parameters
end_user_id_or_heron_id required | string |
query Parameters
date required | string <date> Example: date=2023-01-19 Cut-off date to consider transactions to for calculating scorecard (inclusive) |
Responses
Response samples
- 202
{- "message": "string"
}
Get EndUser transaction data coverage
Information about dates covered by any transaction data source
Authorizations:
path Parameters
end_user_id_or_heron_id required | string |
query Parameters
start_date required | string <date> |
end_date required | string <date> |
Responses
Response samples
- 200
{- "by_account": {
- "property1": [
- {
- "account_number": "string",
- "data_source_type": "string",
- "ranges": [
- {
- "data_source_account": {
- "account_id": "202348",
- "anomaly_score": 200,
- "balances": [
- {
- "closing_amount": 25000.45,
- "currency": "USD",
- "date": "2022-01-01"
}
], - "currency": "USD",
- "end_date": "2022-01-31",
- "heron_id": "dso_98xKHY3ciUkcL9ypYif3JH",
- "institution_name": "Chase",
- "is_enabled": true,
- "max_date": "2022-01-31",
- "min_date": "2022-01-01",
- "name": "Checking Account",
- "num_transactions": 120,
- "number": "123456789",
- "owner_name": "John Doe",
- "reference_id": "account-202348",
- "start_date": "2022-01-01",
- "transactions_match_balances": true,
- "type": "Checking"
}, - "end_date": "2019-08-24",
- "has_coverage": true,
- "is_enabled": true,
- "start_date": "2019-08-24"
}
]
}
], - "property2": [
- {
- "account_number": "string",
- "data_source_type": "string",
- "ranges": [
- {
- "data_source_account": {
- "account_id": "202348",
- "anomaly_score": 200,
- "balances": [
- {
- "closing_amount": 25000.45,
- "currency": "USD",
- "date": "2022-01-01"
}
], - "currency": "USD",
- "end_date": "2022-01-31",
- "heron_id": "dso_98xKHY3ciUkcL9ypYif3JH",
- "institution_name": "Chase",
- "is_enabled": true,
- "max_date": "2022-01-31",
- "min_date": "2022-01-01",
- "name": "Checking Account",
- "num_transactions": 120,
- "number": "123456789",
- "owner_name": "John Doe",
- "reference_id": "account-202348",
- "start_date": "2022-01-01",
- "transactions_match_balances": true,
- "type": "Checking"
}, - "end_date": "2019-08-24",
- "has_coverage": true,
- "is_enabled": true,
- "start_date": "2019-08-24"
}
]
}
]
}, - "end_user_heron_id": "string",
- "reconciliation_by_account": {
- "property1": {
- "account_number": "string",
- "ranges": [
- {
- "end_date": "2019-08-24",
- "reconciliation_report_by_date": {
- "property1": [
- {
- "data_source_account_heron_id": "string",
- "date": "2019-08-24",
- "metrics": [
- {
- "category_label": null,
- "metric": null,
- "value": null
}
]
}
], - "property2": [
- {
- "data_source_account_heron_id": "string",
- "date": "2019-08-24",
- "metrics": [
- {
- "category_label": null,
- "metric": null,
- "value": null
}
]
}
]
}, - "reconciliation_status": "no_data",
- "start_date": "2019-08-24"
}
]
}, - "property2": {
- "account_number": "string",
- "ranges": [
- {
- "end_date": "2019-08-24",
- "reconciliation_report_by_date": {
- "property1": [
- {
- "data_source_account_heron_id": "string",
- "date": "2019-08-24",
- "metrics": [
- {
- "category_label": null,
- "metric": null,
- "value": null
}
]
}
], - "property2": [
- {
- "data_source_account_heron_id": "string",
- "date": "2019-08-24",
- "metrics": [
- {
- "category_label": null,
- "metric": null,
- "value": null
}
]
}
]
}, - "reconciliation_status": "no_data",
- "start_date": "2019-08-24"
}
]
}
}
}
Get EndUser attribute values
Get calculated attribute values for a given end user
Authorizations:
path Parameters
end_user_heron_id required | string |
Responses
Response samples
- 200
[- {
- "attribute": {
- "label": "string",
- "type": "float"
}, - "availability": "available",
- "value": null
}
]
Bulk create category feedback for an end user
Provide bulk feedback on Transaction Categories for a specified end user
Authorizations:
path Parameters
end_user_id_or_heron_id required | string |
query Parameters
high_priority | boolean Default: false Whether to process the feedback with high priority |
Request Body schema: application/json
A list of objects containing a Transaction's heron id and the suggested Category. If you provide a heron_id
for Category, you don't need to provide other fields. If heron_id
is provided, we disregard label
.
required | object (CategoryFeedback) |
source | string or null <= 120 characters Default: null your identifier for where the feedback comes from e.g. bob_the_underwriter |
transaction_heron_ids | Array of strings Default: [] List of transaction heron IDs |
transaction_reference_ids | Array of strings Default: [] List of transaction reference IDs |
Responses
Request samples
- Payload
{- "category": {
- "heron_id": "ctg_jagpWc3R92Va58x2SQfwc2",
- "label": "Insurance"
}, - "source": null,
- "transaction_heron_ids": [ ],
- "transaction_reference_ids": [ ]
}
Response samples
- 201
{- "num_annotations": 1
}
Create category, merchant feedback
Provide feedback on a Transaction's Categories and Merchants
Authorizations:
path Parameters
heron_id required | string Transaction |
Request Body schema: application/json
A partial Transaction object with the suggested Category and/or Merchant. If you provide a heron_id
for Category or Merchant, you don't need to provide other fields. If you don't know the Merchant heron_id
nor name, you can just send the is_correct
boolean. If heron_id
is provided, we disregard name
and label
. If is_correct
is set to true, we disregard all other Merchant fields.
object (TransactionFeedbackSchema) | |||||||
|
Responses
Request samples
- Payload
{- "transaction": {
- "category": {
- "heron_id": "ctg_VPuFygPvFNB8dcFGdjQhuj",
- "label": "Insurance"
}, - "merchant": {
- "heron_id": "mrc_hCNNw2GksziSduqqGRoBBG",
- "is_correct": false,
- "name": "Spotify"
}, - "source": null
}
}
Get EndUser's combined financials
Get the combined P&L & Balance Sheet data from financial documents for an EndUser
Authorizations:
path Parameters
end_user_id_or_heron_id required | string |
query Parameters
grouping | string or null Enum: "by_month" "by_quarter" "by_year" |
Responses
Response samples
- 200
{- "by_category": [
- {
- "label": "string",
- "time_period_label": "string",
- "value": 0
}
], - "by_sub_category": [
- {
- "label": "string",
- "time_period_label": "string",
- "value": 0
}
], - "currency": "string",
- "grouping": "by_month",
- "metrics": [
- {
- "label": "string",
- "time_period_label": "string",
- "value": 0
}
]
}
Evaluate all rules for an end user
Authorizations:
path Parameters
end_user_id_or_heron_id required | string |
Responses
Response samples
- 200
[- {
- "metric": {
- "context": "higher_is_better",
- "currency": "string",
- "date_range": "last_180_days",
- "description": "The number of unique transactions with a timestamp",
- "group": "data_quality",
- "label": "unique_transactions",
- "status": "not_available",
- "unit": "n",
- "value": 42.42
}, - "result": "PASS",
- "rule": {
- "condition": "equal",
- "created": "2024-12-05T10:27:12.304883",
- "date_range": "last_180_days",
- "group": "data_quality_datasource",
- "heron_id": "rul_GHVbrAZFWmfDcszwjZsEBT",
- "last_updated": "2025-01-16T10:27:12.304927",
- "metric_label": "unique_transactions",
- "name": "notify_if_debt_investment_count_gt_0_last_180d",
- "selector": {
- "is_portfolio": true
}, - "value": 42.42,
- "value_str": "mrc_12345678ijwdd321d921"
}
}
]
Send a Finicity Connect email to an end user
Create a Finicity Link for an end user and send a Finicity Connect email to the end user to initiate the connection. The end user must have sufficient end user information to create the link.
Authorizations:
path Parameters
end_user_id_or_heron_id required | string |
Responses
Trigger a cashflow report generation for an end user
Request a cashflow report generation for an end user. When the report is ready it will be available as EndUserFile.
Authorizations:
path Parameters
end_user_id_or_heron_id required | string |
Request Body schema: application/json
applicant_is_personal_guarantor required | boolean |
for_cra_purpose required | boolean |
user_type required | string Enum: "personal" "business" |
Responses
Request samples
- Payload
{- "applicant_is_personal_guarantor": true,
- "for_cra_purpose": true,
- "user_type": "personal"
}
Trigger a statement reports generation for an end user
Request a Finicity statement reports generation for end user. Reports will be generated for each account available and each month going back in time between min_statement_index and max_statement_index. When the report is ready it will be available as EndUserFile.
Authorizations:
path Parameters
end_user_id_or_heron_id required | string |
Request Body schema: application/json
max_statement_index | integer Default: 24 |
min_statement_index | integer Default: 1 |
Responses
Request samples
- Payload
{- "max_statement_index": 24,
- "min_statement_index": 1
}
Trigger a Finicity VOE transactions report generation for an end user
Request a Finicity VOE transactions report generation for an end user. When the report is ready it will be available as an EndUserFile.
Authorizations:
path Parameters
end_user_id_or_heron_id required | string |
Request Body schema: application/json
from_date | string <date-time> |
Responses
Request samples
- Payload
{- "from_date": "2019-08-24T14:15:22Z"
}
Update an Integration Link
Allows refreshing the access_token of an existing Integration Link
Authorizations:
path Parameters
item_id required | string |
Request Body schema: application/json
IntegrationLink
object (IntegrationLinkUpdateSchema) | |||
|
Responses
Request samples
- Payload
{- "end_user": {
- "access_token": "access-sandbox-de3ce8ef-33f8-452c-a685-8671031fc0f6"
}
}
Response samples
- 200
{- "integration_link": {
- "created": "2020-01-01T00:00:00Z",
- "item_id": "M5eVJqLnv3tbzdngLDp9FL5OlDNxlNhlE55op",
- "last_successful_sync": "2020-01-01T00:00:00Z",
- "last_updated": "2020-01-01T00:00:00Z",
- "status": "active",
- "status_message": "[ITEM_LOGIN_REQUIRED] the login details of this item have changed (credentials, MFA, or required user action) and a user login is required to update this information. use Link's update mode to restore the item to a good state",
- "type": "plaid_assets_report"
}
}
Response samples
- 200
{- "integrations": [
- {
- "client_id": "string",
- "client_secret": "string",
- "heron_id": "string",
- "name": "Plaid Prod",
- "resource": "transaction",
- "type": "plaid",
}
]
}
Create an integration
Create an integration e.g. with Plaid
Authorizations:
Request Body schema: application/json
object (IntegrationSchema) | |||||||||||||||||
|
Responses
Request samples
- Payload
{- "integration": {
- "client_auth": { },
- "client_id": "string",
- "client_secret": "string",
- "name": "Plaid Prod",
- "resource": "transaction",
- "type": "plaid",
}
}
Response samples
- 201
{- "integration": {
- "client_id": "string",
- "client_secret": "string",
- "heron_id": "string",
- "name": "Plaid Prod",
- "resource": "transaction",
- "type": "plaid",
}
}
Update Integration
Update an Integration
Authorizations:
path Parameters
heron_id required | string |
Request Body schema: application/json
Integration
object (IntegrationSchema) | |||||||||||||||||
|
Responses
Request samples
- Payload
{- "end_user": {
- "client_auth": { },
- "client_id": "string",
- "client_secret": "string",
- "name": "Plaid Prod",
- "resource": "transaction",
- "type": "plaid",
}
}
Response samples
- 200
{- "integration": {
- "client_id": "string",
- "client_secret": "string",
- "heron_id": "string",
- "name": "Plaid Prod",
- "resource": "transaction",
- "type": "plaid",
}
}
Get IntegrationLinks by Integration
Get a list of IntegrationLinks for an Integration filtered by end user
Authorizations:
path Parameters
heron_id required | string The Integration's heron_id |
query Parameters
end_user_id_or_heron_id required | string Return only IntegrationLinks for that end user |
Responses
Response samples
- 200
{- "links": [
- {
- "created": "2020-01-01T00:00:00Z",
- "item_id": "M5eVJqLnv3tbzdngLDp9FL5OlDNxlNhlE55op",
- "last_successful_sync": "2020-01-01T00:00:00Z",
- "last_updated": "2020-01-01T00:00:00Z",
- "status": "active",
- "status_message": "[ITEM_LOGIN_REQUIRED] the login details of this item have changed (credentials, MFA, or required user action) and a user login is required to update this information. use Link's update mode to restore the item to a good state",
- "type": "plaid_assets_report"
}
]
}
Create an integration Link
Create a Link for an active Integration every time a customer connects their bank. In Plaid, this is a Plaid Link every time a customer connects their bank. For Plaid, call this after exchanging a public token for an Item access_token.
Authorizations:
path Parameters
heron_id required | string |
Request Body schema: application/json
access_token required | string The generated token that grants access to the bank (this is encrypted in transit and at-rest with a custom key) |
end_user_id required | string A unique identifier for your end user (customer) generated by you |
end_user_name | string An human readable name for this end user, like the company legal name |
item_id required | string Unique identifier for each bank connection made by your end users. In Plaid this is the 'item_id'. |
Responses
Request samples
- Payload
{- "access_token": "access-sandbox-de3ce8ef-33f8-452c-a685-8671031fc0f6",
- "end_user_id": "0f84e19a-5f55-4b39-8018-3a88d7b14819",
- "end_user_name": "Acme Corp",
- "item_id": "M5eVJqLnv3tbzdngLDp9FL5OlDNxlNhlE55op"
}
Response samples
- 201
{- "link": {
- "created": "2020-01-01T00:00:00Z",
- "data_source_heron_id": "string",
- "item_id": "M5eVJqLnv3tbzdngLDp9FL5OlDNxlNhlE55op",
- "last_successful_sync": "2020-01-01T00:00:00Z",
- "last_updated": "2020-01-01T00:00:00Z",
- "status": "active",
- "status_message": "[ITEM_LOGIN_REQUIRED] the login details of this item have changed (credentials, MFA, or required user action) and a user login is required to update this information. use Link's update mode to restore the item to a good state",
- "type": "plaid_assets_report"
}
}
Refresh an IntegrationLink
Trigger a refresh operation for an IntegrationLink
Authorizations:
path Parameters
heron_id required | string The Integration's heron_id |
link_item_id required | string The IntegrationLink's item_id |
Responses
Response samples
- 200
{- "link": {
- "created": "2020-01-01T00:00:00Z",
- "item_id": "M5eVJqLnv3tbzdngLDp9FL5OlDNxlNhlE55op",
- "last_successful_sync": "2020-01-01T00:00:00Z",
- "last_updated": "2020-01-01T00:00:00Z",
- "status": "active",
- "status_message": "[ITEM_LOGIN_REQUIRED] the login details of this item have changed (credentials, MFA, or required user action) and a user login is required to update this information. use Link's update mode to restore the item to a good state",
- "type": "plaid_assets_report"
}
}
Upload Inscribe
Upload Inscribe JSON for a specified end user to translate into Heron Data format and add transactions for the end user
Authorizations:
path Parameters
end_user_id_or_heron_id required | string The |
Request Body schema: application/json
customer_name | string or null Default: null |
object (InscribeParsedDetails) |
Responses
Request samples
- Payload
{- "customer_name": null,
- "parsed_details": {
- "bank_accounts": [
- {
- "account_type": "string",
- "beginning_balance": {
- "confidence": 0,
- "normalized": 0,
- "raw": "string"
}, - "ending_balance": {
- "confidence": 0,
- "normalized": 0,
- "raw": "string"
}, - "institution_name": "string",
- "number": {
- "confidence": 0,
- "normalized": "string",
- "raw": "string"
}, - "transactions": [
- {
- "amount": 0,
- "date": "2019-08-24",
- "description": "string",
- "id": "string"
}
], - "transactions_match_balances": true
}
], - "name": {
- "raw": "string"
}
}
}
Response samples
- 201
{- "_summary": {
- "request_id": "string"
}
}
Get Integration Links
Get a list of integration links for a specified end user
Authorizations:
path Parameters
end_user_id_or_heron_id required | string The |
Responses
Response samples
- 200
{- "links": [
- {
- "created": "2020-01-01T00:00:00Z",
- "item_id": "M5eVJqLnv3tbzdngLDp9FL5OlDNxlNhlE55op",
- "last_successful_sync": "2020-01-01T00:00:00Z",
- "last_updated": "2020-01-01T00:00:00Z",
- "status": "active",
- "status_message": "[ITEM_LOGIN_REQUIRED] the login details of this item have changed (credentials, MFA, or required user action) and a user login is required to update this information. use Link's update mode to restore the item to a good state",
- "type": "plaid_assets_report"
}
]
}
Upload Ocrolus
Upload Ocrolus JSON for a specified end user to translate into Heron Data format and add transactions for the end user
Authorizations:
path Parameters
end_user_id_or_heron_id required | string The |
query Parameters
skip_num_txns_check | boolean Skip the check for the number of transactions in the payload |
Request Body schema: application/json
required | object (OcrolusResponse) | ||||
|
Responses
Request samples
- Payload
{- "response": {
- "bank_accounts": [
- {
- "account_category": "string",
- "account_number": "string",
- "alternative_lender_transactions": [
- {
- "amount": "string",
- "description": "string",
- "pk": 0,
- "timestamp": "2019-08-24T14:15:22Z",
- "txn_date": "2019-08-24"
}
], - "daily_balances": {
- "property1": "string",
- "property2": "string"
}, - "debt_consolidator_txns": [
- {
- "amount": "string",
- "description": "string",
- "pk": 0,
- "timestamp": "2019-08-24T14:15:22Z",
- "txn_date": "2019-08-24"
}
], - "deposits_max_by_month": {
- "property1": [
- {
- "amount": "string",
- "description": "string",
- "pk": 0,
- "timestamp": "2019-08-24T14:15:22Z",
- "txn_date": "2019-08-24"
}
], - "property2": [
- {
- "amount": "string",
- "description": "string",
- "pk": 0,
- "timestamp": "2019-08-24T14:15:22Z",
- "txn_date": "2019-08-24"
}
]
}, - "estimated_expense_txns_list": [
- {
- "amount": "string",
- "description": "string",
- "pk": 0,
- "timestamp": "2019-08-24T14:15:22Z",
- "txn_date": "2019-08-24"
}
], - "estimated_revenue_txns_list": [
- {
- "amount": "string",
- "description": "string",
- "pk": 0,
- "timestamp": "2019-08-24T14:15:22Z",
- "txn_date": "2019-08-24"
}
], - "factor_txns": [
- {
- "amount": "string",
- "description": "string",
- "pk": 0,
- "timestamp": "2019-08-24T14:15:22Z",
- "txn_date": "2019-08-24"
}
], - "holder_country": "string",
- "insurance_credits": [
- {
- "amount": "string",
- "description": "string",
- "pk": 0,
- "timestamp": "2019-08-24T14:15:22Z",
- "txn_date": "2019-08-24"
}
], - "insurance_debits": [
- {
- "amount": "string",
- "description": "string",
- "pk": 0,
- "timestamp": "2019-08-24T14:15:22Z",
- "txn_date": "2019-08-24"
}
], - "interbank_transactions": [
- {
- "amount": "string",
- "description": "string",
- "pk": 0,
- "timestamp": "2019-08-24T14:15:22Z",
- "txn_date": "2019-08-24"
}
], - "merchant_cash_advance_lender_txns": [
- {
- "amount": "string",
- "description": "string",
- "pk": 0,
- "timestamp": "2019-08-24T14:15:22Z",
- "txn_date": "2019-08-24"
}
], - "non_estimated_revenue_txns_list": [
- {
- "amount": "string",
- "description": "string",
- "pk": 0,
- "timestamp": "2019-08-24T14:15:22Z",
- "txn_date": "2019-08-24"
}
], - "nsf_transactions": [
- {
- "amount": "string",
- "description": "string",
- "pk": 0,
- "timestamp": "2019-08-24T14:15:22Z",
- "txn_date": "2019-08-24"
}
], - "nsf_transactions_paid_or_negative_balance": [
- {
- "amount": "string",
- "description": "string",
- "pk": 0,
- "timestamp": "2019-08-24T14:15:22Z",
- "txn_date": "2019-08-24"
}
], - "nsf_transactions_returned_or_not_paid": [
- {
- "amount": "string",
- "description": "string",
- "pk": 0,
- "timestamp": "2019-08-24T14:15:22Z",
- "txn_date": "2019-08-24"
}
], - "outside_source_deposits": [
- {
- "amount": "string",
- "description": "string",
- "pk": 0,
- "timestamp": "2019-08-24T14:15:22Z",
- "txn_date": "2019-08-24"
}
], - "payroll": [
- {
- "amount": "string",
- "description": "string",
- "pk": 0,
- "timestamp": "2019-08-24T14:15:22Z",
- "txn_date": "2019-08-24"
}
], - "period_balance_mismatches": [
- {
- "amount": "string",
- "description": "string",
- "pk": 0,
- "timestamp": "2019-08-24T14:15:22Z",
- "txn_date": "2019-08-24"
}
], - "ppp_loan_txns": [
- {
- "amount": "string",
- "description": "string",
- "pk": 0,
- "timestamp": "2019-08-24T14:15:22Z",
- "txn_date": "2019-08-24"
}
], - "probable_recurring_txns": [
- [
- {
- "amount": "string",
- "description": "string",
- "pk": 0,
- "timestamp": "2019-08-24T14:15:22Z",
- "txn_date": "2019-08-24"
}
]
], - "returned_items": [
- {
- "amount": "string",
- "description": "string",
- "pk": 0,
- "timestamp": "2019-08-24T14:15:22Z",
- "txn_date": "2019-08-24"
}
], - "round_number_txns": [
- {
- "amount": "string",
- "description": "string",
- "pk": 0,
- "timestamp": "2019-08-24T14:15:22Z",
- "txn_date": "2019-08-24"
}
], - "txn_count": 0,
- "withdrawals": [
- {
- "amount": "string",
- "description": "string",
- "pk": 0,
- "timestamp": "2019-08-24T14:15:22Z",
- "txn_date": "2019-08-24"
}
], - "withdrawals_max_by_month": {
- "property1": [
- {
- "amount": "string",
- "description": "string",
- "pk": 0,
- "timestamp": "2019-08-24T14:15:22Z",
- "txn_date": "2019-08-24"
}
], - "property2": [
- {
- "amount": "string",
- "description": "string",
- "pk": 0,
- "timestamp": "2019-08-24T14:15:22Z",
- "txn_date": "2019-08-24"
}
]
}
}
], - "name": "string"
}
}
Response samples
- 201
{- "_summary": {
- "request_id": "string"
}
}
Get PDFs
Get list of PDFs for a specified end user
Authorizations:
path Parameters
end_user_id_or_heron_id required | string The |
query Parameters
with_processed_results | boolean Include processed results where applicable per pdf |
Responses
Response samples
- 200
{- "pdfs": [
- {
- "account_id": "checking_account_202348",
- "created": "2025-01-16T10:27:11.768559",
- "currency": "USD",
- "end_user": {
- "heron_id": "eus_ZUqkYBeBJ7i95px73nqyDR"
}, - "filename": "my-favourite.pdf",
- "heron_id": "pdf_53Vhu84ioG6ydSy9J4MGyS",
- "is_image_based": true,
- "last_updated": "2025-01-16T10:27:11.768599",
- "notes": "failed to send to external OCR provider",
- "parsing_version": "string",
- "reference_id": "my-favourite-pdf",
- "statements": [
- {
- "exclude": true,
- "invalid_transaction_partials": [
- {
- "amount": 0,
- "balance": 0,
- "bounds": {
- "page": 0,
- "x_max": 0,
- "x_min": 0,
- "y_max": 0,
- "y_min": 0
}, - "currency": "string",
- "description": "string",
- "ocr_suspect": true,
- "reference_id": "string",
- "timestamp": "2019-08-24T14:15:22Z",
- "transaction_code": "string"
}
], - "summary": {
- "account_number": "string",
- "account_title": "string",
- "bank_name": "string",
- "company": "string",
- "currency": "string",
- "end_balance": 0,
- "fraud_reasons": [
- "string"
], - "fraud_score": 0,
- "is_business_account": true,
- "is_ocr": true,
- "max_resolution": 0,
- "min_resolution": 0,
- "num_credits": 0,
- "num_debits": 0,
- "num_transactions": 0,
- "reconciled": true,
- "start_balance": 0,
- "statement_end_date": "2019-08-24T14:15:22Z",
- "statement_start_date": "2019-08-24T14:15:22Z",
- "total_credits": 0,
- "total_debits": 0,
- "unreconciled_end_balance": 0,
- "web_report": true
}, - "transaction_partials": [
- {
- "amount": 0,
- "balance": 0,
- "bounds": {
- "page": 0,
- "x_max": 0,
- "x_min": 0,
- "y_max": 0,
- "y_min": 0
}, - "currency": "string",
- "description": "string",
- "ocr_suspect": true,
- "reference_id": "string",
- "timestamp": "2019-08-24T14:15:22Z",
- "transaction_code": "string"
}
]
}
], - "status": "processed"
}
]
}
Parse all PDF
Starts parsing all PDFs for a specified end users. This will not restart any PDFs that are already being parsed
Authorizations:
path Parameters
end_user_id_or_heron_id required | string The |
Responses
Response samples
- 200
{- "pdf_heron_ids": [
- "string"
], - "request_id": "string"
}
Upload PDF
Upload encoded PDF of transactions for a specified end user to translate into Heron Data format
Authorizations:
path Parameters
end_user_id_or_heron_id required | string The |
Request Body schema: application/json
account_id | string or null Default: null Unique ID for account associated with PDF |
currency | string or null Default: null Enum: "USD" "GBP" ISO 4217 currency code for transactions in account. We currently only support GBP and USD PDFs |
filename | string or null Default: null The filename of the PDF |
pdf_base64 required | string^data\:\w+\/\w+\;base64\, The base64 encoded string of the PDF file. If using Javascript, this is directly the output of the FileReader.readAsDataURL() output. See https://developer.mozilla.org/en-US/docs/Web/API/FileReader/readAsDataURL for more info |
read_us_dates | boolean or null Default: null True if date formats in the statement are US: month/date/year |
reference_id | string or null <= 140 characters Default: null An optional field for your unique identifier for the PDF |
with_fraud | boolean or null Default: null True if fraud detection should be enabled for this PDF |
Responses
Request samples
- Payload
{- "account_id": "checking_account_202348",
- "currency": "USD",
- "filename": "my-favourite.pdf",
- "pdf_base64": "string",
- "read_us_dates": null,
- "reference_id": "my-favourite-pdf",
- "with_fraud": null
}
Response samples
- 201
{- "pdf_heron_id": "string",
- "request_id": "string"
}
Upload Plaid assets
Upload Plaid asset JSON for a specified end user to translate into Heron Data format and add transactions for the end user
Authorizations:
path Parameters
end_user_id_or_heron_id required | string The |
Request Body schema: application/json
required | object (PlaidAssetReport) | ||||||
|
Responses
Request samples
- Payload
{- "report": {
- "date_generated": "2019-08-24T14:15:22Z",
- "days_requested": 0,
- "items": [
- {
- "accounts": [
- {
- "account_id": "string",
- "balances": {
- "available": 0,
- "current": 0,
- "iso_currency_code": "string",
- "limit": 0
}, - "historical_balances": [
- {
- "current": 0,
- "date": "2019-08-24",
- "iso_currency_code": "USD"
}
], - "mask": "string",
- "name": "string",
- "official_name": "string",
- "owners": [
- {
- "names": [
- "string"
]
}
], - "subtype": "string",
- "transactions": [
- {
- "account_id": "string",
- "amount": 0,
- "balance": 0,
- "category": "string",
- "date": "2019-08-24",
- "iso_currency_code": "USD",
- "merchant_name": "string",
- "name": "string",
- "pending": true,
- "pending_transaction_id": null,
- "timestamp": "2019-08-24T14:15:22Z",
- "transaction_code": "string",
- "transaction_id": "string"
}
], - "type": "string"
}
], - "institution_name": "string"
}
]
}
}
Response samples
- 201
{- "_summary": {
- "request_id": "string"
}
}
Upload Plaid transactions
Upload Plaid transactions JSON for a specified end user to translate into Heron Data format and add transactions for the end user
Authorizations:
path Parameters
end_user_id_or_heron_id required | string The |
Request Body schema: application/json
Array of objects (PlaidAccountSnapshot) | |
required | Array of objects (PlaidTransaction) |
Responses
Request samples
- Payload
{- "accounts": [
- {
- "account_id": "string",
- "balances": {
- "available": 0,
- "current": 0,
- "iso_currency_code": "string",
- "limit": 0
}, - "mask": "string",
- "name": "string",
- "official_name": "string",
- "subtype": "string",
- "type": "string"
}
], - "transactions": [
- {
- "account_id": "string",
- "amount": 0,
- "balance": 0,
- "category": "string",
- "date": "2019-08-24",
- "iso_currency_code": "USD",
- "merchant_name": "string",
- "name": "string",
- "pending": true,
- "pending_transaction_id": null,
- "timestamp": "2019-08-24T14:15:22Z",
- "transaction_code": "string",
- "transaction_id": "string"
}
]
}
Response samples
- 201
{- "_summary": {
- "request_id": "string"
}
}
Upload Yodlee
Upload Yodlee JSON files for a specified end user to translate into Heron Data format and add transactions for the end user
Authorizations:
path Parameters
end_user_id_or_heron_id required | string The |
Request Body schema: application/json
Array of objects (YodleeAccount) | |
Array of objects (YodleeTransaction) |
Responses
Request samples
- Payload
{- "accounts": [
- {
- "balance": {
- "amount": 0,
- "currency": "string"
}, - "classification": "string",
- "id": 0
}
], - "transactions": [
- {
- "accountId": 0,
- "amount": {
- "amount": 0,
- "currency": "string"
}, - "baseType": "CREDIT",
- "category": "string",
- "date": "2019-08-24T14:15:22Z",
- "description": {
- "original": "string",
- "simple": "string"
}, - "id": 0
}
]
}
Response samples
- 201
{- "_summary": {
- "request_id": "string"
}
}
Update PDF attributes including status
Update PDF attributes including status
Authorizations:
path Parameters
heron_id required | string heron_id of the pdf |
Request Body schema: application/json
filename | string The filename of the PDF |
fraud_reason | string or null If fraud reason |
is_fraud | boolean True if fraud was detected in the PDF |
notes | string Notes associated with PDF, e.g., rejected reason, failed reason |
reference_id | string <= 140 characters An optional field for your unique identifier for the PDF |
status | string Enum: "new" "parsing" "parsed" "processed" "human_reviewing" "approved" "rejected" "failed" "transactions_loaded" "transactions_unloaded" Status of PDF |
Responses
Request samples
- Payload
{- "filename": "my-favourite.pdf",
- "fraud_reason": "string",
- "is_fraud": true,
- "notes": "string",
- "reference_id": "my-favourite-pdf",
- "status": "processed"
}
Response samples
- 200
{- "pdf": {
- "account_id": "checking_account_202348",
- "created": "2025-01-16T10:27:11.768559",
- "currency": "USD",
- "end_user": {
- "heron_id": "eus_ZUqkYBeBJ7i95px73nqyDR"
}, - "filename": "my-favourite.pdf",
- "heron_id": "pdf_53Vhu84ioG6ydSy9J4MGyS",
- "is_image_based": true,
- "last_updated": "2025-01-16T10:27:11.768599",
- "notes": "failed to send to external OCR provider",
- "parsing_version": "string",
- "reference_id": "my-favourite-pdf",
- "statements": [
- {
- "exclude": true,
- "invalid_transaction_partials": [
- {
- "amount": 0,
- "balance": 0,
- "bounds": {
- "page": 0,
- "x_max": 0,
- "x_min": 0,
- "y_max": 0,
- "y_min": 0
}, - "currency": "string",
- "description": "string",
- "ocr_suspect": true,
- "reference_id": "string",
- "timestamp": "2019-08-24T14:15:22Z",
- "transaction_code": "string"
}
], - "summary": {
- "account_number": "string",
- "account_title": "string",
- "bank_name": "string",
- "company": "string",
- "currency": "string",
- "end_balance": 0,
- "fraud_reasons": [
- "string"
], - "fraud_score": 0,
- "is_business_account": true,
- "is_ocr": true,
- "max_resolution": 0,
- "min_resolution": 0,
- "num_credits": 0,
- "num_debits": 0,
- "num_transactions": 0,
- "reconciled": true,
- "start_balance": 0,
- "statement_end_date": "2019-08-24T14:15:22Z",
- "statement_start_date": "2019-08-24T14:15:22Z",
- "total_credits": 0,
- "total_debits": 0,
- "unreconciled_end_balance": 0,
- "web_report": true
}, - "transaction_partials": [
- {
- "amount": 0,
- "balance": 0,
- "bounds": {
- "page": 0,
- "x_max": 0,
- "x_min": 0,
- "y_max": 0,
- "y_min": 0
}, - "currency": "string",
- "description": "string",
- "ocr_suspect": true,
- "reference_id": "string",
- "timestamp": "2019-08-24T14:15:22Z",
- "transaction_code": "string"
}
]
}
], - "status": "processed"
}, - "request_id": "string"
}
Send patch transactions for a pdf statement
Send patch transactions processed pdf that will override the extracted transactions in the specified statement
Authorizations:
path Parameters
heron_id required | string heron_id of the pdf |
Request Body schema: application/json
exclude | boolean True if the statement should be excluded from processing |
index required | integer The index of the statement in the pdf to patch |
object (PdfPatchStatementSummary) | |
required | Array of objects (PdfPatchTransaction) The full list of transactions that will be used to override the extracted transactions for the specified statement |
Responses
Request samples
- Payload
{- "exclude": true,
- "index": 0,
- "summary": {
- "account_number": "string",
- "bank_name": "string",
- "company": "string",
- "currency": "string",
- "end_balance": 0,
- "fraud_reasons": [
- "string"
], - "fraud_score": 0,
- "start_balance": 0,
- "statement_end_date": "2019-08-24T14:15:22Z",
- "statement_start_date": "2019-08-24T14:15:22Z"
}, - "transactions": [
- {
- "amount": 0,
- "balance": 0,
- "bounds": {
- "page": 0,
- "x_max": 0,
- "x_min": 0,
- "y_max": 0,
- "y_min": 0
}, - "currency": "string",
- "description": "string",
- "ocr_suspect": true,
- "reference_id": "string",
- "timestamp": "2019-08-24T14:15:22Z",
- "transaction_code": "string"
}
]
}
Response samples
- 200
{- "ok": true
}
Upload an ISO application PDF for for an end user
Use this endpoint to upload an ISO application PDF. Once uploaded, the file will be automatically scrubbed asynchronously. You can use the returned iso_application heron_id (prefixed "iso_") to fetch the scrubbing results. Please contact support@herondata.io to enable this endpoint.
Authorizations:
path Parameters
end_user_id_or_heron_id required | string |
Request Body schema: multipart/form-data
file | string <binary> |
Responses
Response samples
- 200
{- "bank_statement": null,
- "created": "2019-08-24T14:15:22Z",
- "email": null,
- "file_class": "other",
- "filename": "string",
- "heron_id": "string",
- "iso_application": {
- "heron_id": "iso_6hBjQT9k6KP2rLCXwjUJff",
- "processing_status": "processed"
}, - "page_classes": {
- "property1": {
- "confidence": 1,
- "file_class": "other"
}, - "property2": {
- "confidence": 1,
- "file_class": "other"
}
}, - "parent_heron_id": "string",
- "parsed_results": [ ],
- "reference_id": "string",
- "renamed_filename": "string"
}
Get EndUser ISO Applications
Get all ISO applications for an end user
Authorizations:
path Parameters
end_user_id_or_heron_id required | string |
Responses
Response samples
- 200
[- {
- "created": "2019-08-24T14:15:22Z",
- "end_user_heron_id": "string",
- "end_user_id": "string",
- "field_validations": [
- {
- "failure_reason": "string",
- "field_name": "string",
- "result": "passed",
- "validation_type": "string"
}
], - "filename": "iso_app.pdf",
- "heron_id": "iso_6hBjQT9k6KP2rLCXwjUJff",
- "processing_status": "processed",
- "quality_status": "fully_matched",
- "result": {
- "property1": {
- "document_field_name": "Company Legal Name",
- "is_empty": false,
- "value": "Heron Data Ltd",
- "value_confidence": 0.99
}, - "property2": {
- "document_field_name": "Company Legal Name",
- "is_empty": false,
- "value": "Heron Data Ltd",
- "value_confidence": 0.99
}
}, - "source_email": {
- "date_sent": "2019-08-24T14:15:22Z",
- "date_sent_string": "string",
- "from_address": "string",
- "from_address_domain": "string",
- "from_name": "string",
- "html_body": "string",
- "html_or_text_body": "string",
- "subject": "string",
- "text_body": "string"
}
}
]
Upload an ISO application PDF for automated scrubbing in under 15 seconds
Use this endpoint to upload an ISO application PDF. Once uploaded, the file will be automatically scrubbed asynchronously. You can use the returned heron_id (prefixed "iso_") to fetch the scrubbing results from the GET endpoint below. Please contact support@herondata.io to enable this endpoint.
Authorizations:
Request Body schema: multipart/form-data
file | string <binary> |
Responses
Response samples
- 200
{- "heron_id": "string",
- "status": "processing"
}
Upload an ISO application PDF for automated scrubbing in under 15 seconds (base64)
This endpoint is for uploading ISO application PDFs in base64 format.
Authorizations:
Request Body schema: application/json
file_base64 required | string^data\:\w+\/\w+\;base64\, The base64 encoded string of the file |
filename required | string The original filename of the ISO application form |
reference_id | string or null Default: null A reference id for the file |
Responses
Request samples
- Payload
{- "file_base64": "base64_encoded_string",
- "filename": "iso_app.pdf",
- "reference_id": "your-file-id"
}
Response samples
- 200
{- "heron_id": "string",
- "status": "processing"
}
Get the scrubbed results and data validations of an uploaded ISO application by its heron_id (prefixed "iso_")
Use this endpoint to retrieve the scrubbed results and data validations of an uploaded ISO application PDF once it has finished processing. If processing is still underway, the processing_status field will be "processing".
Authorizations:
path Parameters
heron_id required | string |
Responses
Response samples
- 200
{- "created": "2019-08-24T14:15:22Z",
- "end_user_heron_id": "string",
- "end_user_id": "string",
- "field_validations": [
- {
- "failure_reason": "string",
- "field_name": "string",
- "result": "passed",
- "validation_type": "string"
}
], - "filename": "iso_app.pdf",
- "heron_id": "iso_6hBjQT9k6KP2rLCXwjUJff",
- "processing_status": "processed",
- "quality_status": "fully_matched",
- "result": {
- "property1": {
- "document_field_name": "Company Legal Name",
- "is_empty": false,
- "value": "Heron Data Ltd",
- "value_confidence": 0.99
}, - "property2": {
- "document_field_name": "Company Legal Name",
- "is_empty": false,
- "value": "Heron Data Ltd",
- "value_confidence": 0.99
}
}, - "source_email": {
- "date_sent": "2019-08-24T14:15:22Z",
- "date_sent_string": "string",
- "from_address": "string",
- "from_address_domain": "string",
- "from_name": "string",
- "html_body": "string",
- "html_or_text_body": "string",
- "subject": "string",
- "text_body": "string"
}
}
Get Missing Accounts (beta)
Get a list of possible missing accounts for a given End User. This endpoint is in beta and likely to change.
Authorizations:
path Parameters
end_user_id_or_heron_id required | string The |
Responses
Response samples
- 200
{- "missing_accounts": [
- {
- "account_name": "Checking",
- "account_number": "****4321",
- "transactions": [
- {
- "account_id": "checking_account_202348",
- "amount": -42.42,
- "currency": "USD",
- "heron_id": "txn_J2AN4abNxxEPYBeZenNZCb",
- "timestamp": "2021-11-12T10:38:05Z"
}
]
}
]
}
Get end user transactions
Get all unique transactions for a single end user. Set end user status to "ready" to initiate transaction enrichment, otherwise may contain both enriched and unenriched transactions
Authorizations:
path Parameters
end_user_id_or_heron_id required | string |
query Parameters
last_updated_min | string or null <date-time> Default: null Example: last_updated_min=2025-01-16T10:27:11.752617 Filter for transactions whose values were last updated in Heron systems after the specified input value, isoformat |
page | integer >= 1 Default: 1 Results page |
per_page | integer [ 1 .. 50000 ] Default: 100 Desired results per page |
Responses
Response samples
- 200
{- "_meta": {
- "next_url": "string",
- "num_results": 0,
- "page": 0,
- "per_page": 0,
- "prev_url": "string"
}, - "transactions_enriched": [
- {
- "account_id": "checking_account_202348",
- "amount": -42.42,
- "annotation": {
- "annotator": {
- "context": "sync",
- "priority_type": "gold_standard"
}, - "category": {
- "heron_id": "ctg_btJFzxZK8YUQiVASoBsdso",
- "label": "Rent"
}, - "confidence": 0,
- "model_version": "string"
}, - "balance": 423,
- "currency": "USD",
- "end_user_id": "my_best_customer_203948",
- "features": {
- "description_clean": "GOOGLE ADS",
- "duplicate_of_id": "txn_dygNyAPXTYFxMkKfpF9FEn",
- "has_matching_transaction": true,
- "is_potential_duplicate": true,
- "is_recurring": true
}, - "heron_id": "txn_J2AN4abNxxEPYBeZenNZCb",
- "last_updated": "2025-01-16T10:27:11.657837",
- "merchant": {
- "categories": [
- {
- "code": "7311",
- "description": "Advertising services",
- "slug": "advertising_services"
}
], - "group_id": "Uber",
- "heron_id": "mrc_GBDaec5u8gWTRAHVvXjyBD",
- "icon_url": "string",
- "is_priority": true,
- "logo_url": "string",
- "name": "string",
- "url": "string"
}, - "reference_id": "my_favourite_transaction_231098",
- "request_id": "req_GPwpp3VBbLMxVFMwy4sMbZ",
- "timestamp": "2021-11-12T10:38:05Z",
- "transaction_code": "card"
}
]
}
Get enriched transaction
Get enriched transaction
Authorizations:
path Parameters
reference_id_or_heron_id required | string |
Responses
Response samples
- 200
{- "transaction_enriched": {
- "account_id": "checking_account_202348",
- "amount": -42.42,
- "annotation": {
- "annotator": {
- "context": "sync",
- "priority_type": "gold_standard"
}, - "category": {
- "heron_id": "ctg_btJFzxZK8YUQiVASoBsdso",
- "label": "Rent"
}, - "confidence": 0,
- "model_version": "string"
}, - "balance": 423,
- "currency": "USD",
- "end_user_id": "my_best_customer_203948",
- "features": {
- "description_clean": "GOOGLE ADS",
- "duplicate_of_id": "txn_dygNyAPXTYFxMkKfpF9FEn",
- "has_matching_transaction": true,
- "is_potential_duplicate": true,
- "is_recurring": true
}, - "heron_id": "txn_J2AN4abNxxEPYBeZenNZCb",
- "last_updated": "2025-01-16T10:27:11.657837",
- "merchant": {
- "categories": [
- {
- "code": "7311",
- "description": "Advertising services",
- "slug": "advertising_services"
}
], - "group_id": "Uber",
- "heron_id": "mrc_GBDaec5u8gWTRAHVvXjyBD",
- "icon_url": "string",
- "is_priority": true,
- "logo_url": "string",
- "name": "string",
- "url": "string"
}, - "reference_id": "my_favourite_transaction_231098",
- "request_id": "req_GPwpp3VBbLMxVFMwy4sMbZ",
- "timestamp": "2021-11-12T10:38:05Z",
- "transaction_code": "card"
}
}
Create end user transactions (async)
Upload transactions for a specific end user. Does not include enriching transactions -- set end user status = 'ready' to initiate processing. For synchronous enrichment, please instead use "Enrich transactions (sync). Either timestamp (preferred) or date must be present in the transaction payload."
Authorizations:
path Parameters
end_user_id_or_heron_id required | string |
Request Body schema: application/json
Array of objects or null (AccountBalance1) Bank account balance information for a particular account_id. The balance here must be the latest balance after all the transactions in this batch have been applied. | |
required | Array of objects (EndUserTransactionPostAsync) non-empty |
Responses
Request samples
- Payload
{- "balances": [
- {
- "account_id": "checking_account_202348",
- "batch_closing_balance": 25000.45
}
], - "transactions": [
- {
- "account_id": "checking_account_202348",
- "amount": -42.42,
- "balance": 423,
- "categories_default": "shopping",
- "currency": "USD",
- "date": "2020-04-27",
- "mcc_code": "string",
- "order": 0,
- "reference_id": "my_favourite_transaction_231098",
- "timestamp": "2021-11-12T10:38:05Z",
- "transaction_code": "card"
}
]
}
Response samples
- 201
{- "request_id": "string",
- "transactions_loaded": 0
}
Delete transactions
Please provide at least one of the following parameters: heron_ids, heron_id, request_id or end_user_id.
Authorizations:
query Parameters
account_id | string or null Default: null account_id of transactions to be deleted |
heron_id | string or null Default: null Example: heron_id=txn_CqK6hFi4sNPgdvv9fZWcAB (legacy) Heron ID of transaction to be deleted |
only_duplicates | boolean or null Default: null if true, deletes only transactions that are marked as duplicates |
end_user_id | string or null Default: null end_user_id of transactions to be deleted |
request_id | string or null Default: null Request ID of transactions to be deleted |
heron_ids | Array of strings Default: [] Heron IDs of transactions to be deleted |
reference_ids | Array of strings Default: [] Reference IDs of transactions to be deleted |
Responses
Callbacks
Response samples
- 202
{- "message": "string"
}
Callback payload samples
{- "created": "2025-01-16T10:27:11.663440",
- "data": {
- "transactions": [
- {
- "heron_id": "txn_J2AN4abNxxEPYBeZenNZCb",
- "reference_id": "my_favourite_transaction_231098"
}
]
}, - "meta": { },
- "topic": "transactions.deleted"
}
Get transactions. At least `end_user_id`, `heron_i
Get transactions. At least end_user_id
, heron_id
or request_id
must be provided.
Authorizations:
query Parameters
last_updated_min | string <date-time> Example: last_updated_min=2025-01-16T10:27:11.659988 Filter for transactions whose values were last updated in Heron systems after the specified input value |
description_keyword | string Filter by keyword match on transaction description; case insensitive |
page | integer >= 1 Default: 1 Page of transaction to return |
confidence_min | number [ 0 .. 1 ] Filter by minimum confidence of annotation associated with transaction |
account_ids | Array of strings or null Default: null Example: account_ids=1234 Account ids to include. If not provided, all accounts are included |
include_duplicates | boolean Whether or not to include duplicate transactions in the response. Defaults to false unless request_id is provided, in which case it defaults to true. |
last_updated_max | string <date-time> Example: last_updated_max=2025-01-16T10:27:11.660002 Filter for transactions whose values were last updated in Heron systems before the specified input value |
merchant_group_id | string Filter by merchant group id |
created_date_max | string <date> Example: created_date_max=2020-04-27 Filter by latest transaction upload date - when Heron received the transaction |
end_user_id | string End user id of transaction |
limit | integer [ 1 .. 10000 ] Default: 1000 Number of transactions to return per page |
has_merchant | boolean or null Default: null Filter by whether the transaction has a merchant entity associated with it |
order_by | string Default: "id_asc" Enum: "amount_asc" "amount_desc" "abs_amount_asc" "abs_amount_desc" "description_asc" "description_desc" "timestamp_asc" "timestamp_desc" "id_asc" "id_desc" "confidence_asc" "confidence_desc" What to order transactions by |
heron_id | string Example: heron_id=txn_ZSx7aft7JSRvyHXvmuh6Hi Heron generated Id of transaction |
merchant_heron_id | string Filter by merchant heron id |
from_date | string <date> Deprecated; see created_date_ or timestamp_date_ |
confidence_max | number [ 0 .. 1 ] Filter by maximum confidence of annotation associated with transaction |
to_date | string <date> Deprecated; see created_date_ or timestamp_date_ |
timestamp_date_min | string <date> Example: timestamp_date_min=2020-04-27 Filter by earliest transaction timestamp |
transaction_code | string Filter by transaction code |
created_date_min | string <date> Example: created_date_min=2020-04-27 Filter by earliest transaction upload date - when Heron received the transaction |
max_amount | number Filter by maximum amount of transaction |
is_recurring | boolean Filter by whether the transaction is recurring |
reference_id | string Reference Id of transaction |
category_heron_id | Array of strings or null Default: [] Example: category_heron_id=ctg_3NA4esGfv3vkKKs3oWAuYY Filter by the heron_id of the category that the transaction is annotated with |
timestamp_date_max | string <date> Example: timestamp_date_max=2020-04-27 Filter by latest transaction timestamp |
description_regex | string Filter by regex matching transaction description |
has_matching_transaction | boolean Filter by whether the transaction has a matching transaction |
request_id | string Request-Id header returned in the response of POST transactions. Sending this parameter will return all transactions sent in a particular POST request, including any duplicates. |
min_amount | number Filter by minimum amount of transaction |
Responses
Response samples
- 200
{- "_meta": {
- "next_url": "string",
- "page": 0,
- "pages": 0,
- "per_page": 0,
- "prev_url": "string"
}, - "_summary": {
- "returned_transactions": 0,
- "transactions": 0
}, - "transactions": [
- {
- "account_id": "checking_account_202348",
- "account_number": "1234567890",
- "amount": -42.42,
- "balance": 423,
- "categories": [
- {
- "annotator": "predicted",
- "confidence": 0.5,
- "heron_id": "ctg_CziN3N2dTG9dYVKsa7A92q",
- "label": "Rent",
- "model_version": "0eb46c88-a205-4c9f-b47f-5d3a25296ef3"
}
], - "created": "2025-01-16T10:27:11.659594",
- "currency": "USD",
- "data_source_account_heron_id": "dsa_nmef6krJjPhLMxpvDBhtbg",
- "data_source_heron_id": "dso_SpwD6Qg2gJMLo3UFmWmgtN",
- "description_clean": "GOOGLE ADS",
- "duplicate_of_id": "txn_dygNyAPXTYFxMkKfpF9FEn",
- "end_user_id": "my_best_customer_203948",
- "has_matching_transaction": true,
- "heron_id": "txn_J2AN4abNxxEPYBeZenNZCb",
- "is_potential_duplicate": true,
- "is_recurring": true,
- "last_updated": "2025-01-16T10:27:11.659621",
- "merchant": {
- "categories": [
- {
- "code": "7311",
- "description": "Advertising services",
- "slug": "advertising_services"
}
], - "group_id": "Uber",
- "heron_id": "mrc_GBDaec5u8gWTRAHVvXjyBD",
- "icon_url": "string",
- "is_priority": true,
- "logo_url": "string",
- "name": "string",
- "url": "string"
}, - "payment_processor": {
- "heron_id": "mrc_nRYdGU7nYuevb7qem65cEb",
- "name": "Paypal",
}, - "reference_id": "my_favourite_transaction_231098",
- "request_id": "req_GPwpp3VBbLMxVFMwy4sMbZ",
- "timestamp": "2021-11-12T10:38:05Z",
- "transaction_code": "card"
}
]
}
Enrich transactions (sync)
Enrich and categorize transactions and consume them in a sync response. For business lending and underwriting, please use "Create end user transactions" instead. Please send a maximum of 249 transactions per request.
Authorizations:
Request Body schema: application/json
required | Array of objects (Transaction1) non-empty | ||||||||||||||||||||||||||
Array (non-empty)
|
Responses
Request samples
- Payload
{- "transactions": [
- {
- "account_id": "checking_account_202348",
- "amount": -42.42,
- "balance": 423,
- "categories_default": "shopping",
- "currency": "USD",
- "date": "2020-04-27",
- "end_user_id": "my_best_customer_203948",
- "mcc_code": "string",
- "order": 0,
- "reference_id": "my_favourite_transaction_231098",
- "timestamp": "2021-11-12T10:38:05Z",
- "transaction_code": "card"
}
]
}
Response samples
- 200
- 413
{- "_summary": {
- "request_id": "string"
}, - "transactions": [
- {
- "account_id": "checking_account_202348",
- "amount": -42.42,
- "balance": 423,
- "categories": [
- {
- "annotator": "predicted",
- "confidence": 0.5,
- "heron_id": "ctg_CziN3N2dTG9dYVKsa7A92q",
- "label": "Rent",
- "model_version": "0eb46c88-a205-4c9f-b47f-5d3a25296ef3"
}
], - "currency": "USD",
- "description_clean": "GOOGLE ADS",
- "duplicate_of_id": "txn_dygNyAPXTYFxMkKfpF9FEn",
- "end_user_id": "my_best_customer_203948",
- "has_matching_transaction": true,
- "is_potential_duplicate": true,
- "is_recurring": true,
- "merchant": {
- "categories": [
- {
- "code": "7311",
- "description": "Advertising services",
- "slug": "advertising_services"
}
], - "group_id": "Uber",
- "heron_id": "mrc_GBDaec5u8gWTRAHVvXjyBD",
- "icon_url": "string",
- "is_priority": true,
- "logo_url": "string",
- "name": "string",
- "url": "string"
}, - "payment_processor": {
- "heron_id": "mrc_nRYdGU7nYuevb7qem65cEb",
- "name": "Paypal",
}, - "reference_id": "my_favourite_transaction_231098",
- "request_id": "req_GPwpp3VBbLMxVFMwy4sMbZ",
- "timestamp": "2021-11-12T10:38:05Z",
- "transaction_code": "card"
}
]
}
Get the policy evaluations for an end user
Evaluates the user's policies against end user on-the-fly
Authorizations:
path Parameters
heron_id required | string |
Responses
Response samples
- 200
[- {
- "failed_checks": [
- {
- "attribute_value": null,
- "check": null,
- "evaluations": null,
- "result": "pass"
}
], - "missing_data_checks": [
- {
- "attribute_value": null,
- "check": null,
- "evaluations": null,
- "result": "pass"
}
], - "passed_checks": [
- {
- "attribute_value": null,
- "check": null,
- "evaluations": null,
- "result": "pass"
}
], - "policy": {
- "checks": [
- {
- "attribute_label": "string",
- "boolean_check": null,
- "composite_check": null,
- "date_check": null,
- "date_delta_to_now_check": null,
- "numeric_check": null,
- "string_check": null
}
], - "display_order": null,
- "heron_id": "string",
- "name": "string"
}, - "result": "passed"
}
]
Extract Merchant from a transaction description
Extract Merchant from a transaction description
Authorizations:
Request Body schema: application/json
The bank transaction description as a string
description required | string |
Responses
Request samples
- Payload
{- "description": "PAYPAL* AMZN Mktp 198748320"
}
Response samples
- 200
{- "description_clean": "Amzn Mktp",
- "merchant": {
- "categories": [
- {
- "code": "7311",
- "description": "Advertising services",
- "slug": "advertising_services"
}
], - "confidence": null,
- "group_id": "string",
- "heron_id": "mrc_GBDaec5u8gWTRAHVvXjyBD",
- "icon_url": "string",
- "logo_url": "string",
- "name": "Amazon",
}, - "payment_processor": {
- "heron_id": "mrc_nRYdGU7nYuevb7qem65cEb",
- "name": "Paypal",
}
}
Search Merchants by name
Search Merchants by name
Authorizations:
query Parameters
name required | string Full or partial name, minimum 3 characters |
only_priority | boolean If true, only returns priority merchants |
Responses
Response samples
- 200
{- "merchants": [
- {
- "categories": [
- {
- "code": "7311",
- "description": "Advertising services",
- "slug": "advertising_services"
}
], - "group_id": "Uber",
- "heron_id": "mrc_GBDaec5u8gWTRAHVvXjyBD",
- "icon_url": "string",
- "is_priority": true,
- "logo_url": "string",
- "name": "string",
- "url": "string"
}
]
}
Get Merchant by heron_id
Get Merchant by heron_id
Authorizations:
path Parameters
heron_id required | string The Merchant |
Responses
Response samples
- 200
{- "merchant": {
- "categories": [
- {
- "code": "7311",
- "description": "Advertising services",
- "slug": "advertising_services"
}
], - "group_id": "Uber",
- "heron_id": "mrc_GBDaec5u8gWTRAHVvXjyBD",
- "icon_url": "string",
- "is_priority": true,
- "logo_url": "string",
- "name": "string",
- "url": "string"
}
}
Response samples
- 200
{- "rules": [
- {
- "condition": "equal",
- "created": "2024-12-05T10:27:12.304883",
- "date_range": "last_180_days",
- "group": "data_quality_datasource",
- "heron_id": "rul_GHVbrAZFWmfDcszwjZsEBT",
- "last_updated": "2025-01-16T10:27:12.304927",
- "metric_label": "unique_transactions",
- "name": "notify_if_debt_investment_count_gt_0_last_180d",
- "selector": {
- "is_portfolio": true
}, - "value": 42.42,
- "value_str": "mrc_12345678ijwdd321d921"
}
]
}
Create a single rule
Create a new rule to send a 'end_user.review_required' webhook after processing if rule condition evaluates to true
Authorizations:
Request Body schema: application/json
object (Rule) | |||||||||||||||||
|
Responses
Request samples
- Payload
{- "rule": {
- "condition": "equal",
- "date_range": "last_180_days",
- "group": "data_quality_datasource",
- "metric_label": "unique_transactions",
- "name": "notify_if_debt_investment_count_gt_0_last_180d",
- "selector": {
- "is_portfolio": true
}, - "value": 42.42,
- "value_str": "mrc_12345678ijwdd321d921"
}
}
Response samples
- 201
{- "rule": {
- "condition": "equal",
- "created": "2024-12-05T10:27:12.304883",
- "date_range": "last_180_days",
- "group": "data_quality_datasource",
- "heron_id": "rul_GHVbrAZFWmfDcszwjZsEBT",
- "last_updated": "2025-01-16T10:27:12.304927",
- "metric_label": "unique_transactions",
- "name": "notify_if_debt_investment_count_gt_0_last_180d",
- "selector": {
- "is_portfolio": true
}, - "value": 42.42,
- "value_str": "mrc_12345678ijwdd321d921"
}
}
Update rule by heron_id
Update a rule
Authorizations:
path Parameters
heron_id required | string |
Request Body schema: application/json
Rule
object (RuleUpdateSchema) | |||||||||||||||||
|
Responses
Request samples
- Payload
{- "rule": {
- "condition": "equal",
- "date_range": "last_180_days",
- "group": "data_quality_datasource",
- "metric_label": "unique_transactions",
- "name": "notify_if_debt_investment_count_gt_0_last_180d",
- "selector": {
- "is_portfolio": true
}, - "value": 42.42,
- "value_str": "mrc_12345678ijwdd321d921"
}
}
Response samples
- 200
{- "rule": {
- "condition": "equal",
- "created": "2024-12-05T10:27:12.304883",
- "date_range": "last_180_days",
- "group": "data_quality_datasource",
- "heron_id": "rul_GHVbrAZFWmfDcszwjZsEBT",
- "last_updated": "2025-01-16T10:27:12.304927",
- "metric_label": "unique_transactions",
- "name": "notify_if_debt_investment_count_gt_0_last_180d",
- "selector": {
- "is_portfolio": true
}, - "value": 42.42,
- "value_str": "mrc_12345678ijwdd321d921"
}
}
Get parsed submissions for an End User
Authorizations:
path Parameters
end_user_heron_id required | string The heron_id of the end user |
Responses
Response samples
- 200
[- {
- "end_user_heron_id": "string",
- "result": { },
- "status": "success",
- "submission_parser": {
- "description": "string",
- "heron_id": "string",
- "name": "string",
- "slug": "string"
}
}
]
Save user's company overview layout
Authorizations:
Request Body schema: application/json
The new company overview layout
group_name required | string |
id required | string A unique id used to reference the group |
required | Array of objects (Widget) |
Responses
Request samples
- Payload
[- {
- "group_name": "string",
- "id": "string",
- "widgets": [
- {
- "id": "string",
- "scorecard_metric_date_range": "latest",
- "scorecard_metric_label": "string",
- "type": "scorecard_metric"
}
]
}
]
Save user's settings
Authorizations:
Request Body schema: application/json
The new settings
object (BalanceSheetCategories) | |
object | |
object (PnLCategories) | |
use_new_company_layout | boolean |
use_new_end_user_table | boolean |
Responses
Request samples
- Payload
{- "balance_sheet_categories": {
- "current_assets": {
- "property1": [
- "string"
], - "property2": [
- "string"
]
}, - "current_liabilities": {
- "property1": [
- "string"
], - "property2": [
- "string"
]
}, - "equity": {
- "property1": [
- "string"
], - "property2": [
- "string"
]
}, - "fixed_assets": {
- "property1": [
- "string"
], - "property2": [
- "string"
]
}, - "non_current_liabilities": {
- "property1": [
- "string"
], - "property2": [
- "string"
]
}, - "other_assets": {
- "property1": [
- "string"
], - "property2": [
- "string"
]
}
}, - "financials_metrics": {
- "property1": {
- "context": "string",
- "date_ranges": [
- "string"
], - "description": "string",
- "formula": {
- "add": {
- "addend_1": { },
- "addend_2": { }
}, - "div": {
- "dividend": { },
- "divisor": { }
}, - "mult": {
- "multiplicand": { },
- "multiplier": { }
}, - "scalar": {
- "value": 0
}, - "simple_metric": {
- "date_range": null,
- "filter": null,
- "metric_name": "string",
- "value_if_unavailable": null
}, - "sub": {
- "minuend": { },
- "subtrahend": { }
}, - "type": "string"
}, - "group": "string",
- "unit": "string"
}, - "property2": {
- "context": "string",
- "date_ranges": [
- "string"
], - "description": "string",
- "formula": {
- "add": {
- "addend_1": { },
- "addend_2": { }
}, - "div": {
- "dividend": { },
- "divisor": { }
}, - "mult": {
- "multiplicand": { },
- "multiplier": { }
}, - "scalar": {
- "value": 0
}, - "simple_metric": {
- "date_range": null,
- "filter": null,
- "metric_name": "string",
- "value_if_unavailable": null
}, - "sub": {
- "minuend": { },
- "subtrahend": { }
}, - "type": "string"
}, - "group": "string",
- "unit": "string"
}
}, - "pnl_categories": {
- "cogs": {
- "property1": [
- "string"
], - "property2": [
- "string"
]
}, - "income": {
- "property1": [
- "string"
], - "property2": [
- "string"
]
}, - "operating_expenses": {
- "property1": [
- "string"
], - "property2": [
- "string"
]
}, - "other_expenses": {
- "property1": [
- "string"
], - "property2": [
- "string"
]
}, - "other_income": {
- "property1": [
- "string"
], - "property2": [
- "string"
]
}
}, - "use_new_company_layout": true,
- "use_new_end_user_table": true
}
Response samples
- 200
[- {
- "headers": {
- "Content-Type": "application/json"
}, - "heron_id": "wbh_2bJfBH43u5qxkaY6VysoNd",
- "is_enabled": true,
- "topic": "end_user.processed",
}
]
Create a webhook
Create a webhook
Authorizations:
Request Body schema: application/json
headers | object or null Headers to send webhook with |
is_enabled | boolean Whether the webhook is enabled |
topic | string Enum: "data_source_account_summary.created" "data_source.disabled" "end_user.created" "end_user.processed" "end_user.failed" "end_user.reviewed" "end_user.transactions_updated" "end_user.review_required" "end_user.files_changed" "end_user.files_classified" "end_user_information.updated" "end_user.policy_workflow_finished" "end_user.policy_workflow_failed" "enrich_workflow.finished" "transactions.deleted" "transactions.updated" "pdf.processed" "pdf.checks_passed" "pdf.checks_failed" "pdf.transactions_loaded" "pdf.failed" "pdf.parsed" "pdf.approved" "integration_link.erroring" "iso_application.processed" "iso_application.processed_simple" "iso_application.created" "end_user_email.processed" "end_user_email.failed" "debt_summary.processed" "end_user_file.parsed" "end_user_file.parse_failed" Webhook topic for different Heron events |
url | string <url> URL where webhook should be sent |
Responses
Request samples
- Payload
{- "headers": {
- "Content-Type": "application/json"
}, - "is_enabled": true,
- "topic": "end_user.processed",
}
Response samples
- 201
{- "headers": {
- "Content-Type": "application/json"
}, - "heron_id": "wbh_2bJfBH43u5qxkaY6VysoNd",
- "is_enabled": true,
- "topic": "end_user.processed",
}
Update a webhook
Update a webhook
Authorizations:
path Parameters
heron_id required | string |
Request Body schema: application/json
headers | object or null Headers to send webhook with |
is_enabled | boolean Whether the webhook is enabled |
topic | string Enum: "data_source_account_summary.created" "data_source.disabled" "end_user.created" "end_user.processed" "end_user.failed" "end_user.reviewed" "end_user.transactions_updated" "end_user.review_required" "end_user.files_changed" "end_user.files_classified" "end_user_information.updated" "end_user.policy_workflow_finished" "end_user.policy_workflow_failed" "enrich_workflow.finished" "transactions.deleted" "transactions.updated" "pdf.processed" "pdf.checks_passed" "pdf.checks_failed" "pdf.transactions_loaded" "pdf.failed" "pdf.parsed" "pdf.approved" "integration_link.erroring" "iso_application.processed" "iso_application.processed_simple" "iso_application.created" "end_user_email.processed" "end_user_email.failed" "debt_summary.processed" "end_user_file.parsed" "end_user_file.parse_failed" Webhook topic for different Heron events |
url | string <url> URL where webhook should be sent |
Responses
Request samples
- Payload
{- "headers": {
- "Content-Type": "application/json"
}, - "is_enabled": true,
- "topic": "end_user.processed",
}
Response samples
- 200
{- "headers": {
- "Content-Type": "application/json"
}, - "heron_id": "wbh_2bJfBH43u5qxkaY6VysoNd",
- "is_enabled": true,
- "topic": "end_user.processed",
}