NetSuite Restlet 2.0 Tutorial
To enable integration (e.g. with Shopify and Amazon), you'll need to expose a RESTful endpoint and create a script to handle POSTs to that endpoint:
1) Enable Features
Login to NetSuite as an administrator
Go to Setup > Company > Enable Features and click on the SuiteCloud subtab, then enable these features:
- Client SuiteScript
- Server SuiteScript
- Token-Based Authentication
data:image/s3,"s3://crabby-images/aa8ab/aa8ab2008daf485d0b9461e59faaeffceec83280" alt=""
data:image/s3,"s3://crabby-images/a849e/a849e8c57301de780441bf22ef34158096f86e2f" alt=""
Then click Save
2) Set Up Role
Go to Setup > Users/Roles > Manage Roles > New and enter the following information:
- Name: Token Based Authentication
- ID: _token_based_auth
- Center Type: System Administrator Center
- Accessible Subsidiaries (for OneWorld accounts): ALL
In the Permissions > Setup subtab, add the following permissions (at Full level):
- Access Token Management
- Log in using Access Tokens
- User Access Tokens
data:image/s3,"s3://crabby-images/0bb33/0bb3349bebbb5c301f5a883f1da8680773d2ac24" alt=""
Then click Save
3) Create Employee Record
Go to Lists > Employees > Employees > New and enter the following information:
- Name: Restlet User
- Email: create a new email address/alias using your company email system and enter it here
- Subsidiary (for OneWorld accounts): your company subsidiary
In the Access subtab, do the following:
- check Give Access
- check Manually Assign or Change Password and set a complex password
- select Token Based Authentication for the role and click Add
data:image/s3,"s3://crabby-images/fcf27/fcf2709f2200e2bcaa2b2281c7cdd872cf4c9447" alt=""
Then click Save
4) Create Integration Record
Go to Setup > Integration > Manage Integrations > New and enter the following information:
- Name: Restlet Integration
In the Authentication subtab, uncheck User Credentials and check Token-Based Authentication:
data:image/s3,"s3://crabby-images/2a1b9/2a1b94f79647210fddad241f7b5cb584d96a5de8" alt=""
Then click Save
IMPORTANT: copy the Consumer Key and Consumer Secret values to a safe location:
data:image/s3,"s3://crabby-images/48060/480604ac0bb7daf6b8c9c0d0f5406601308bd237" alt=""
5) Create Employee Token
Logout of NetSuite
Login with employee credentials from Step #3
Go to Setup > Users/Roles > Access Tokens > New and enter the following information:
- Application Name: Restlet Integration
- User: Restlet User
- Role: Token Based Authentication
- Token Name (rename to): Restlet Integration Token
data:image/s3,"s3://crabby-images/57d8b/57d8b6fc9355ee17493a44cef1e98c0c9ba7aa0a" alt=""
Then click Save
IMPORTANT: copy the Token ID and Token Secret values to a safe location:
data:image/s3,"s3://crabby-images/d3084/d30843fa3a9bb27a2f75d4400371220d0de3dca0" alt=""
Logout of NetSuite
6) Download Code Template
7) Upload Code Template
Login to NetSuite as an administrator
Go to Customization > Scripting > Scripts > New
Hover your mouse to the right of the textbox and a plus (+) sign with appear. Click on it.
data:image/s3,"s3://crabby-images/cddbd/cddbda01b3e934da3dec208b1c00d25eb83932c8" alt=""
Select SuiteScripts for Folder and select the file from Step #6, then click Save
data:image/s3,"s3://crabby-images/d7437/d7437ac357a6da94826f415925e10e13d8c1c3bd" alt=""
Click Create Script Record
data:image/s3,"s3://crabby-images/45a6e/45a6e7b1f12da50d1285bf3f6f86377661527b92" alt=""
Enter the following information:
- Name: Restlet Example
- ID: _restlet_example
data:image/s3,"s3://crabby-images/dafc1/dafc17863ec3c8d0447b8dff32a41a25e533d46e" alt=""
Then click Save
Click Deploy Script
data:image/s3,"s3://crabby-images/15530/1553021f759b45f9ab9e5841d7decc6275fc0134" alt=""
Enter the following information:
- Title: Restlet Example Deployment
- ID: _restlet_example_deployment
- Status: Released
- Log Level: Debug
- Roles: Token Based Authentication
- Subsidiaries (for OneWorld accounts): select your subsidiary
- Employees: Restlet User
data:image/s3,"s3://crabby-images/014aa/014aa6faed612c5db4870ab537418db15466227a" alt=""
Then click Save
IMPORTANT: copy the External URL value to a safe location:
data:image/s3,"s3://crabby-images/6e246/6e24667f0816999b8a08801404214e1b72dc4eb8" alt=""
8) Get Account ID
Go to Setup > Company > Company Information
IMPORTANT: copy the Account ID value to a safe location:
data:image/s3,"s3://crabby-images/b849d/b849dca6471918894d4ab3da9750f86dafafb987" alt=""
9) Run Test
(…Insomnia is used in this tutorial)
Enter the following OAuth 1.0 information:
- Consumer Key: see Step #4
- Consumer Key: see Step #4
- Token: see Step #5
- Token Secret: see Step #5
- Signature Method: HMAC-SHA256
- Version: 1.0
- Realm: see Step #8
Set type to POST and URL from Step #7. Set payload to {"example":"my data"} then click Send. You should get at 200 OK response:
data:image/s3,"s3://crabby-images/94c7b/94c7b1339324d71e29576aa140311b1f5ec6b65d" alt=""
10) Verify Test
In NetSuite, go to Customization > Scripting > Scripts
Set Type to RESTlet and click View for Restlet Example
data:image/s3,"s3://crabby-images/7c103/7c1034caff6bb4571969197c98701ccb660ea1ef" alt=""
In the Execution Log subtab you should see the JSON payload from Step #9
data:image/s3,"s3://crabby-images/c394b/c394bfc00d932c79f9f403c007490f48d8a3e386" alt=""
11) Edit Script
In another browser tab, go to Customization > Scripting > Scripts and click View for Restlet Example
data:image/s3,"s3://crabby-images/868cf/868cf65180ad0a2e214a889ccce4a4dc41c0f2ed" alt=""
In the Scripts subtab, click Edit
data:image/s3,"s3://crabby-images/12871/12871b4d16791aec7b7a8a5b33ff57894754e739" alt=""
Change Hello, World to Hello, World Again and then click Save
data:image/s3,"s3://crabby-images/492fd/492fdb633578f203c98c9f014dfc0c990f7c2ef3" alt=""
Re-run Step #9
In your other browser tab, click “Refresh” and confirm the new change:
data:image/s3,"s3://crabby-images/c8e12/c8e122f69dd2e87fe47fdb0bf123023a2fabf3fd" alt=""
References:
- https://www.techfino.com/hubfs/Techfino_March2018/Images/Token-Based-Authentication-Guide-for-NetSuite.pdf
- https://github.com/cafeasp/netsuite-suitescript20/blob/master/RestletExample.js
- https://netsuite-tutorial.blogspot.com/2016/08/create-standard-netsuite-record-using.html
- https://docs.oracle.com/cloud/latest/netsuitecs_gs/NSIRL/NSIRL.pdf
- Get link
- X
- Other Apps
Comments
Post a Comment
Keep it clean and professional...