Using the Sandbox Environment
Middesk has a sandbox environment that can be accessed through the API or through the Dashboard. Sandbox mode can be used to test your integration end to end with mock data.
Accessing Sandbox Mode Through the Dashboard
While logged in to the dashboard, you can access the Sandbox test environment by clicking on the Products icon on the top-right corner of the page, then toggling "View Sandbox". Once in Sandbox mode, the sample attributes described under the Example Sandbox Business Attributes table below can be used to create a Business with sample data.
Accessing Sandbox Mode Through the API
You are immediately provided Sandbox API keys when your account is created. Your Sandbox keys can be retrieved by logging into your Middesk account and visiting Developer Settings. Sandbox keys must be used with the Sandbox API url https://api-sandbox.middesk.com/v1/
.
Sandbox API requests are free and while you may include real business data in the Create a Business request, the response will return fake data. You may also set up Webhooks in the Sandbox environment.
Example Sandbox Business Attributes
One major benefit of using the Sandbox environment is that you can walk through various example scenarios that you might encounter you Create a Business.
To do so, include one (or more) of the specified values in the table below in your Create a Business request. Middesk will then return a response according to that value. This will allow you to run specific scenarios and build out your integration workflow accordingly.
Feel free to mix-and-match any of the values found on the table to create unique scenarios. For example, you can create a business with an approximate address match and unverified person using the inputs 223 Grand St., New York, NY 10013
and J Doe
, respectively.
Default Responses
If none of the special case inputs listed below are included in a submitted business, the Business will fallback to verifying all information. Given most inputs then, you can expect to receive a Review object with successful tasks.
Name Statuses
Type | Value | Description |
---|---|---|
Name | Unregistered Business | The business has no Secretary of State filings. The Business returned will have no associated registrations. |
Name | Similar Name Business | The business has a Secretary of State filing with a similar name to the submitted business name. The "name" review task indicates that a similar name was found to the submitted name. |
Name | Unverified Name Business | The submitted business name is unverified. The "name" review task indicates that a no similar name was found to match the submitted name. |
Name | Corporation | The business will have a formation entity_type matching the type CORPORATION . CORPORATION is the default if there's no entity type provided. |
Name | Partnership | The business will have a formation entity_type matching the type PARTNERSHIP . |
Name | Sole Proprietorship | The business will have a formation entity_type matching the type SOLE PROPRIETORSHIP . |
Name | Trust | The business will have a formation entity_type matching the type TRUST . |
Name | Non Profit | The business will have a formation entity_type matching the type Non Profit . |
Name | Agent | The business will have a formation entity_type matching the type AGENT . |
Name | LLC | The business will have a formation entity_type matching the type LLC . |
Name | Young Business | The business will have been formed 10 days ago. The formation date should be ten days before the current date. |
Name | A business name containing the phrase short analyst review | This will simulate a standard case of a business being flagged for Middesk's Analyst-in-the-Loop flow by delaying the completion of the Identity order by 2 minutes. After 2 minutes the business will move from status: pending to status: in_review , results will be returned depending on the other trigger values provided, and a business.updated webhook will be sent if that is set up for your account. |
Name | A business name containing the phrase long analyst review | This will simulate a long-running case of a business being flagged for Middesk's Analyst-in-the-Loop flow by delaying the completion of the Identity order by 10 minutes. After 10 minutes the business will move from status: pending to status: in_review , results will be returned depending on the other trigger values provided, and a business.updated webhook will be sent if that is set up for your account. |
Address Statuses
Type | Value | Description |
---|---|---|
Address | 123 Grand St., New York, NY 10013 | Unable to identify a match to the submitted Office Address. The submitted address is not found to match any address listed in Business records. |
Address | 223 Grand St., New York, NY 10013 | Identified a similar address. The submitted address is similar to an address that has been found. |
Address | 423 Grand St., New York, NY 10013 | Identified an approximate address. Identified an address within 0.2 miles of the submitted Office Address |
Address | New York, NY | Identified an incomplete address. Identified a partial match with a submitted address that is incomplete |
Address - CMRA | Include cmra in address_line1 or full_address (e.g. 991 cmra st., New York, NY 10013 )You may also combine this w/ Office Address -Verification values. For example, 423 Grand St. cmra will trigger an Approximate Match + CMRA task | Identified a CMRA address. Submitted Office Address is zoned by USPS as a Commercial Mail Receiving Agency |
Address - Registered Agent | Include registered agent in address_line1 or full_address (e.g. 991 registered agent st., New York, NY 10013 )You may also combine this w/ Office Address -Verification values. For example, 423 Grand St. registered agent will trigger an Approximate Match + Registered Agent task | Identified a Registered Agent address: Submitted Office Address is actually the address of a Registered Agent, not the actual business |
Address - Deliverability | Include undeliverable in address_line1 or full_address (e.g. 991 st. undeliverable, New York, NY 10013 You may also combine this w/ Office Address -Verification values. For example, 423 Grand St. undeliverable will trigger an Approximate Match + Undeliverable task | Identified an Undeliverable address: The USPS is unable to deliver mail to the submitted Office Address |
SOS Statuses
Type | Value | Description |
---|---|---|
SOS Filings - Domestic | Business Name = Domestic Missing | Missing Domestic Secretary of State Filing: The business has no domestic filing |
SOS Filings - Domestic | Business Name = Domestic Inactive | Domestic Secretary of State Filing is Inactive: Inactive domestic filing found |
SOS Filings - Domestic | Business Name = Domestic Unknown | Unable to detect status of Domestic Filing: No domestic filing status provided |
SOS Filings - Partially Inactive | Business Name = Partial Inactive | At least one Secretary of state filing is inactive and another active: At least one filing is active. Another inactive. |
Entity Types
Type | Value | Description |
---|---|---|
entity_type | CORPORATION | This will cause the entity_type_match insight to return a failure |
entity_type | LLC | This will cause the entity_type_match insight to return a success |
Person Statuses
Type | Value | Description |
---|---|---|
Person | J Doe | Unable to identify a match to the submitted person. The person input will result in an unverified Person, meaning there's no match found to the Person's name on any Business record. |
TIN Statuses
Type | Value | Description |
---|---|---|
TIN | 110000099 | TIN Name mismatch. The submitted TIN was found to be associated with a different entity name. |
TIN | 111222333 | TIN Name unknown and issued. The submitted TIN's status is unknown. The TIN's issued status will be issued. |
TIN | 444555666 | TIN Name unknown and not issued This TIN will return unverified with the submitted name and will also be marked as unissued. |
TIN | tin = 222333444 Person = Jane Match If SSN or SSN and EIN is added to the end of the Person name, then the returned tin_type will change accordingly | TIN Name matches the submitted person. The submitted TIN is associated with the submitted person. |
TIN | Business name ends with SSN or SSN and EIN | TIN type changed The submitted TIN will have a tin_type of whichever type is added to the submitted business name |
TIN | 333444555 | IRS Unavailable. The IRS is unavailable at this time. TIN will be rerun once the IRS is available again |
Bankruptcy
Type | Value | Description |
---|---|---|
Bankruptcy | A business name containing the word bankruptcy | The business will have a bankruptcy. The Business will have a bankruptcy attached. |
Watchlist
Type | Value | Description |
---|---|---|
Watchlist | A Business name or Person name containing the phrase watchlist hit . | The business or person will have a watchlist hit on them |
Industry Classification
Type | Value | Description |
---|---|---|
Industry Classification | Any website | The business' website will have an industry classification |
Industry Classification | A website containing the wordshighrisk | The business' website will have an industry classification with a high risk result. |
Liens Search
Type | Value | Description |
---|---|---|
No Liens Found | Any business name | No liens will be found. The liens search will return no records for this business. Note: Liens is a premium feature. See this page for more information. |
Liens Found - Blanket | Any business name containing the phrase liens found | By default, blanket liens will be found (see the collateral_type field). |
Liens Found - Collateral | To produce collateral liens in the search results, add the phrase liens found collateral lien to the business name. |
NPI Records
Type | Value | Description |
---|---|---|
NPI Records | A business named Healthcare Provider | This will return a business with NPI records returned. The submitted address will be linked to an NPI record. |
FMCSA Records
Type | Value | Description |
---|---|---|
FMCSA Registrations | A business named Trucking Business | This will return a business with FMCSA registrations . The submitted address will be linked to an FMCSA registration. |
People Bankruptcy
Type | Value | Description |
---|---|---|
Person | A person with a provided first_name, last_name, and SSN, with the last name containing bankruptcy | When people bankruptcies are ordered, the provided person will have a bankruptcy returned on them. |
Socure KYC
Type | Value | Description |
---|---|---|
Person with KYC fields | Any person with KYC fields | All of the fields present on a sandbox Socure KYC Person request will be sent through to Socure's sandbox triggers. You can read about Socure's sandbox trigger values here (Socure account and login required). Note: KYC is a premium feature. See this page for more information. |
Adverse Media
Type | Value | Description |
---|---|---|
adverse_media | A business name containing "adverse media highrisk" | This will result in a High Risk result for adverse media (identity /business_verification_verify and adverse_media must be ordered on the business) |
adverse_media | A business name containing "adverse media lowrisk" | This will result in a Low Risk result for adverse media (identity /business_verification_verify and adverse_media must be ordered on the business) |
adverse_media | A business name containing "adverse media moderaterisk" | This will result in a Moderate Risk result for adverse media (identity / business_verification_verify and adverse_media must be ordered on the business) |
Differences between Sandbox and Production
The Sandbox environment enables you to familiarize yourself and experiment with the Middesk API before going live in a Production environment. Listed below are some key differences between the two environments:
Depth of report information
Middesk provides a rich set of information for its Businesses. In Production, a Business could have a significant number of Resources associated with it such as multiple registration records, multiple addresses, multiple officers, and so on. The Sandbox environment provides enough information to build an integration, but the variance in the data that is returned is limited in order to address the most common integration use cases.
Business lifecycle
As referenced in the Lifecycle of a Business section, Middesk transitions a Business through multiple statuses, from pending
to in_review
. The Sandbox environment supports all of these statuses, with the exception of the in_audit
status. When building in Sandbox, it's important to take this difference into consideration.
Documents
In Sandbox, Documents can be ordered for every Business that is created. Ordering Documents automatically is a premium feature which must also be enabled in Production. If interested in learning more, please contact sales.
Liens
In Sandbox, Liens can be ordered for every Business that is created. Ordering Liens Searches automatically is a premium feature which must also be enabled in Production. If interested in learning more, please contact sales.
Litigations
In Sandbox, Litigations are not automatic. Ordering litigations is a premium feature and to enable the support in Sandbox, it has to be enabled in production and configured to order automatically. If interested in learning more, please contact sales.
Signal
In Sandbox, Signal Signal is not automatically ordered on all submitted businesses. Ordering Signal is a separate feature and to enable the support in Sandbox. If interested in learning more, please contact`sales.
Once enabled, you can test Signal through the Middesk dashboard and API. Using sample inputs through the CSV upload process, you can also test Signal in batches directly within the dashboard.
Additional features
Business Batches
Businesses can be created in Batches in both the Sandbox and Production environments. Use this feature to create many businesses at once, and provide attributes as detailed in the table above to trigger different verification scenarios as desired.
Industry Classification
Classifications can be created for Sandbox businesses if a website URL is inputted or as stand-alone classifications. For both products, the possible inputs to get different results are described below:
Website URL | Results |
---|---|
Containshighrisk | Includes a result in a high-risk category. |
Anything else | Results only in low-risk categories. |
Monitoring
To test monitoring, create a business with the inputs described below. The business will automatically have a monitor with the corresponding event type. After a minute, the business and its records will be updated accordingly to simulate the occurrence of that event, which you can receive by creating a webhook or polling for updates.
Event Type | Input Field | Value | Description |
---|---|---|---|
watchlist_result.created | Business Name | Watchlist Result Created Inc | A new Watchlist Result will be created for the Business |
tin.retrieved | TI | 111222333 | The TIN will initially be unknown and then become verified. |
registration.updated | Business Name | Monitoring Registration.Updated | A registration associated will be updated and a registration.updated officers, status, addresses fields will be updated. |
Lien Filing
To test Lien Filing, you'll need to have Lien Filing enabled in production. If it is not currently enabled, you can contact [email protected] to get that set up. Once enabled, you can test with the File a Lien endpoint in Sandbox. Approximately thirty seconds after you hit the File a Lien endpoint, we'll transition the Lien status to filed
to mimic the time it takes Middesk to process your request. At this point, a production filing would have been submitted to the government, but no UCC-1 Document would be associated with the Lien, and this is the case in Sandbox too. After approximately another thirty seconds, we'll transition the Lien status to open
to mimic the time it takes the government to process the filing. At this point, a production filing would have a UCC-1 document, and a blank UCC-1 document will be present on the Lien in Sandbox to reflect this. lien.updated
Webhook Events are sent when the Lien status changes.
User Roles and Permissions
Each Middesk user has a role that allows for specific capabilities:
- Member: Basic team member; can create and view Businesses
- Developer: Includes all Member privileges as well as the ability to view (and edit where appropriate) API Keys, Webhooks, APILogs, IPAllowLists, and add Batches
- Admin: All privileges; including Developer privileges as well as the ability to add team members and to customize Policies
Updated about 1 month ago