Income
API reference for Income endpoints and webhooks
Verify a user's income via payroll or bank account data.
Endpoints | |
---|---|
/credit/sessions/get | Get Link session metadata and results for the end user |
/credit/bank_income/get | Retrieve information from the bank accounts used for income verification |
/credit/bank_income/pdf/get | Retrieve information from the bank accounts used for income verification in PDF format |
/credit/bank_income/refresh | Refresh a user's bank income information |
/credit/bank_income/webhook/update | Subscribe and unsubscribe to proactive notifications for a user's income profile |
/credit/bank_statements/uploads/get | Retrieve information from the bank statements used for income verification |
/credit/payroll_income/get | Retrieve information from the pay stubs or tax forms used for income verification |
/credit/payroll_income/risk_signals/get | Analyze uploaded income documents for indications of potential fraud |
/credit/payroll_income/parsing_config/update | Update the parsing configuration for a document verification |
/credit/employment/get | (Beta) Retrieve employment information about the end user |
/credit/payroll_income/refresh | (Beta) Retrieve updated payroll income data on a linked account |
See also | |
---|---|
/sandbox/income/fire_webhook | Manually fire an Income webhook (Sandbox only) |
/user/create | Create a user for use with the income verification product |
Webhooks | |
---|---|
INCOME_VERIFICATION | Income verification has completed |
INCOME_VERIFICATION_RISK_SIGNALS | Risk evaluation of user-uploaded documents has completed |
BANK_INCOME_REFRESH_UPDATE | A change to user's income has been detected |
BANK_INCOME_REFRESH_COMPLETE | The refreshed report has finished generating |
INCOME_VERIFICATION_REFRESH_RECONNECT_NEEDED | A Payroll Income verification could not be refreshed |
Endpoints
/user/create
Create user
This endpoint should be called for each of your end users before they begin a Plaid Check or Income flow, or a Multi-Item Link flow. This provides you a single token to access all data associated with the user. You should only create one per end user.
The consumer_report_user_identity
object must be present in order to create a Plaid Check Consumer Report for a user. If it is not provided during the /user/create
call, it can be added later by calling /user/update
.
If you call the endpoint multiple times with the same client_user_id
, the first creation call will succeed and the rest will fail with an error message indicating that the user has been created for the given client_user_id
.
Ensure that you store the user_token
along with your user's identifier in your database, as it is not possible to retrieve a previously created user_token
.
client_id
client_id
. The client_id
is required and may be provided either in the PLAID-CLIENT-ID
header or as part of a request body.secret
secret
. The secret
is required and may be provided either in the PLAID-SECRET
header or as part of a request body.client_user_id
client_user_id
.128
1
consumer_report_user _identity
/user/update
. Once the field has been added to the user, you will be able to call /link/token/create
with a non-empty consumer_report_permissible_purpose
(which will automatically create a Plaid Check Consumer Report), or call /cra/check_report/create
for that user.first_name
last_name
phone_numbers
emails
primary_address
city
region
state
.
Example: "NC"
street
"564 Main Street, APT 15"
postal_code
zip
.country
1const request: UserCreateRequest = {2 client_user_id: 'c0e2c4ee-b763-4af5-cfe9-46a46bce883d',3};45try {6 const response = await client.userCreate(request);7} catch (error) {8 // handle error9}
Response fields and example
user_token
user_id
user_id
of the User associated with this webhook, warning, or error.request_id
1{2 "user_token": "user-sandbox-b0e2c4ee-a763-4df5-bfe9-46a46bce993d",3 "user_id": "wz666MBjYWTp2PDzzggYhM6oWWmBb",4 "request_id": "Aim3b"5}
Was this helpful?
/credit/sessions/get
Retrieve Link sessions for your user
This endpoint can be used for your end users after they complete the Link flow. This endpoint returns a list of Link sessions that your user completed, where each session includes the results from the Link flow.
These results include details about the Item that was created and some product related metadata (showing, for example, whether the user finished the bank income verification step).
client_id
client_id
. The client_id
is required and may be provided either in the PLAID-CLIENT-ID
header or as part of a request body.secret
secret
. The secret
is required and may be provided either in the PLAID-SECRET
header or as part of a request body.user_token
1const request: CreditSessionsGetRequest = {2 user_token: 'user-sandbox-b0e2c4ee-a763-4df5-bfe9-46a46bce993d',3};45try {6 const response = await client.creditSessionsGet(request);7} catch (error) {8 // handle error9}
Response fields and example
sessions
link_session_id
link_session_id
returned in the onSuccess/onExit callbacks.session_start_time
date-time
results
item_add_results
public_token
item_id
item_id
is always unique; linking the same account at the same institution twice will result in two Items with different item_id
values. Like all Plaid identifiers, the item_id
is case-sensitive.institution_id
bank_income_results
status
APPROVED
: User has approved and verified their incomeNO_DEPOSITS_FOUND
: We attempted, but were unable to find any income in the connected account.USER_REPORTED_NO_INCOME
: The user explicitly indicated that they don't receive income in the connected account.STARTED
: The user began the bank income portion of the link flow.INTERNAL_ERROR
: The user encountered an internal error.APPROVED
, NO_DEPOSITS_FOUND
, USER_REPORTED_NO_INCOME
item_id
item_id
is always unique; linking the same account at the same institution twice will result in two Items with different item_id
values. Like all Plaid identifiers, the item_id
is case-sensitive.institution_id
bank_employment _results
status
APPROVED
: User has approved and verified their employment.NO_EMPLOYMENTS_FOUND
: We attempted, but were unable to find any employment in the connected account.EMPLOYER_NOT_LISTED
: The user explicitly indicated that they did not see their current or previous employer in the list of employer names found.STARTED
: The user began the bank income portion of the link flow.INTERNAL_ERROR
: The user encountered an internal error.APPROVED
, NO_EMPLOYERS_FOUND
, EMPLOYER_NOT_LISTED
item_id
item_id
is always unique; linking the same account at the same institution twice will result in two Items with different item_id
values. Like all Plaid identifiers, the item_id
is case-sensitive.institution_id
payroll_income_results
num_paystubs_retrieved
num_w2s_retrieved
institution_id
institution_name
document_income _results
num_paystubs_uploaded
num_w2s_uploaded
num_bank_statements _uploaded
num_1099s_uploaded
errors
error_type
error_code
error_message
display_message
null
if the error is not related to user action.request_id
1{2 "request_id": "Aim3b",3 "sessions": [4 {5 "link_session_id": "356dbb28-7f98-44d1-8e6d-0cec580f3171",6 "results": {7 "item_add_results": [8 {9 "public_token": "public-sandbox-5c224a01-8314-4491-a06f-39e193d5cddc",10 "item_id": "M5eVJqLnv3tbzdngLDp9FL5OlDNxlNhlE55op",11 "institution_id": "ins_56"12 }13 ],14 "bank_income_results": [15 {16 "status": "APPROVED",17 "item_id": "M5eVJqLnv3tbzdngLDp9FL5OlDNxlNhlE55op",18 "institution_id": "ins_56"19 }20 ]21 },22 "session_start_time": "2022-09-30T23:40:30.946225Z"23 },24 {25 "link_session_id": "f742cae8-31e4-49cc-a621-6cafbdb26fb9",26 "results": {27 "payroll_income_results": [28 {29 "num_paystubs_retrieved": 2,30 "num_w2s_retrieved": 1,31 "institution_id": "ins_92"32 }33 ]34 },35 "session_start_time": "2022-09-26T23:40:30.946225Z"36 }37 ]38}
Was this helpful?
/credit/bank_income/get
Retrieve information from the bank accounts used for income verification
/credit/bank_income/get
returns the bank income report(s) for a specified user. A single report corresponds to all institutions linked in a single Link session. To include multiple institutions in a single report, use Multi-Item Link. To return older reports, use the options.count
field.
client_id
client_id
. The client_id
is required and may be provided either in the PLAID-CLIENT-ID
header or as part of a request body.secret
secret
. The secret
is required and may be provided either in the PLAID-SECRET
header or as part of a request body.user_token
options
/credit/bank_income/get
request options.count
1
1const request: CreditBankIncomeGetRequest = {2 user_token: 'user-sandbox-b0e2c4ee-a763-4df5-bfe9-46a46bce993d',3 options: {4 count: 1,5 },6};78try {9 const response = await client.creditBankIncomeGet(request);10} catch (error) {11 // handle error12}
Response fields and example
bank_income
bank_income_id
generated_time
date-time
days_requested
items
bank_income_accounts
account_id
mask
name
official_name
subtype
checking
, savings
, hsa
, cd
, money market
, paypal
, prepaid
, cash management
, ebt
, all
type
depository
.depository
owners
names
If an Item contains multiple accounts with different owner names, some institutions will report all names associated with the Item in each account's
names
array.phone_numbers
emails
addresses
data
city
region
state
.
Example: "NC"
street
"564 Main Street, APT 15"
postal_code
zip
.country
primary
true
, identifies the address as the primary address on an account.bank_income_sources
income_source_id
income_description
income_category
CASH
value has been deprecated and is used only for existing legacy implementations. It has been replaced by the new categories CASH_DEPOSIT
(representing cash or check deposits) and TRANSFER_FROM_APPLICATION
(representing cash transfers originating from apps, such as Zelle or Venmo).SALARY
, UNEMPLOYMENT
, CASH
, GIG_ECONOMY
, RENTAL
, CHILD_SUPPORT
, MILITARY
, RETIREMENT
, LONG_TERM_DISABILITY
, BANK_INTEREST
, CASH_DEPOSIT
, TRANSFER_FROM_APPLICATION
, TAX_REFUND
, BENEFIT_OTHER
, OTHER
account_id
start_date
date
end_date
date
pay_frequency
WEEKLY
, BIWEEKLY
, SEMI_MONTHLY
, MONTHLY
, DAILY
, UNKNOWN
total_amount
transaction_count
historical_summary
total_amount
total_amounts
instead.iso_currency_code
total_amounts
instead.unofficial_currency _code
null
if iso_currency_code
is non-null.
Unofficial currency codes are used for currencies that do not have official ISO currency codes, such as cryptocurrencies and the currencies of certain countries.
Please use total_amounts
instead.total_amounts
amount
iso_currency_code
unofficial_currency _code
null
if iso_currency_code
is non-null.
Unofficial currency codes are used for currencies that do not have official ISO currency codes, such as cryptocurrencies and the currencies of certain countries.start_date
date
end_date
date
transactions
amount
iso_currency_code
or unofficial_currency_code
.
Positive values when money moves out of the account; negative values when money moves in.
For example, credit card purchases are positive; credit card payment, direct deposits, and refunds are negative.date
date
name
original_description
pending
transaction_id
transaction_id
is case sensitive.check_number
iso_currency_code
unofficial_currency _code
null
if iso_currency_code
is non-null.
Unofficial currency codes are used for currencies that do not have official ISO currency codes, such as cryptocurrencies and the currencies of certain countries.last_updated_time
date-time
institution_id
institution_name
item_id
bank_income_summary
total_amount
total_amounts
instead.iso_currency_code
total_amounts
instead.unofficial_currency _code
null
if iso_currency_code
is non-null.
Unofficial currency codes are used for currencies that do not have official ISO currency codes, such as cryptocurrencies and the currencies of certain countries.
Please use total_amounts
instead.total_amounts
amount
iso_currency_code
unofficial_currency _code
null
if iso_currency_code
is non-null.
Unofficial currency codes are used for currencies that do not have official ISO currency codes, such as cryptocurrencies and the currencies of certain countries.start_date
date
end_date
date
income_sources_count
income_categories _count
income_transactions _count
historical_summary
total_amount
total_amounts
instead.iso_currency_code
total_amounts
instead.unofficial_currency _code
null
if iso_currency_code
is non-null.
Unofficial currency codes are used for currencies that do not have official ISO currency codes, such as cryptocurrencies and the currencies of certain countries.
Please use total_amounts
instead.total_amounts
amount
iso_currency_code
unofficial_currency _code
null
if iso_currency_code
is non-null.
Unofficial currency codes are used for currencies that do not have official ISO currency codes, such as cryptocurrencies and the currencies of certain countries.start_date
date
end_date
date
transactions
amount
iso_currency_code
or unofficial_currency_code
.
Positive values when money moves out of the account; negative values when money moves in.
For example, credit card purchases are positive; credit card payment, direct deposits, and refunds are negative.date
date
name
original_description
pending
transaction_id
transaction_id
is case sensitive.check_number
iso_currency_code
unofficial_currency _code
null
if iso_currency_code
is non-null.
Unofficial currency codes are used for currencies that do not have official ISO currency codes, such as cryptocurrencies and the currencies of certain countries.warnings
warning_type
BANK_INCOME_WARNING
.BANK_INCOME_WARNING
warning_code
IDENTITY_UNAVAILABLE
: Unable to extract identity for the Item
TRANSACTIONS_UNAVAILABLE
: Unable to extract transactions for the Item
ITEM_UNAPPROVED
: User exited flow before giving permission to share data for the Item
REPORT_DELETED
: Report deleted due to customer or consumer request
DATA_UNAVAILABLE
: No relevant data was found for the ItemIDENTITY_UNAVAILABLE
, TRANSACTIONS_UNAVAILABLE
, ITEM_UNAPPROVED
, REPORT_DELETED
, DATA_UNAVAILABLE
cause
item_id
used to identify a specific Item and error when a batch operation operating on multiple Items has encountered an error in one of the Items.error_type
INTERNAL_SERVER_ERROR
, INSUFFICIENT_CREDENTIALS
, ITEM_LOCKED
, USER_SETUP_REQUIRED
, COUNTRY_NOT_SUPPORTED
, INSTITUTION_DOWN
, INSTITUTION_NO_LONGER_SUPPORTED
, INSTITUTION_NOT_RESPONDING
, INVALID_CREDENTIALS
, INVALID_MFA
, INVALID_SEND_METHOD
, ITEM_LOGIN_REQUIRED
, MFA_NOT_SUPPORTED
, NO_ACCOUNTS
, ITEM_NOT_SUPPORTED
, ACCESS_NOT_GRANTED
error_code
error_type
. In general, 200 HTTP codes correspond to success, 40X codes are for developer- or user-related failures, and 50X codes are for Plaid-related issues. Error fields will be null
if no error has occurred.error_message
display_message
item_id
item_id
of the Item associated with this warning.request_id
1{2 "bank_income": [3 {4 "bank_income_id": "dacc92a0-cb59-43a5-ba24-1b1c07a03f28",5 "bank_income_summary": {6 "end_date": "2024-08-21",7 "historical_summary": [8 {9 "end_date": "2024-08-21",10 "iso_currency_code": "USD",11 "start_date": "2024-08-06",12 "total_amount": 4090.14,13 "total_amounts": [14 {15 "amount": 4090.14,16 "iso_currency_code": "USD",17 "unofficial_currency_code": null18 }19 ],20 "transactions": [21 {22 "amount": 120.12,23 "check_number": null,24 "date": "2024-08-07",25 "iso_currency_code": "USD",26 "name": "TEXAS OAG CHILD SUPPORT",27 "original_description": "TEXAS OAG CHILD SUPPORT",28 "transaction_id": "EZMmvwREqlSGmlRam7bzFKyBll3kJjU4xKm1w",29 "unofficial_currency_code": null30 },31 {32 "amount": 1525,33 "check_number": null,34 "date": "2024-08-08",35 "iso_currency_code": "USD",36 "name": "AIRBNB PAYMENTS PPD ID: 1234567890",37 "original_description": "AIRBNB PAYMENTS PPD ID: 1234567890",38 "transaction_id": "Wr6jzLwg1qs6ag9Xa8BrCpBAPPxnEXF6ZmjDR",39 "unofficial_currency_code": null40 },41 {42 "amount": 500,43 "check_number": null,44 "date": "2024-08-12",45 "iso_currency_code": "USD",46 "name": "TWC-BENEFITS/UI BENEFIT",47 "original_description": "TWC-BENEFITS/UI BENEFIT",48 "transaction_id": "Aj7Apx5bDyIA3VRl35yqC18wXXorBgI9rX5dp",49 "unofficial_currency_code": null50 },51 {52 "amount": 1000.7,53 "check_number": null,54 "date": "2024-08-15",55 "iso_currency_code": "USD",56 "name": "PLAID PAYROLL",57 "original_description": "PLAID PAYROLL",58 "transaction_id": "G1L9oybBrKSMPmBdPzXoFN8aGGE7gXC6MeoQB",59 "unofficial_currency_code": null60 },61 {62 "amount": 824.2,63 "check_number": null,64 "date": "2024-08-15",65 "iso_currency_code": "USD",66 "name": "SSI TREAS 310 XXSUPP SEC PPD ID: 1234567890",67 "original_description": "SSI TREAS 310 XXSUPP SEC PPD ID: 1234567890",68 "transaction_id": "nWLlwMm1qxi8DomvDXP3FaGjXX5bm9TAlyQnk",69 "unofficial_currency_code": null70 },71 {72 "amount": 120.12,73 "check_number": null,74 "date": "2024-08-21",75 "iso_currency_code": "USD",76 "name": "TEXAS OAG CHILD SUPPORT",77 "original_description": "TEXAS OAG CHILD SUPPORT",78 "transaction_id": "b7dkg6eQbPFQeRvVeZlxcqxZooa7nWSmb47dj",79 "unofficial_currency_code": null80 }81 ],82 "unofficial_currency_code": null83 }84 ],85 "income_categories_count": 5,86 "income_sources_count": 5,87 "income_transactions_count": 6,88 "iso_currency_code": "USD",89 "start_date": "2024-08-07",90 "total_amount": 4090.14,91 "total_amounts": [92 {93 "amount": 4090.14,94 "iso_currency_code": "USD",95 "unofficial_currency_code": null96 }97 ],98 "unofficial_currency_code": null99 },100 "days_requested": 15,101 "generated_time": "2024-08-21T18:10:46.293199Z",102 "items": [103 {104 "bank_income_accounts": [105 {106 "account_id": "G1L9oybBrKSMPmBdPzXoFN8oo16rqqC6PwkA5",107 "mask": "9217",108 "name": "Checking",109 "official_name": "Plaid checking",110 "owners": [111 {112 "addresses": [],113 "emails": [],114 "names": [115 "Jane Doe"116 ],117 "phone_numbers": []118 }119 ],120 "subtype": "checking",121 "type": "depository"122 }123 ],124 "bank_income_sources": [125 {126 "account_id": "G1L9oybBrKSMPmBdPzXoFN8oo16rqqC6PwkA5",127 "end_date": "2024-08-15",128 "historical_summary": [129 {130 "end_date": "2024-08-21",131 "iso_currency_code": "USD",132 "start_date": "2024-08-06",133 "total_amount": 1000.7,134 "total_amounts": [135 {136 "amount": 1000.7,137 "iso_currency_code": "USD",138 "unofficial_currency_code": null139 }140 ],141 "transactions": [142 {143 "amount": 1000.7,144 "check_number": null,145 "date": "2024-08-15",146 "iso_currency_code": "USD",147 "name": "PLAID PAYROLL",148 "original_description": "PLAID PAYROLL",149 "transaction_id": "G1L9oybBrKSMPmBdPzXoFN8aGGE7gXC6MeoQB",150 "unofficial_currency_code": null151 }152 ],153 "unofficial_currency_code": null154 }155 ],156 "income_category": "SALARY",157 "income_description": "PLAID PAYROLL",158 "income_source_id": "0e9d6fbc-29de-4225-9843-2f71e02a54d1",159 "pay_frequency": "UNKNOWN",160 "start_date": "2024-08-15",161 "total_amount": 1000.7,162 "transaction_count": 1163 },164 {165 "account_id": "G1L9oybBrKSMPmBdPzXoFN8oo16rqqC6PwkA5",166 "end_date": "2024-08-15",167 "historical_summary": [168 {169 "end_date": "2024-08-21",170 "iso_currency_code": "USD",171 "start_date": "2024-08-06",172 "total_amount": 824.2,173 "total_amounts": [174 {175 "amount": 824.2,176 "iso_currency_code": "USD",177 "unofficial_currency_code": null178 }179 ],180 "transactions": [181 {182 "amount": 824.2,183 "check_number": null,184 "date": "2024-08-15",185 "iso_currency_code": "USD",186 "name": "SSI TREAS 310 XXSUPP SEC PPD ID: 1234567890",187 "original_description": "SSI TREAS 310 XXSUPP SEC PPD ID: 1234567890",188 "transaction_id": "nWLlwMm1qxi8DomvDXP3FaGjXX5bm9TAlyQnk",189 "unofficial_currency_code": null190 }191 ],192 "unofficial_currency_code": null193 }194 ],195 "income_category": "LONG_TERM_DISABILITY",196 "income_description": "SSI TREAS 310 XXSUPP SEC PPD ID: 1234567890",197 "income_source_id": "88bc00d8-2bb1-42d0-a054-db3f20948283",198 "pay_frequency": "UNKNOWN",199 "start_date": "2024-08-15",200 "total_amount": 824.2,201 "transaction_count": 1202 },203 {204 "account_id": "G1L9oybBrKSMPmBdPzXoFN8oo16rqqC6PwkA5",205 "end_date": "2024-08-08",206 "historical_summary": [207 {208 "end_date": "2024-08-21",209 "iso_currency_code": "USD",210 "start_date": "2024-08-06",211 "total_amount": 1525,212 "total_amounts": [213 {214 "amount": 1525,215 "iso_currency_code": "USD",216 "unofficial_currency_code": null217 }218 ],219 "transactions": [220 {221 "amount": 1525,222 "check_number": null,223 "date": "2024-08-08",224 "iso_currency_code": "USD",225 "name": "AIRBNB PAYMENTS PPD ID: 1234567890",226 "original_description": "AIRBNB PAYMENTS PPD ID: 1234567890",227 "transaction_id": "Wr6jzLwg1qs6ag9Xa8BrCpBAPPxnEXF6ZmjDR",228 "unofficial_currency_code": null229 }230 ],231 "unofficial_currency_code": null232 }233 ],234 "income_category": "RENTAL",235 "income_description": "AIRBNB PAYMENTS PPD ID: 1234567890",236 "income_source_id": "063689af-7299-4327-b71f-9d8849a40c0e",237 "pay_frequency": "UNKNOWN",238 "start_date": "2024-08-08",239 "total_amount": 1525,240 "transaction_count": 1241 },242 {243 "account_id": "G1L9oybBrKSMPmBdPzXoFN8oo16rqqC6PwkA5",244 "end_date": "2024-08-12",245 "historical_summary": [246 {247 "end_date": "2024-08-21",248 "iso_currency_code": "USD",249 "start_date": "2024-08-06",250 "total_amount": 500,251 "total_amounts": [252 {253 "amount": 500,254 "iso_currency_code": "USD",255 "unofficial_currency_code": null256 }257 ],258 "transactions": [259 {260 "amount": 500,261 "check_number": null,262 "date": "2024-08-12",263 "iso_currency_code": "USD",264 "name": "TWC-BENEFITS/UI BENEFIT",265 "original_description": "TWC-BENEFITS/UI BENEFIT",266 "transaction_id": "Aj7Apx5bDyIA3VRl35yqC18wXXorBgI9rX5dp",267 "unofficial_currency_code": null268 }269 ],270 "unofficial_currency_code": null271 }272 ],273 "income_category": "UNEMPLOYMENT",274 "income_description": "TWC-BENEFITS/UI BENEFIT",275 "income_source_id": "ce160170-49d0-4811-b58e-cb4878d05f83",276 "pay_frequency": "UNKNOWN",277 "start_date": "2024-08-12",278 "total_amount": 500,279 "transaction_count": 1280 },281 {282 "account_id": "G1L9oybBrKSMPmBdPzXoFN8oo16rqqC6PwkA5",283 "end_date": "2024-08-21",284 "historical_summary": [285 {286 "end_date": "2024-08-21",287 "iso_currency_code": "USD",288 "start_date": "2024-08-06",289 "total_amount": 240.24,290 "total_amounts": [291 {292 "amount": 240.24,293 "iso_currency_code": "USD",294 "unofficial_currency_code": null295 }296 ],297 "transactions": [298 {299 "amount": 120.12,300 "check_number": null,301 "date": "2024-08-07",302 "iso_currency_code": "USD",303 "name": "TEXAS OAG CHILD SUPPORT",304 "original_description": "TEXAS OAG CHILD SUPPORT",305 "transaction_id": "EZMmvwREqlSGmlRam7bzFKyBll3kJjU4xKm1w",306 "unofficial_currency_code": null307 },308 {309 "amount": 120.12,310 "check_number": null,311 "date": "2024-08-21",312 "iso_currency_code": "USD",313 "name": "TEXAS OAG CHILD SUPPORT",314 "original_description": "TEXAS OAG CHILD SUPPORT",315 "transaction_id": "b7dkg6eQbPFQeRvVeZlxcqxZooa7nWSmb47dj",316 "unofficial_currency_code": null317 }318 ],319 "unofficial_currency_code": null320 }321 ],322 "income_category": "CHILD_SUPPORT",323 "income_description": "TEXAS OAG CHILD SUPPORT",324 "income_source_id": "c8e1576e-9de4-47b4-ad55-3f7b068cc863",325 "pay_frequency": "UNKNOWN",326 "start_date": "2024-08-07",327 "total_amount": 240.24,328 "transaction_count": 2329 }330 ],331 "institution_id": "ins_20",332 "institution_name": "Citizens Bank",333 "item_id": "L8EKo4GydxSKmJQGmXyPuDkeNn4rg9fP3MKLv",334 "last_updated_time": "2024-08-21T18:10:47.367335Z"335 }336 ]337 }338 ],339 "request_id": "MLM1fFu4fbVg7KR"340}
Was this helpful?
/credit/bank_income/pdf/get
Retrieve information from the bank accounts used for income verification in PDF format
/credit/bank_income/pdf/get
returns the most recent bank income report for a specified user in PDF format. A single report corresponds to all institutions linked in a single Link session. To include multiple institutions in a single report, use Multi-Item Link.
client_id
client_id
. The client_id
is required and may be provided either in the PLAID-CLIENT-ID
header or as part of a request body.secret
secret
. The secret
is required and may be provided either in the PLAID-SECRET
header or as part of a request body.user_token
1const request: CreditBankIncomePDFGetRequest = {2 user_token: 'user-sandbox-b0e2c4ee-a763-4df5-bfe9-46a46bce993d',3};45try {6 const response = await client.creditBankIncomePdfGet(request, {7 responseType: 'arraybuffer',8 });9 const pdf = response.buffer.toString('base64');10} catch (error) {11 // handle error12}
Response
This endpoint returns binary PDF data. View a sample Bank Income PDF.
/credit/bank_income/refresh
Refresh a user's bank income information
/credit/bank_income/refresh
refreshes the most recent bank income report data for a specific user. If the most recent bank income report is no longer valid (i.e. deleted), the endpoint will refresh the most recent valid report instead.
client_id
client_id
. The client_id
is required and may be provided either in the PLAID-CLIENT-ID
header or as part of a request body.secret
secret
. The secret
is required and may be provided either in the PLAID-SECRET
header or as part of a request body.user_token
options
/credit/bank_income/refresh
request options.days_requested
1const request: CreditBankIncomeRefreshRequest = {2 user_token: 'user-sandbox-b0e2c4ee-a763-4df5-bfe9-46a46bce993d',3 options: {4 days_requested: 120,5 },6};78try {9 const response = await client.creditBankIncomeRefresh(request);10} catch (error) {11 // handle error12}
Response fields and example
request_id
1{2 "request_id": "LhQf0THi8SH1yJm"3}
Was this helpful?
/credit/bank_income/webhook/update
Subscribe and unsubscribe to proactive notifications for a user's income profile
/credit/bank_income/webhook/update
allows you to subscribe or unsubscribe a user for income webhook notifications. By default, all users start out unsubscribed.
If a user is subscribed, on significant changes to the user's income profile, you will receive a BANK_INCOME_REFRESH_UPDATE
webhook, prompting you to refresh bank income data for the user.
client_id
client_id
. The client_id
is required and may be provided either in the PLAID-CLIENT-ID
header or as part of a request body.secret
secret
. The secret
is required and may be provided either in the PLAID-SECRET
header or as part of a request body.user_token
enable_webhooks
1const request: CreditBankIncomeWebhookUpdateRequest = {2 user_token: 'user-sandbox-b0e2c4ee-a763-4df5-bfe9-46a46bce993d',3 enable_webhooks: true,4};56try {7 const response = await client.creditBankIncomeWebhookUpdateRequest(request);8} catch (error) {9 // handle error10}
Response fields and example
request_id
1{2 "request_id": "LhQf0THi8SH1yJm"3}
Was this helpful?
/credit/bank_statements/uploads/get
Retrieve data for a user's uploaded bank statements
/credit/bank_statements/uploads/get
returns parsed data from bank statements uploaded by users as part of the Document Income flow. If your account is not enabled for Document Parsing, contact your account manager to request access.
client_id
client_id
. The client_id
is required and may be provided either in the PLAID-CLIENT-ID
header or as part of a request body.secret
secret
. The secret
is required and may be provided either in the PLAID-SECRET
header or as part of a request body.user_token
options
/credit/bank_statements/uploads/get
request options.item_ids
item_id
s whose bank statements information is returned. Each item_id
should uniquely identify a bank statements uploaded item. If this field is not provided, all item_id
s associated with the user_token
will returned in the response.1const request: CreditBankStatementsUploadsGetRequest = {2 user_token: 'user-sandbox-b0e2c4ee-a763-4df5-bfe9-46a46bce993d',3};45try {6 const response = await client.creditBankStatementsUploadsGet(request);7} catch (error) {8 // handle error9}
Response fields and example
items
item_id
item_id
of the Item associated with this webhook, warning, or errorbank_statements
transactions
amount
date
date
original_description
account_id
document_metadata
name
document_type
PAYSTUB
: A paystub.BANK_STATEMENT
: A bank statement.US_TAX_W2
: A W-2 wage and tax statement provided by a US employer reflecting wages earned by the employee.US_MILITARY_ERAS
: An electronic Retirement Account Statement (eRAS) issued by the US military.US_MILITARY_LES
: A Leave and Earnings Statement (LES) issued by the US military.US_MILITARY_CLES
: A Civilian Leave and Earnings Statement (CLES) issued by the US military.GIG
: Used to indicate that the income is related to gig work. Does not necessarily correspond to a specific document type.PLAID_GENERATED_PAYSTUB_PDF
: Used to indicate that the PDF for the paystub was generated by Plaid.NONE
: Used to indicate that there is no underlying document for the data.UNKNOWN
: Document type could not be determined.UNKNOWN
, PAYSTUB
, BANK_STATEMENT
, US_TAX_W2
, US_MILITARY_ERAS
, US_MILITARY_LES
, US_MILITARY_CLES
, GIG
, PLAID_GENERATED_PAYSTUB_PDF
, NONE
download_url
null
. If you would like Plaid to generate a PDF if the original is not available, contact your Account Manager. Example generated pay stub.For Document Income, this field will not be
null
, and the file type will be the original file type uploaded by the user. For more details on available file types, see the Document Income documentation.This download URL can only be used once and expires after two minutes. To generate a new download URL, call
/credit/payroll_income/get
again.status
PROCESSING_COMPLETE
: The document was successfully processed.DOCUMENT_ERROR
: The document could not be processed. Possible causes include: The document was an unacceptable document type such as an offer letter or bank statement, the document image was cropped or blurry, or the document was corrupted.UNKNOWN
or null
: An internal error occurred. If this happens repeatedly, contact support or your Plaid account manager.UNKNOWN
, PROCESSING_COMPLETE
, DOCUMENT_ERROR
, null
page_count
error_message
document_id
bank_accounts
name
bank_name
account_type
account_number
periods
start_date
date
end_date
date
starting_balance
ending_balance
account_id
status
processing_status
UNKNOWN
: The processing status could not be determined.PROCESSING_COMPLETE
: The processing has completed and the user has approved for sharing. The data is available to be retrieved.PROCESSING
: The verification is still processing. The data is not available yet.FAILED
: The processing failed to complete successfully.APPROVAL_STATUS_PENDING
: The processing has completed but the user has not yet approved the sharing of the data.UNKNOWN
, PROCESSING_COMPLETE
, PROCESSING
, FAILED
, APPROVAL_STATUS_PENDING
updated_at
date-time
request_id
1{2 "items": [3 {4 "item_id": "eVBnVMp7zdTJLkRNr33Rs6zr7KNJqBFL9DrE6",5 "bank_statements": [6 {7 "transactions": [8 {9 "amount": -1000,10 "date": "2023-01-01",11 "original_description": "PAYCHECK",12 "account_id": "c6778d3f-e44c-4348-874e-71507c1ac12d"13 }14 ],15 "document_metadata": {16 "document_type": "BANK_STATEMENT",17 "name": "statement_01.pdf",18 "status": "PROCESSING_COMPLETE",19 "download_url": null,20 "page_count": 221 },22 "document_id": "2jkflanbd",23 "bank_accounts": [24 {25 "name": "CHASE CHECKING",26 "bank_name": "CHASE",27 "account_type": "CHECKING",28 "account_number": "000009752",29 "account_id": "c6778d3f-e44c-4348-874e-71507c1ac12d",30 "owner": {31 "name": "JANE DOE",32 "address": {33 "postal_code": "94133",34 "country": "US",35 "region": "CA",36 "city": "SAN FRANCISCO",37 "street": "2140 TAYLOR ST"38 }39 },40 "periods": [41 {42 "start_date": "2023-01-01",43 "end_date": "2023-02-01",44 "starting_balance": 2500,45 "ending_balance": 350046 }47 ]48 }49 ]50 }51 ],52 "status": {53 "processing_status": "PROCESSING_COMPLETE"54 },55 "updated_at": "2023-02-01T21:14:54Z"56 }57 ],58 "request_id": "LhQf0THi8SH1yJm"59}
Was this helpful?
/credit/payroll_income/get
Retrieve a user's payroll information
This endpoint gets payroll income information for a specific user, either as a result of the user connecting to their payroll provider or uploading a pay related document.
credit/payroll_income/getclient_id
client_id
. The client_id
is required and may be provided either in the PLAID-CLIENT-ID
header or as part of a request body.secret
secret
. The secret
is required and may be provided either in the PLAID-SECRET
header or as part of a request body.user_token
options
/credit/payroll_income/get
request options.item_ids
item_id
s whose payroll information is returned. Each item_id
should uniquely identify a payroll income item. If this field is not provided, all item_id
s associated with the user_token
will returned in the response.1const request: CreditPayrollIncomeGetRequest = {2 user_token: 'user-sandbox-b0e2c4ee-a763-4df5-bfe9-46a46bce993d',3};45try {6 const response = await client.creditPayrollIncomeGet(request);7} catch (error) {8 // handle error9}
Response fields and example
items
item_id
item_id
of the Item associated with this webhook, warning, or errorinstitution_id
institution_name
accounts
account_id
rate_of_pay
pay_rate
ANNUAL
, HOURLY
, CONTRACT
, WEEKLY
, BI_WEEKLY
, MONTHLY
, SEMI_MONTHLY
, DAILY
, COMMISSION
, OTHER
, null
pay_amount
double
pay_frequency
DAILY
, WEEKLY
, BIWEEKLY
, SEMI_MONTHLY
, MONTHLY
, CONTRACT
, QUARTERLY
, SEMI_ANNUALLY
, ANNUALLY
, OTHER
, null
payroll_income
account_id
pay_stubs
deductions
breakdown
current_amount
double
description
iso_currency_code
null
if unofficial_currency_code
is non-null.unofficial_currency _code
null
if iso_currency_code
is non-null
. Unofficial currency codes are used for currencies that do not have official ISO currency codes, such as cryptocurrencies and the currencies of certain countries.See the currency code schema for a full listing of supported
iso_currency_code
s.ytd_amount
double
total
current_amount
double
iso_currency_code
null
if unofficial_currency_code
is non-null.unofficial_currency _code
null
if iso_currency_code
is non-null
. Unofficial currency codes are used for currencies that do not have official ISO currency codes, such as cryptocurrencies and the currencies of certain countries.See the currency code schema for a full listing of supported
iso_currency_code
s.ytd_amount
double
document_id
document_metadata
name
document_type
PAYSTUB
: A paystub.BANK_STATEMENT
: A bank statement.US_TAX_W2
: A W-2 wage and tax statement provided by a US employer reflecting wages earned by the employee.US_MILITARY_ERAS
: An electronic Retirement Account Statement (eRAS) issued by the US military.US_MILITARY_LES
: A Leave and Earnings Statement (LES) issued by the US military.US_MILITARY_CLES
: A Civilian Leave and Earnings Statement (CLES) issued by the US military.GIG
: Used to indicate that the income is related to gig work. Does not necessarily correspond to a specific document type.PLAID_GENERATED_PAYSTUB_PDF
: Used to indicate that the PDF for the paystub was generated by Plaid.NONE
: Used to indicate that there is no underlying document for the data.UNKNOWN
: Document type could not be determined.UNKNOWN
, PAYSTUB
, BANK_STATEMENT
, US_TAX_W2
, US_MILITARY_ERAS
, US_MILITARY_LES
, US_MILITARY_CLES
, GIG
, PLAID_GENERATED_PAYSTUB_PDF
, NONE
download_url
null
. If you would like Plaid to generate a PDF if the original is not available, contact your Account Manager. Example generated pay stub.For Document Income, this field will not be
null
, and the file type will be the original file type uploaded by the user. For more details on available file types, see the Document Income documentation.This download URL can only be used once and expires after two minutes. To generate a new download URL, call
/credit/payroll_income/get
again.status
PROCESSING_COMPLETE
: The document was successfully processed.DOCUMENT_ERROR
: The document could not be processed. Possible causes include: The document was an unacceptable document type such as an offer letter or bank statement, the document image was cropped or blurry, or the document was corrupted.UNKNOWN
or null
: An internal error occurred. If this happens repeatedly, contact support or your Plaid account manager.UNKNOWN
, PROCESSING_COMPLETE
, DOCUMENT_ERROR
, null
page_count
error_message
earnings
breakdown
canonical_description
BONUS
, COMMISSION
, OVERTIME
, PAID_TIME_OFF
, REGULAR_PAY
, VACATION
, BASIC_ALLOWANCE_HOUSING
, BASIC_ALLOWANCE_SUBSISTENCE
, OTHER
, ALLOWANCE
, BEREAVEMENT
, HOLIDAY_PAY
, JURY_DUTY
, LEAVE
, LONG_TERM_DISABILITY_PAY
, MILITARY_PAY
, PER_DIEM
, REFERRAL_BONUS
, REIMBURSEMENTS
, RETENTION_BONUS
, RETROACTIVE_PAY
, SEVERANCE_PAY
, SHIFT_DIFFERENTIAL
, SHORT_TERM_DISABILITY_PAY
, SICK_PAY
, SIGNING_BONUS
, TIPS_INCOME
, RETIREMENT
, GIG_ECONOMY
, STOCK_COMPENSATION
, null
current_amount
double
description
hours
iso_currency_code
null
if unofficial_currency_code
is non-null.rate
double
unofficial_currency _code
null
if iso_currency_code
is non-null
. Unofficial currency codes are used for currencies that do not have official ISO currency codes, such as cryptocurrencies and the currencies of certain countries.See the currency code schema for a full listing of supported
iso_currency_code
s.ytd_amount
double
total
current_amount
double
hours
iso_currency_code
null
if unofficial_currency_code
is non-null.unofficial_currency _code
null
if iso_currency_code
is non-null
. Unofficial currency codes are used for currencies that do not have official ISO currency codes, such as cryptocurrencies and the currencies of certain countries.See the currency code schema for a full listing of supported
iso_currency_code
s.ytd_amount
double
employee
name
marital_status
SINGLE
or MARRIED
or NOT LISTED
.SINGLE
, MARRIED
, NOT LISTED
, null
taxpayer_id
net_pay
current_amount
double
description
iso_currency_code
null
if unofficial_currency_code
is non-null.unofficial_currency _code
null
if iso_currency_code
is non-null
. Unofficial currency codes are used for currencies that do not have official ISO currency codes, such as cryptocurrencies and the currencies of certain countries.See the currency code schema for a full listing of supported
iso_currency_code
s.ytd_amount
double
pay_period_details
pay_amount
double
distribution_breakdown
account_name
bank_name
current_amount
double
iso_currency_code
null
if unofficial_currency_code
is non-null.mask
type
unofficial_currency _code
null
if iso_currency_code
is non-null
. Unofficial currency codes are used for currencies that do not have official ISO currency codes, such as cryptocurrencies and the currencies of certain countries.See the currency code schema for a full listing of supported
iso_currency_code
s.gross_earnings
double
iso_currency_code
null
if unofficial_currency_code
is non-null.pay_frequency
UNKNOWN
, WEEKLY
, BIWEEKLY
, SEMI_MONTHLY
, MONTHLY
, null
pay_basis
SALARY
, HOURLY
, COMMISSION
start_date
unofficial_currency _code
null
if iso_currency_code
is non-null
. Unofficial currency codes are used for currencies that do not have official ISO currency codes, such as cryptocurrencies and the currencies of certain countries.See the currency code schema for a full listing of supported
iso_currency_code
s.w2s
document_metadata
name
document_type
PAYSTUB
: A paystub.BANK_STATEMENT
: A bank statement.US_TAX_W2
: A W-2 wage and tax statement provided by a US employer reflecting wages earned by the employee.US_MILITARY_ERAS
: An electronic Retirement Account Statement (eRAS) issued by the US military.US_MILITARY_LES
: A Leave and Earnings Statement (LES) issued by the US military.US_MILITARY_CLES
: A Civilian Leave and Earnings Statement (CLES) issued by the US military.GIG
: Used to indicate that the income is related to gig work. Does not necessarily correspond to a specific document type.PLAID_GENERATED_PAYSTUB_PDF
: Used to indicate that the PDF for the paystub was generated by Plaid.NONE
: Used to indicate that there is no underlying document for the data.UNKNOWN
: Document type could not be determined.UNKNOWN
, PAYSTUB
, BANK_STATEMENT
, US_TAX_W2
, US_MILITARY_ERAS
, US_MILITARY_LES
, US_MILITARY_CLES
, GIG
, PLAID_GENERATED_PAYSTUB_PDF
, NONE
download_url
null
. If you would like Plaid to generate a PDF if the original is not available, contact your Account Manager. Example generated pay stub.For Document Income, this field will not be
null
, and the file type will be the original file type uploaded by the user. For more details on available file types, see the Document Income documentation.This download URL can only be used once and expires after two minutes. To generate a new download URL, call
/credit/payroll_income/get
again.status
PROCESSING_COMPLETE
: The document was successfully processed.DOCUMENT_ERROR
: The document could not be processed. Possible causes include: The document was an unacceptable document type such as an offer letter or bank statement, the document image was cropped or blurry, or the document was corrupted.UNKNOWN
or null
: An internal error occurred. If this happens repeatedly, contact support or your Plaid account manager.UNKNOWN
, PROCESSING_COMPLETE
, DOCUMENT_ERROR
, null
page_count
error_message
document_id
employee
name
marital_status
SINGLE
or MARRIED
or NOT LISTED
.SINGLE
, MARRIED
, NOT LISTED
, null
taxpayer_id
tax_year
employer_id_number
wages_tips_other_comp
federal_income_tax _withheld
social_security_wages
social_security_tax _withheld
medicare_wages_and _tips
medicare_tax_withheld
social_security_tips
allocated_tips
box_9
dependent_care _benefits
nonqualified_plans
statutory_employee
retirement_plan
third_party_sick_pay
other
state_and_local_wages
state
employer_state_id _number
state_wages_tips
state_income_tax
local_wages_tips
local_income_tax
locality_name
form1099s
document_id
document_metadata
name
document_type
PAYSTUB
: A paystub.BANK_STATEMENT
: A bank statement.US_TAX_W2
: A W-2 wage and tax statement provided by a US employer reflecting wages earned by the employee.US_MILITARY_ERAS
: An electronic Retirement Account Statement (eRAS) issued by the US military.US_MILITARY_LES
: A Leave and Earnings Statement (LES) issued by the US military.US_MILITARY_CLES
: A Civilian Leave and Earnings Statement (CLES) issued by the US military.GIG
: Used to indicate that the income is related to gig work. Does not necessarily correspond to a specific document type.PLAID_GENERATED_PAYSTUB_PDF
: Used to indicate that the PDF for the paystub was generated by Plaid.NONE
: Used to indicate that there is no underlying document for the data.UNKNOWN
: Document type could not be determined.UNKNOWN
, PAYSTUB
, BANK_STATEMENT
, US_TAX_W2
, US_MILITARY_ERAS
, US_MILITARY_LES
, US_MILITARY_CLES
, GIG
, PLAID_GENERATED_PAYSTUB_PDF
, NONE
download_url
null
. If you would like Plaid to generate a PDF if the original is not available, contact your Account Manager. Example generated pay stub.For Document Income, this field will not be
null
, and the file type will be the original file type uploaded by the user. For more details on available file types, see the Document Income documentation.This download URL can only be used once and expires after two minutes. To generate a new download URL, call
/credit/payroll_income/get
again.status
PROCESSING_COMPLETE
: The document was successfully processed.DOCUMENT_ERROR
: The document could not be processed. Possible causes include: The document was an unacceptable document type such as an offer letter or bank statement, the document image was cropped or blurry, or the document was corrupted.UNKNOWN
or null
: An internal error occurred. If this happens repeatedly, contact support or your Plaid account manager.UNKNOWN
, PROCESSING_COMPLETE
, DOCUMENT_ERROR
, null
page_count
error_message
form_1099_type
FORM_1099_TYPE_UNKNOWN
, FORM_1099_TYPE_MISC
, FORM_1099_TYPE_K
recipient
name
tin
account_number
facta_filing _requirement
CHECKED
, NOT CHECKED
second_tin_exists
CHECKED
, NOT CHECKED
payer
name
tin
telephone_number
filer
name
tin
type
Payment Settlement Entity (PSE)
, Electronic Payment Facilitator (EPF)
, Other Third Party
tax_year
rents
double
royalties
double
other_income
double
federal_income_tax _withheld
double
fishing_boat_proceeds
double
medical_and _healthcare_payments
double
nonemployee _compensation
double
substitute_payments _in_lieu_of_dividends _or_interest
double
payer_made_direct _sales_of_5000_or _more_of_consumer _products_to_buyer
crop_insurance _proceeds
double
excess_golden _parachute_payments
double
gross_proceeds_paid _to_an_attorney
double
section_409a_deferrals
double
section_409a_income
double
state_tax_withheld
double
state_tax_withheld _lower
double
payer_state_number
payer_state_number _lower
state_income
double
state_income_lower
double
transactions_reported
Payment card
, Third party network
pse_name
pse_telephone_number
gross_amount
double
card_not_present _transaction
double
merchant_category_code
number_of_payment _transactions
january_amount
double
february_amount
double
march_amount
double
april_amount
double
may_amount
double
june_amount
double
july_amount
double
august_amount
double
september_amount
double
october_amount
double
november_amount
double
december_amount
double
primary_state
secondary_state
primary_state_id
secondary_state_id
primary_state_income _tax
double
secondary_state _income_tax
double
status
processing_status
UNKNOWN
: The processing status could not be determined.PROCESSING_COMPLETE
: The processing has completed and the user has approved for sharing. The data is available to be retrieved.PROCESSING
: The verification is still processing. The data is not available yet.FAILED
: The processing failed to complete successfully.APPROVAL_STATUS_PENDING
: The processing has completed but the user has not yet approved the sharing of the data.UNKNOWN
, PROCESSING_COMPLETE
, PROCESSING
, FAILED
, APPROVAL_STATUS_PENDING
updated_at
date-time
error
error_code
and categorized by error_type
. Use these in preference to HTTP status codes to identify and handle specific errors. HTTP status codes are set and provide the broadest categorization of errors: 4xx codes are for developer- or user-related errors, and 5xx codes are for Plaid-related errors, and the status will be 2xx in non-error cases. An Item with a non-null
error object will only be part of an API response when calling /item/get
to view Item status. Otherwise, error fields will be null
if no error has occurred; if an error has occurred, an error code will be returned instead.error_type
INVALID_REQUEST
, INVALID_RESULT
, INVALID_INPUT
, INSTITUTION_ERROR
, RATE_LIMIT_EXCEEDED
, API_ERROR
, ITEM_ERROR
, ASSET_REPORT_ERROR
, RECAPTCHA_ERROR
, OAUTH_ERROR
, PAYMENT_ERROR
, BANK_TRANSFER_ERROR
, INCOME_VERIFICATION_ERROR
, MICRODEPOSITS_ERROR
, SANDBOX_ERROR
, PARTNER_ERROR
, TRANSACTIONS_ERROR
, TRANSACTION_ERROR
, TRANSFER_ERROR
error_code
error_code_reason
null
will be returned otherwise. Safe for programmatic use.Possible values:
OAUTH_INVALID_TOKEN
: The user’s OAuth connection to this institution has been invalidated.OAUTH_CONSENT_EXPIRED
: The user's access consent for this OAuth connection to this institution has expired.OAUTH_REVOKED_TOKEN
: The user’s OAuth connection to this institution is invalid because the user revoked their connection.error_message
display_message