@constructor-io/constructorio-node 5.1.2 → 5.2.0

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
package/package.json CHANGED
@@ -1,6 +1,6 @@
1
1
  {
2
2
  "name": "@constructor-io/constructorio-node",
3
- "version": "5.1.2",
3
+ "version": "5.2.0",
4
4
  "description": "Constructor.io Node.js client",
5
5
  "main": "src/constructorio.js",
6
6
  "types": "src/types/constructorio.d.ts",
@@ -139,6 +139,7 @@ function send(url, userParameters, networkParameters, method = 'GET', body = {})
139
139
 
140
140
  if (request) {
141
141
  const instance = this;
142
+ const emitError = helpers.getEmitError(instance, { url, method });
142
143
 
143
144
  request.then((response) => {
144
145
  // Request was successful, and returned a 2XX status code
@@ -152,26 +153,25 @@ function send(url, userParameters, networkParameters, method = 'GET', body = {})
152
153
 
153
154
  // Request was successful, but returned a non-2XX status code
154
155
  else {
155
- response.json().then((json) => {
156
- instance.eventemitter.emit('error', {
157
- url,
158
- method,
159
- message: json && json.message,
156
+ const contentType = response.headers.get('Content-Type') || '';
157
+
158
+ if (contentType.includes('application/json')) {
159
+ response.json().then((json) => {
160
+ emitError(json && json.message);
161
+ }).catch((error) => {
162
+ emitError(error.type);
160
163
  });
161
- }).catch((error) => {
162
- instance.eventemitter.emit('error', {
163
- url,
164
- method,
165
- message: error.type,
164
+ } else {
165
+ // If not JSON, fallback to text
166
+ response.text().then((text) => {
167
+ emitError(text || 'Unknown error message');
168
+ }).catch((error) => {
169
+ emitError(`Error reading text: ${error.message}`);
166
170
  });
167
- });
171
+ }
168
172
  }
169
173
  }).catch((error) => {
170
- instance.eventemitter.emit('error', {
171
- url,
172
- method,
173
- message: error.toString(),
174
- });
174
+ emitError(error.toString());
175
175
  });
176
176
  }
177
177
  }
@@ -134,6 +134,12 @@ const utils = {
134
134
 
135
135
  return url;
136
136
  },
137
+
138
+ getEmitError(instance, { url, method }) {
139
+ return function emitError(message) {
140
+ instance.eventemitter.emit('error', { url, method, message });
141
+ };
142
+ },
137
143
  };
138
144
 
139
145
  module.exports = utils;