const UserError = require('vn-loopback/util/user-error'); module.exports = Self => { Self.remoteMethod('addToOrder', { description: 'Creates rows (lines) for a order', accessType: 'WRITE', accepts: [{ arg: 'params', type: 'object', required: true, description: 'order id, [items]', http: {source: 'body'} }], returns: { type: 'object', root: true }, http: { path: `/addToOrder`, verb: 'POST' } }); Self.addToOrder = async params => { let isEditable = await Self.app.models.Order.isEditable(params.orderFk); if (!isEditable) throw new UserError('This order is not editable'); let promises = []; params.items.forEach(item => { promises.push( Self.rawSql( `CALL hedera.order_addItem(?, ?, ?, ?)`, [params.orderFk, item.warehouseFk, item.itemFk, item.quantity] ) ); }); await Promise.all(promises); return true; }; };