Errors
The REST API uses conventional HTTP response codes to indicate the success or failure of a request. The codes can be in one of the following ranges:
- 
            2xxif the request is successful.
- 
            4xxif the request fails due to the information provided in the request — it indicates an error in the request.
- 
            5xxif the request fails due to a problem with the SuiteProjects Pro server.
Your client application needs to handle errors when the request fails. The following table lists common response codes and possible reasons for failing requests. The JSON-encoded response should always include the message property, a string containing a brief message about the status of your request.
| HTTP Status Code | Description | Reasons | 
|---|---|---|
| 
                     | The request was successful. | 
 | 
| 
                     | Part of the request was successful, part of the request failed. | Possible reasons include: 
 | 
| 
                     | The request is unacceptable. | Possible reasons include: 
 | 
| 
                     | Authentication error. The response includes a WWW-Authenticate header with information about the error. | The access token is invalid. See Authentication Errors. | 
| 
                     | Permission to perform the request is denied. | The access token does not allow the client application to perform the operation requested on the resource specified in the request. In most cases, this is due to business rules configured for the SuiteProjects Pro account, which may include: 
 | 
| 
                     | The requested resource does not exist. | Possible reasons include: 
 | 
| 
                     | The method is not allowed. | Possible reasons include: 
 | 
| 
                     | API limit reached. | One of the API limits set for the account was reached. See API Limits. | 
| 
                     | A problem occurred on SuiteProjects Pro’s end. | If system errors persist, please check SuiteProjects Pro system status, or contact SuiteProjects Pro Support. | 
| 
                     | The service is temporarily unavailable. | If the problem persists, please check SuiteProjects Pro system status, or contact SuiteProjects Pro Support. | 
The REST API returns HTTP status 500 Internal Server Error if you attempt to access a BI Connector resource endpoint with a valid access token and the BI Connector feature is disabled.
Parameter errors
Requests return a 400 Bad Request HTTP response code if there is a problem with one of the query parameters in the request URL. The response JSON object includes the message property only, with an error description.
Examples of parameter error messages:
- 
              limitparameter above the maximum allowed —The specified query parameter 'limit' is out of bounds. Provide value between 1 and 1000
- 
              The page offsetis not divisible by the pagelimit—Invalid limit and offset values. The offset must be divisible by the page limit
- 
              Problem with the query expression q—Filter error: Expected a valid field name, but found 'created AFTER '2020-' instead
Validation Errors
PUT or POST requests return a 400 Bad Request HTTP response code if there is a problem with any key-value pair in the JSON-encoded request body. The response JSON object includes the following properties:
- 
              message— Themessagestring shows“Invalid data”.
- 
              errorFields— An object containing the fields with errors as attributes, and for each field an array of objects containing the attributes:- 
                  type— The type of validation error returned.
- 
                  message— The error message.
 
- 
                  
The following example shows the response returned if the request attempts to set or update read-only fields.
            HTTP/ 1.1 400 Bad Request
Content-Type: application/json
 
{
  "errorFields": {
    "created": [{
      "type": "read-only-value",
      "message": "Read-only value"
    }],
    "updated": [{
      "type": "read-only-value",
      "message": "Read-only value"
    }]
  },
  "message": "Invalid data"
} 
          
          The following table lists the validation error types
| Error Type | Description | 
|---|---|
| custom-error | A  | 
| invalid-value | The value is not formatted correctly. For example, if the field data type and format is  | 
| netsuite-integration-error | A  | 
| permission-error | A  | 
| required-field | The field is required. The object in the request body must contain a value for this field. For more information about required fields, see REST API Endpoint Reference or Generated API Documentation JSON. | 
| read-only-value | The field is read-only. The field cannot be set or updated using the REST API. Hidden fields are read-only. The REST API returns an error if an attribute-value pair for a hidden field is included in a POST or PUT request body. For more information about read-only fields, see REST API Endpoint Reference or Generated API Documentation JSON. | 
| unknown-field | The attribute is not a valid attribute for the object to be created or updated. For more information about valid object attributes, see REST API Endpoint Reference or Generated API Documentation JSON. 
                      Note: 
                       Attribute names are case sensitive and use camelCase, a naming convention in which each word within a compound word is capitalized except for the first word. For example, note the initial lowercase  | 
| unknown-type | Unknown error type. | 
An evaluation order is used for the different validation rules. If an error of a given type is encountered, validation stops and a response returned with that given error type. For example, if the object in the request body includes an invalid attribute name, and an attribute-value pair for a read-only field, the unknown-field validation rule is evaluated first, and an error response is returned before the read-only-value validation rule is evaluated.