salix/back/methods/docuware/upload.js

152 lines
5.4 KiB
JavaScript
Raw Normal View History

2023-01-09 14:11:53 +00:00
const UserError = require('vn-loopback/util/user-error');
const axios = require('axios');
2023-01-09 14:11:53 +00:00
module.exports = Self => {
Self.remoteMethodCtx('upload', {
2023-06-13 10:42:12 +00:00
description: 'Upload docuware PDFs',
2023-01-09 14:11:53 +00:00
accessType: 'WRITE',
accepts: [
{
arg: 'ticketIds',
type: ['number'],
description: 'The ticket ids',
required: true
2023-01-09 14:11:53 +00:00
},
{
arg: 'fileCabinet',
type: 'string',
description: 'The file cabinet',
required: true
2023-01-09 14:11:53 +00:00
}
],
2023-06-13 09:37:35 +00:00
returns: {
type: 'object',
root: true
},
2023-01-09 14:11:53 +00:00
http: {
path: `/upload`,
2023-01-09 14:11:53 +00:00
verb: 'POST'
}
});
Self.upload = async function(ctx, ticketIds, fileCabinet) {
delete ctx.args.ticketIds;
2023-01-09 14:11:53 +00:00
const models = Self.app.models;
const action = 'store';
2023-01-09 14:11:53 +00:00
const options = await Self.getOptions();
const fileCabinetId = await Self.getFileCabinet(fileCabinet);
const dialogId = await Self.getDialog(fileCabinet, action, fileCabinetId);
2023-01-09 14:11:53 +00:00
const uploaded = [];
for (id of ticketIds) {
// get delivery note
ctx.args.id = id;
const deliveryNote = await models.Ticket.deliveryNotePdf(ctx, {
id,
type: 'deliveryNote'
});
// get ticket data
const ticket = await models.Ticket.findById(id, {
include: [{
relation: 'client',
scope: {
fields: ['id', 'name', 'fi']
}
}]
});
2023-01-09 14:11:53 +00:00
// upload file
const templateJson = {
'Fields': [
{
'FieldName': 'N__ALBAR_N',
'ItemElementName': 'string',
'Item': id,
},
{
'FieldName': 'CIF_PROVEEDOR',
'ItemElementName': 'string',
'Item': ticket.client().fi,
},
{
'FieldName': 'CODIGO_PROVEEDOR',
'ItemElementName': 'string',
'Item': ticket.client().id,
},
{
'FieldName': 'NOMBRE_PROVEEDOR',
'ItemElementName': 'string',
'Item': ticket.client().name + ' - ' + id,
},
{
'FieldName': 'FECHA_FACTURA',
'ItemElementName': 'date',
'Item': ticket.shipped,
},
{
'FieldName': 'TOTAL_FACTURA',
'ItemElementName': 'Decimal',
'Item': ticket.totalWithVat,
},
{
'FieldName': 'ESTADO',
'ItemElementName': 'string',
'Item': 'Pendiente procesar',
},
{
'FieldName': 'FIRMA_',
'ItemElementName': 'string',
'Item': 'Si',
},
{
'FieldName': 'FILTRO_TABLET',
'ItemElementName': 'string',
'Item': 'Tablet1',
}
]
};
2023-01-09 14:11:53 +00:00
2023-06-13 09:37:35 +00:00
if (process.env.NODE_ENV != 'production')
throw new UserError('Action not allowed on the test environment');
2023-01-12 14:16:38 +00:00
// delete old
const docuwareFile = await models.Docuware.checkFile(id, fileCabinet, false);
if (docuwareFile) {
const deleteJson = {
'Field': [{'FieldName': 'ESTADO', 'Item': 'Pendiente eliminar', 'ItemElementName': 'String'}]
};
const deleteUri = `${options.url}/FileCabinets/${fileCabinetId}/Documents/${docuwareFile.id}/Fields`;
await axios.put(deleteUri, deleteJson, options.headers);
}
2023-01-12 14:16:38 +00:00
const uploadUri = `${options.url}/FileCabinets/${fileCabinetId}/Documents?StoreDialogId=${dialogId}`;
const FormData = require('form-data');
const data = new FormData();
data.append('document', JSON.stringify(templateJson), 'schema.json');
data.append('file[]', deliveryNote[0], 'file.pdf');
const uploadOptions = {
headers: {
'Content-Type': 'multipart/form-data',
'X-File-ModifiedDate': Date.vnNew(),
'Cookie': options.headers.headers.Cookie,
...data.getHeaders()
},
};
try {
await axios.post(uploadUri, data, uploadOptions);
} catch (err) {
const $t = ctx.req.__;
2023-06-14 05:30:50 +00:00
const message = $t('Failed to upload delivery note', {id});
if (uploaded.length)
await models.TicketTracking.setDelivered(ctx, uploaded);
throw new UserError(message);
}
uploaded.push(id);
}
return models.TicketTracking.setDelivered(ctx, ticketIds);
2023-01-09 14:11:53 +00:00
};
};