Skip to content

t3hchipmunk/netsuite-suitetalk

 
 

Folders and files

NameName
Last commit message
Last commit date

Latest commit

 
 
 
 
 
 
 
 
 
 
 
 
 

Repository files navigation

Getting Started

Install the package using npm.

$ npm i netsuite-suitetalk --save

Create a new instance of the client. Initializing the client is an asynchronous operation.

'use strict';
const netsuite       = require('netsuite-suitetalk');
// use credentials authentication
const netSuiteClient = new netsuite(
{
    accountId : YOURACCOUNTID,
    appId     : YOURAPPLICATIONID,
    baseUrl   : YOURBASEURL,     // defaults to production NS - https://webservices.netsuite.com/services/NetSuitePort_2018_1
    password  : YOURPASSWORD,
    roleId    : YOURROLEID,
    username  : YOURUSERNAME,
    wsdlPath  : YOURWSDLPATH    // defaults to wsdl (v2018_1) - https://webservices.netsuite.com/wsdl/v2018_1_0/netsuite.wsdl
});

// use token based authentication
const netSuiteClient = new netsuite(
{
    accountId : YOURACCOUNTID,
    baseUrl   : YOURBASEURL,     // defaults to production NS - https://webservices.netsuite.com/services/NetSuitePort_2018_1
	tokenValues: {
		tokenId: YOURTOKENID,
		tokenSecret: YOURTOKENSECRET,
		consumerKey: YOURCONSUMERKEY,
		consumerSecret: YOURCONSUMERSECRET
	},
    wsdlPath  : YOURWSDLPATH    // defaults to wsdl (v2018_1) - https://webservices.netsuite.com/wsdl/v2018_1_0/netsuite.wsdl
});

netSuiteClient.initialize((err) =>
{
    // netSuiteClient methods are available
});

Methods

Get Record

Get any NetSuite record by type and internalId. This is an asynchronous call requiring the use of a callback.

netSuiteClient.get(type, internalId, callback);

Arguments

  • type (String): Type of Record (i.e. 'salesOrder', 'customer')
  • internalId (String|Number): Internal Id of Record
  • callback (Function): (err, resp)

Example

netSuiteClient.get('customer', '12345', (err, data) =>
{
    if (data && data.readResponse && data.readResponse.status && data.readResponse.status.attributes && data.readResponse.status.attributes.isSuccess)
    {
        console.log(data.readResponse.record);
    }
});
Update Record

Update any allowed NetSuite record by type, internalId, and fields. This is an asynchronous call requiring the use of a callback. Currently this does not work with customFieldList.

netSuiteClient.update(type, internalId, fields, callback);

Arguments

  • type (String): Type of Record (i.e. 'SalesOrder', 'Customer'). Note the different case than the get method.
  • internalId (String|Number): Internal Id of Record
  • fields (Hashtable): Table of name/value properties of fields to update
  • callback (Function): (err, resp)

Example

let fields =
{
    title: 'Developer',
    salutation: 'Mr.'
};

netSuiteClient.update('Customer', '12345', fields, (err, data) =>
{
    if (err)
    {
        console.log('ERROR\n', err);
        return;
    }

    if (data && data.writeResponse && data.writeResponse.status && data.writeResponse.status.attributes && data.writeResponse.status.attributes.isSuccess)
    {
        console.log('Update was successful');
    }
});

About

NetSuite SuiteTalk Node.js Wrapper

Resources

Stars

Watchers

Forks

Releases

No releases published

Packages

No packages published

Languages

  • JavaScript 100.0%