Skip to main content
All CollectionsSalto for Netsuite
Salto for NetSuite - Overview
Salto for NetSuite - Overview
Support avatar
Written by Support
Updated this week

Salto’s NetSuite adapter allows you to:

  • Fetch and deploy common NetSuite configuration data, e.g., workflows, custom fields, enabled features.

  • Deploy configuration changes from one NetSuite account to another.

  • Compare accounts.

  • Document configuration changes.

  • Monitor specific configuration data changes of interest, e.g., preferences, permission schemes.

Supported Types

Setup Instructions

Prerequisites for connecting a NetSuite account with Salto:

  • Enable SuiteCloud Development (SDF)

  • Install the Salto SuiteApp

    • Note: The Salto SuiteApp creates an integration as part of its installation. Please use that integration in the next steps. A custom integration that is created separately is not supported.

  • Generate authentication tokens for SDF and Salto SuiteApp

Enabling SuiteCloud Development (SDF)

📘 The below steps require admin permission for your NetSuite account.

  1. Go to Customization -> SuiteBundler -> Search & Install Bundles and click.

  2. Search for suitecloud, and choose the bundle SuiteCloud Development Integration

  3. Click “Install” to start the bundle installation.

  4. Go to Setup->Company->Enable Features

  5. Choose the “SuiteCloud” tab and make sure the following features are enabled:

    • SOAP web services

    • REST web services

    • Token Based Authentication

    • OAuth 2.0

    • SuiteCloud Development Framework

  6. Agree to all updates and Save.

  7. Go to Customization -> SuiteBundler -> Search & Install Bundles -> List and click in order to verify that SDF installation is done.

  8. Go to Setup -> Integration -> Manage Integrations and click "SuiteCloud Development Integration".

  9. Verify that the integration's state is "Enabled" and that all grants under OAuth 2.0 are marked.

Installing the Salto SuiteApp (aka Salto Integration Application)

  1. Go to SuiteApps

  2. Search for “Salto”, and choose the SuiteApp called “Salto” and click "Install"

  3. Go to Setup->Company->Enable Features

  4. Choose the “SuiteCloud” tab and make sure the following features are enabled:

    • SOAP Web Services

    • REST Web Services

    • Token Based Authentication

    • Create bundles with SuiteBundler

  5. Go to Customization -> SuiteCloud Development -> Installed SuiteApp List in order to verify that Salto's SuiteApp installation is done.

Generating Authentication Tokens for Salto SuiteApp

  1. Go to the home screen, click on “Manage Access Tokens”.

  2. Click on “New My Access Tokens”.

  3. Choose “Salto Integration” from the “Application Name” dropdown.

  4. Click "Save".

  5. Copy the “Token ID” and “Token Secret” and save them. They will not be visible later on due to security reasons.

👍 You have successfully installed SuiteCloud Development (SDF) and Salto's SuiteApp.
You are now ready to connect your NetSuite account to Salto.

Authentication Instructions

In application credentials, provide:

  • NetSuite account ID - can be copied from your NetSuite URL (https://<NetSuiteAccountId>.app.netsuite.com)

  • Certificate ID for SDF OAuth 2.0 (please see instructions below)

  • Token ID and secret for Salto's SuiteApp

Example - Creating a New Environment

Note - to change the authentication credentials in an existing environment, click on the environment name and then click SETTINGS to access the adapter configuration and credentials area.

  1. Create a new environment

  2. Provide a name for the environment (this name can be changed later)

  3. Click on "Connect an App"

  4. Select NetSuite and click "Next"

  5. Set the permissions for the credentials and click "Next"

  6. Install the plugin in your Salto account and click "Next"

  7. Provide your NetSuite Account ID and click "Next"

  8. In the SDF OAuth credentials step, generate a certificate and save it to your computer.

  9. Navigate in NetSuite UI to Setup > Integration > OAuth 2.0 Client Credentials (M2M) Setup and click "Create New"

  10. Choose the Entity (employee), Role (Administrator), and "SuiteCloud Development Integration" as the Application. Upload the certificate and click "Save"

  11. Copy your new SDF certificate ID and paste it back in Salto, then click "Next"

  12. Provide the Salto SuiteApp Token ID and Token Secret and click "Authenticate"

  13. When the credentials are verified, click "Next"

  14. Select "Connect App" or "Connect App & Fetch" to finish the setup.

Fetch and Application Connection Configuration Properties

Fetch Configuration

To learn what is the default NetSuite configuration and how you can modify it to support different use-cases such as fetching custom records or file cabinet, check out this guide.

🚧 Note: Adding more types to your fetch configuration is likely to influence the fetch duration, especially if these types have many instances.

Unlock the full potential of analytics in Salto by adjusting your NetSuite adapter configuration to include analytics Workbooks & Datasets.
This enables a deeper analysis and a broader view of your business metrics, leveraging multiple joins and dynamic data presentations.

To enable Analytics in your account, it's necessary to remove the metadata types 'Workbook' and 'Dataset' from your adapter configuration's exclude list.

Change-Based Fetch

Changed-Based Fetch leverages NetSuite’s ‘system notes’ mechanism and significantly reduces the fetch time by fetching only records and file cabinet items that were modified since your last fetch.

Fetch Specific Types or Files

Specifying NetSuite type names and/or file cabinet path patterns (regular expressions) can reduce fetch time.
Once specified, Salto will fetch only instances of specified types and file cabinet items that matches the specified path patterns.

For example, specifying the following targets:

  • entitycustomfield

  • addressForm

  • customrecord_slt_tst

  • /MyFileCabinetDir/.*\.js

will only fetch entity custom fields, address forms, custom records of customrecord_slt_tst and all files with the .js suffix under the MyFileCabinetDir directory.

🚧 Note that:

  • Deletions in File Cabinet can not be detected in a Change-Based Fetch. All other deletions (standard instances, custom types & custom records) are supported.

  • References in fetched elements will be updated as part of the partial fetch as long as the referenced element exists in the Salto environment. If the referenced element does not exist in the Salto environment (meaning it is either new in that environment and was not fetched yet or that it was deleted), its reference will be omitted until a full regular fetch is performed

Overriding Configuration Values

It is possible to override any fetch configuration property by specifying a key value pair.
Full list of available configuration options can be found here.

FAQs

What does the NetSuite config file look like?

Please refer to this page for details.

What is the benefit of using Salto instead of working directly with SDF?

Salto leverages SDF under the hood, along with a SuiteApp developed by Salto. Thus, Salto extends SDF and adds several key capabilities and components:

  • All files in the file cabinet (including deletions).

  • Data records such as account, subsidiary, department, classification, currency and more.

  • Deletions of custom record types and instances of standard types such as custom entity field, custom CRM field, custom list, custom item field, custom item, number field, custom item option, custom transaction column field and more.

Why does my NetSuite Adapter configuration sometimes get updated automatically?

There are 2 cases where elements are excluded automatically:

  1. When fetching an element via SDF, the element cannot be accessed due to SDF returning an unexpected error in its response. To avoid repeated errors and potential fetch failures, the element is automatically added to the exclude list in the Salto configuration file and will be skipped in subsequent fetches.

    1. Note: If you are unable to access the element's XML definition from the NetSuite UI, we recommend reaching out to NetSuite support as there is likely an issue with the underlying object preventing it from being accessed via SDF.

  2. If an element is locked in NetSuite, SDF will return the error You cannot download the XML file for this object because it is locked, preventing the element from being fetched. When locked elements are detected, they are added to a separate configuration file (lockedElements.nacl) used to track locked elements to be excluded from subsequent fetches.

Are SuiteScripts supported?

Yes, SuiteScripts are fully supported, including identifying dependencies from custom fields that can be used for impact analysis, comparing across environments, and deployments.

What impact does Salto have on my API limits?

Concurrency

What are the limits?

NetSuite limits concurrency on both your account level, and per-integration. Learn more here.

How can you adjust usage or capacity?

- See sdfConcurrencyLimit in NetSuite adapter configuration
- Raise the concurrency limit for the Salto integration, see here
- Raise the concurrency limit of your account, see here

Did this answer your question?