let UserError = require('vn-loopback/util/user-error'); module.exports = Self => { Self.remoteMethodCtx('confirm', { description: '', accessType: 'WRITE', accepts: [{ arg: 'id', type: 'Integer', required: true, description: 'The request ID', }, { arg: 'itemFk', type: 'Integer', required: true, description: 'The request observation', }, { arg: 'quantity', type: 'Integer', required: true, description: 'The request observation', }], returns: { type: 'Object', root: true }, http: { path: `/:id/confirm`, verb: 'post' } }); Self.confirm = async ctx => { const models = Self.app.models; let tx = await Self.beginTransaction({}); try { let options = {transaction: tx}; let item = await models.Item.findById(ctx.args.itemFk); if (!item) throw new UserError(`That item doesn't exists`); let request = await models.TicketRequest.findById(ctx.args.id, { include: {relation: 'ticket'} }); let [[stock]] = await Self.rawSql(`CALL vn.getItemVisibleAvailable(?,?,?,?)`, [ ctx.args.itemFk, request.ticket().shipped, request.ticket().warehouseFk, false ]); if (stock.available < quantity) throw new UserError(`This item is not available`); if (request.saleFk) { let sale = await models.Sale.findById(request.saleFk); sale.updateAttributes({ itemFk: ctx.args.itemFk, quantity: ctx.args.quantity, description: item.description }, options); } else { params = { ticketFk: request.ticketFk, itemFk: ctx.args.itemFk, quantity: ctx.args.quantity }; sale = await models.Sale.create(params, options); request.updateAttributes({saleFk: sale.id, itemFk: sale.itemFk}, options); } query = `CALL vn.ticketCalculateSale(?)`; params = [sale.id]; await Self.rawSql(query, params, options); const message = `Se ha comprado ${params.quantity} unidades de "${item.description}" (#${params.itemFk}) ` + `para el ticket #${params.ticketFk}`; await models.Message.send(ctx, { recipientFk: request.requesterFk, message: message }, options); await tx.commit(); } catch (error) { await tx.rollback(); throw error; } }; };