node-red-contrib-appwrite
Version:
Node-RED connector for appwrite
49 lines (40 loc) • 1.85 kB
JavaScript
const utils = require('../utils');
const errors = require('../autana-error');
const common = require('./common-columns');
let requiredProperties = ['databaseName', 'tableName', 'key'];
function createNode(RED, node, n) {
console.log('creating IntegerColumn node...')
try {
RED.nodes.createNode(node, n);
let staticConfig = n;
node.on("input", function(msg) {
let database = utils.getDatabase(RED, n, msg);
console.log('IntegerColumn.onMessage()');
try {
let messageConfig = msg;
let defaultProperties = {
databaseName: utils.getPreviousDatabaseName(msg),
tableName: utils.getPreviousTableName(msg),
required: false,
isArray: false,
min: null,
max: null,
defaultValue: null
};
let config = utils.mergeConfigs(staticConfig, messageConfig, defaultProperties, requiredProperties);
utils.notifyExecuting(node);
let promise = database.createIntegerAttribute(config.databaseName, config.tableName, config.key,
config.required, config.min, config.max, config.defaultValue, config.isArray);
promise.then(
function (response) { common.onAddColumnComplete(RED, node, msg, config, response); },
function (err) { common.onAddColumnError(RED, node, msg, config, err); }
);
} catch (err) {
common.handleError('error at IntegerColumn.onMessage()', node, err);
}
});
} catch (error) {
common.handleError('error creating IntegerColumn node', node, error);
}
}
module.exports = { createNode };