npm package discovery and stats viewer.

Discover Tips

  • General search

    [free text search, go nuts!]

  • Package details

    pkg:[package-name]

  • User packages

    @[username]

Sponsor

Optimize Toolset

I’ve always been into building performant and accessible sites, but lately I’ve been taking it extremely seriously. So much so that I’ve been building a tool to help me optimize and monitor the sites that I build to make sure that I’m making an attempt to offer the best experience to those who visit them. If you’re into performant, accessible and SEO friendly sites, you might like it too! You can check it out at Optimize Toolset.

About

Hi, 👋, I’m Ryan Hefner  and I built this site for me, and you! The goal of this site was to provide an easy way for me to check the stats on my npm packages, both for prioritizing issues and updates, and to give me a little kick in the pants to keep up on stuff.

As I was building it, I realized that I was actually using the tool to build the tool, and figured I might as well put this out there and hopefully others will find it to be a fast and useful way to search and browse npm packages as I have.

If you’re interested in other things I’m working on, follow me on Twitter or check out the open source projects I’ve been publishing on GitHub.

I am also working on a Twitter bot for this site to tweet the most popular, newest, random packages from npm. Please follow that account now and it will start sending out packages soon–ish.

Open Software & Tools

This site wouldn’t be possible without the immense generosity and tireless efforts from the people who make contributions to the world and share their work via open source initiatives. Thank you 🙏

© 2026 – Pkg Stats / Ryan Hefner

@brokenrubik/n8n-nodes-ns

v1.14.1

Published

n8n node for NetSuite SuiteTalk REST API integration

Downloads

700

Readme

n8n-node-netsuite

A comprehensive n8n node for NetSuite integration, providing full access to NetSuite's SuiteTalk REST API with OAuth 2.0 M2M authentication.

npm package: @brokenrubik/n8n-nodes-ns

Features

Secure Authentication

  • OAuth 2.0 Machine-to-Machine (M2M) authentication
  • JWT token-based authentication with PS256 algorithm
  • Automatic token caching and refresh (with 1-minute safety margin)
  • Certificate-based security

Operations (8 total)

  • List Records: Retrieve multiple records with pagination support
  • Get Record: Fetch individual records by ID (with optional sub-resource expansion)
  • Get Metadata: Fetch record type metadata in JSON, OpenAPI 3.0, or JSON Schema formats
  • Insert Record: Create new records
  • Update Record: Modify existing records (supports replace and replaceSelectedFields)
  • Remove Record: Delete records
  • Execute SuiteQL: Run SQL-like queries with automatic offset-based pagination
  • Raw API Request: Direct access to any NetSuite REST endpoint

Reliability

  • Automatic Retry: Exponential backoff for rate limit (429) and temporary errors (502, 503, 504)
  • Configurable Retries: Default 5 retries, configurable 0-10 via node options
  • Backoff Strategy: Starts at 1s, doubles each attempt, max 60s, with ±10% jitter
  • Network Error Recovery: Retries on ECONNRESET, ETIMEDOUT, and connection errors
  • 500 errors are NOT retried (per NetSuite docs, these require contacting support)

Developer-Friendly

  • Modular Architecture: Each operation is a separate module
  • Structured Logging: Workflow-aware logging with NetSuiteLogger (workflow ID, node ID, execution ID)
  • Comprehensive Error Handling: NetSuite-specific error parsing with o:errorDetails extraction
  • TypeScript Support: Full type safety and IntelliSense
  • Custom Record Support: Use any custom record type via script ID

Prerequisites

System Requirements

  • Node.js >= 20.15 and npm
  • n8n installed globally: npm install n8n -g

NetSuite Requirements

  • NetSuite account with REST API access
  • OAuth 2.0 Application configured in NetSuite
  • Certificate and private key for M2M authentication
  • Appropriate permissions for the operations you want to perform

Installation

From npm

npm install @brokenrubik/n8n-nodes-ns

For Development

# Clone the repository
git clone https://github.com/BrokenRubik/n8n-netsuite-node
cd n8n-netsuite-node

# Install dependencies
npm install

# Build the project
npm run build

# Link for local development
npm link

# Restart n8n to load the new node: https://docs.n8n.io/integrations/creating-nodes/test/run-node-locally/

Setup Instructions

Step 1: Create NetSuite Integration Record

  1. Navigate to Integration Setup:

    • Log into your NetSuite account
    • Go to Setup > Integration > Manage Integrations > New
  2. Configure Integration:

    • Enter a Name for your integration (e.g., "n8n NetSuite Integration")
    • Set State to "Enabled"
    • Under Client Credentials (M2M), check "Client Credentials (Machine To Machine) Grant"
    • Leave all other checkboxes unchecked
    • Click Save
  3. Copy Integration Client ID:

    • Important: After saving, immediately copy the Integration Client ID
    • This ID will disappear if you close the tab or navigate away
    • Store it securely as you'll need it for the n8n credentials

Step 2: Generate Certificate and Private Key

  1. Create Certificate Pair:

    • Open a terminal/command prompt
    • Generate a private key and certificate using OpenSSL:
    openssl req -x509 -newkey rsa:3072 -keyout n8n_key.pem -out n8n_cert.pem -days 365 -nodes
  2. Alternative: Using NetSuite's Guide:

Step 3: Upload Certificate to NetSuite

  1. Navigate to Certificate Setup:

    • Go to Setup > Integration > Manage Authentication > OAuth 2.0 Client Credentials (M2M) Setup
  2. Upload Certificate:

    • Click "New" to create a new certificate entry
    • Enter a Name for the certificate (e.g., "n8n Integration Certificate")
    • Upload the certificate file (n8n_cert.pem) - not the private key
    • Click Save
  3. Copy Certificate ID:

    • After saving, copy the generated Certificate ID
    • You'll need this for the n8n credentials

Step 4: Set Up n8n Credentials

  1. Open n8n:

    • Navigate to Credentials in n8n
    • Click "Add Credential"
    • Select "NetSuite API"
  2. Enter Credential Information:

    • Account ID: Your NetSuite account ID (e.g., "1234567" or "1234567_SB1" for sandbox)
    • Integration Client ID: The ID copied from Step 1
    • Certificate ID (M2M): The ID copied from Step 3
    • PEM Content: Copy and paste the entire content of your private key file (n8n_key.pem)
  3. PEM Content Format:

    -----BEGIN PRIVATE KEY-----
    MIIEvgIBADANBgkqhkiG9w0BAQEFAASCBKgwggSkAgEAAoIBAQC...
    ... (your private key content) ...
    -----END PRIVATE KEY-----

Step 5: Test the Connection

  1. Create a Test Workflow:
    • Create a new workflow in n8n
    • Add a NetSuite SuiteTalk node
    • Configure it to list a simple record type (e.g., Customer)
    • Execute the workflow to verify the connection

Usage Examples

List Sales Orders

| Parameter | Value | |-----------|-------| | Operation | List Records | | Record Type | Sales Order | | Query | status IS SalesOrd:F | | Return All | false | | Limit | 100 |

The Query field maps to NetSuite's q filter parameter. NetSuite uses the syntax field OPERATOR value (e.g., status IS SalesOrd:F, email IS "[email protected]").

Get a Record with Sub-Resources

| Parameter | Value | |-----------|-------| | Operation | Get Record | | Record Type | Sales Order | | ID | 12345 | | Expand Sub-Resources | true | | Restrict Returned Fields | item,entity |

The ID field accepts internal IDs. Prefix with eid: to use external IDs (e.g., eid:MY_EXT_ID).

Create Customer Record

| Parameter | Value | |-----------|-------| | Operation | Insert Record | | Record Type | Customer |

The input data from the previous node is used as the request body:

{
  "companyName": "Acme Corp",
  "email": "[email protected]",
  "phone": "+1-555-0123"
}

Returns { success: true, id: "<new-record-id>", location: "<api-url>", recordType: "customer" }.

Execute SuiteQL Query

| Parameter | Value | |-----------|-------| | Operation | Execute SuiteQL | | Query | SELECT id, companyname, email FROM customer WHERE datecreated >= '2024-01-01' | | Return All | true |

SuiteQL uses SQL-like syntax with NetSuite's database column names (lowercase). When Return All is enabled, the node automatically paginates through all results using offset-based pagination (up to 1000 rows per page).

Get Metadata Catalog

| Parameter | Value | |-----------|-------| | Operation | Get Metadata | | Metadata Format | JSON (Record Type List) | | Record Types | customer,salesOrder,invoice |

Available formats:

  • JSON: Lists available record types
  • OpenAPI 3.0 (Swagger): Full API specification
  • JSON Schema: Record structure descriptions

Leave Record Types empty to return all (can be slow for accounts with many customizations).

Raw API Request

| Parameter | Value | |-----------|-------| | Operation | Raw Request | | HTTP Method | GET | | Path | services/rest/record/v1/customer/123 | | Full Response | true |

The Path is appended to https://<account>.suitetalk.api.netsuite.com/. You can also paste a full URL and the node will extract the path automatically. For methods other than GET/HEAD/OPTIONS, input data from the previous node is sent as the request body.

Using Custom Records

| Parameter | Value | |-----------|-------| | Operation | List Records | | Record Type | Custom Record | | Custom Record Script ID | customrecord_my_record | | Return All | true |

Select Custom Record as the Record Type, then enter the script ID (usually starts with customrecord).

Architecture

Modular Design

  • Main Node (NetSuite.node.ts): Orchestrates 8 operations via switch statement (~150 lines)
  • Service Layer (NetSuite.service.ts): OAuth 2.0 M2M auth, token caching, retry-wrapped HTTP requests
  • Operation Modules (operations/): One file per operation, consistent INetSuiteOperationOptions interface
  • Type System (types/): Auth, request, response, operation, and logger types
  • Utilities (utils/): Response handler, helpers, retry handler, structured logger

Error Handling

  • Follows NetSuite's official error format (o:errorDetails array)
  • Extracts error codes, paths, and details from responses
  • Provides specific guidance per HTTP status code
  • Supports graceful degradation with "Continue on Fail"

SuiteQL Pagination

SuiteQL uses offset-based pagination (not response link-based). Each page requests up to 1000 rows. The loop advances the offset by the number of items returned and stops when fewer items than requested come back. This avoids infinite loops caused by unreliable hasMore/nextUrl fields in SuiteQL POST responses.

Development

Project Structure

nodes/NetSuite/
  types/              # TypeScript type definitions
  utils/              # Response handler, logger, retry handler, helpers
  operations/         # 8 operation modules (one per operation)
  NetSuite.node.ts    # Main node class (orchestrator)
  NetSuite.service.ts # Service layer (auth + API communication)
  NetSuite.node.options.ts # Node UI configuration
credentials/
  NetSuiteApi.credentials.ts # n8n credential definition

Common Commands

| Command | Description | |---------|-------------| | npm run build | Build the project (compiles TypeScript and copies icons) | | npm run dev | Watch mode for development | | npm run lint | Run ESLint | | npm run lintfix | Auto-fix lint errors | | npm run format | Format code with Prettier |

Adding New Operations

  1. Create operation file in operations/ directory
  2. Export function from operations/index.ts
  3. Add case to switch statement in NetSuite.node.ts
  4. Add UI configuration to NetSuite.node.options.ts

Troubleshooting

Debug Logging

  • Legacy debug output: DEBUG=n8n-nodes-netsuite
  • Structured logger: Set N8N_LOG_LEVEL=debug for verbose NetSuiteLogger output
  • Both can be enabled simultaneously

Common Issues

  • 401 Unauthorized: Check that your Integration Client ID, Certificate ID, and PEM content are correct. Ensure the certificate hasn't expired.
  • 403 Forbidden: Verify the role assigned to the integration has permissions for the record type and operation.
  • 429 Too Many Requests: The node retries automatically with exponential backoff. If persistent, reduce concurrency or increase retry count.
  • 500 Internal Server Error: Not retried. Check NetSuite's audit trail or contact NetSuite support.

License

MIT