Transaction Logs as attachments in NetSuite Custom transactions

We’ve added functionality in NetSuite to store transaction logs received from the Portal via an API POST request using a RESTlet script. Two folders have been created in the file cabinet ‘Pending Donation’ and ‘Outgoing Fund’ to store the files. The files are saved in the format ‘<record type>_<internal id>. <file type>’ (e.g., pend_donation_102.png). We tested this with sample base64 data, and it’s correctly storing files in the respective folders. The functionality works fine with PNG, JPEG, and PDF formats. 

 

An API that will take the following values as API parameters:  

  • Record type: Pending Donation or Outgoing Fund.  
  • Internal ID of the record (Pending Donation or Outgoing Fund).  
  • The snapshot(image/PDF) of the completed transaction in base64 text format.  
  • File type: The mime type of the snapshot file (“image/png”, “image/jpeg”, or “application/pdf”) The base64 text will be converted to an image/PDF and will be stored in the NetSuite file cabinet. This file will be attached to the record specified in the request (Pending Donation or Outgoing Fund). 

Notes: 

  • The NetSuite API has a file size limit of 10 MB. The ‘base64’ encoding of a file can be approximately 33% larger than the original file size. If the file is larger than 7.5 MB, the ‘base64’ text might exceed 10 MB limit. If the request exceeds the limit, the request will return an error.  
  • NetSuite has a concurrency limit based on the Suite Cloud processors.  
  • If an API request fails, it should be handled by the portal by resending the failed requests again.  
  • If the data is not correctly passed in the specified format, the API will return an error. 

Testing steps 

In Postman, add the record type, internal ID, and File Content fields to the body. Then, send the request and verify that you receive the file ID in the response. After that, check the respective folders. The created file will be stored in the appropriate folder corresponding to the record type. Below, I’ve provided sample data for you to test with 

    “recordType”: “”

    “internalId”: “”

    “fileContent”:”base64” “”

 

Leave a comment

Your email address will not be published. Required fields are marked *