-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathupdate.js
79 lines (69 loc) · 2.95 KB
/
update.js
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
const v = require(`../../values`);
const dev = require('../dev');
const generalFuncs = require('../general');
const airtableDev = require('../dev/airtable');
/** Updates records passed inside airtable
* @async
* @param {string} tableName - The table name
* @param {Array} recordsArray - An array of maximum 10 JSON elements that is following that specific airtable base fields naming conventions, if column not needed then simply do not include it in the JSON object of that record, each element should have id and fields values
* @param {string} apiKey - The api key // (Optional - configurable through the config.airtable object) //
* @param {string} baseURL - The base url // (Optional - Default is 'https://api.airtable.com/v0/' - configurable through the config.airtable object) //
* @param {string} baseId - The base id // (Optional - configurable through the config.airtable object) //
* @returns - Return a response following this module's format (Created using func.constructResponse functionality)
** The body will have an array with the records updated
** In case of error (error of execution e.g. no url provided, not url hit error response), it will throw an exception with an object following the same format, for the url hit error responses, they will be returned as success but full body will be in the body value
*/
module.exports.records = async (
tableName,
recordsArray,
apiKey = v.airtable.apiKey,
baseURL = v.airtable.baseURL,
baseId = v.airtable.baseId
) => {
dev.throwErrorIfValueNotPassedAndNotSet(apiKey, 'airtable', 'apiKey');
dev.throwErrorIfValueNotPassedAndNotSet(baseURL, 'airtable', 'baseURL');
dev.throwErrorIfValueNotPassedAndNotSet(baseId, 'airtable', 'baseId');
dev.throwErrorIfValueNotPassed(tableName, 'tableName');
if (await generalFuncs.isEmptyArray(recordsArray)) {
return generalFuncs.constructResponse(
true,
200,
`recordsArray is empty`,
[]
);
}
dev.throwErrorIfValueNotPassed(recordsArray, 'recordsArray');
try {
let statusCode;
let recordsUpdatedArray = [];
// let toUpdateRecordsArray = [];
// for (i in recordsArray) {
// toUpdateRecordsArray.push(recordsArray[i]);
// }
await generalFuncs.performActionForSubArrays(
async (chunk, {tableName, apiKey, baseURL, baseId}) => {
const singleResponse = await airtableDev.updateMax10Records(
tableName,
chunk,
apiKey,
baseURL,
baseId
);
statusCode = singleResponse.code;
recordsUpdatedArray = [...recordsUpdatedArray, ...singleResponse.body];
},
recordsArray,
10,
{tableName, apiKey, baseURL, baseId},
v.airtable.waitBetweenRequestsInMilliSeconds
);
return generalFuncs.constructResponse(
true,
statusCode,
`Successfully updated ${recordsUpdatedArray.length} records in table ${tableName}`,
recordsUpdatedArray
);
} catch (err) {
throw dev.formatError(err);
}
};