2024-01-16 14:43:34 +00:00
|
|
|
const UserError = require('vn-loopback/util/user-error');
|
2023-11-23 12:19:59 +00:00
|
|
|
module.exports = Self => {
|
|
|
|
Self.remoteMethodCtx('updateInTime', {
|
2023-11-29 15:25:15 +00:00
|
|
|
description: 'Updates the corresponding registry if the worker has been registered in the last few hours',
|
2023-11-23 12:19:59 +00:00
|
|
|
accessType: 'WRITE',
|
|
|
|
accepts: [
|
|
|
|
{
|
|
|
|
arg: 'plate',
|
|
|
|
type: 'string',
|
|
|
|
}
|
|
|
|
],
|
|
|
|
http: {
|
|
|
|
path: `/updateInTime`,
|
|
|
|
verb: 'POST'
|
|
|
|
}
|
|
|
|
});
|
|
|
|
|
|
|
|
Self.updateInTime = async(ctx, plate, options) => {
|
|
|
|
const models = Self.app.models;
|
|
|
|
const userId = ctx.req.accessToken.userId;
|
2024-01-19 08:52:49 +00:00
|
|
|
const $t = ctx.req.__;
|
2023-11-23 12:19:59 +00:00
|
|
|
|
|
|
|
let tx;
|
|
|
|
const myOptions = {};
|
|
|
|
|
|
|
|
if (typeof options == 'object')
|
|
|
|
Object.assign(myOptions, options);
|
|
|
|
|
|
|
|
if (!myOptions.transaction) {
|
|
|
|
tx = await Self.beginTransaction({});
|
|
|
|
myOptions.transaction = tx;
|
|
|
|
}
|
|
|
|
|
|
|
|
try {
|
|
|
|
const machine = await models.Machine.findOne({
|
|
|
|
fields: ['id', 'plate'],
|
|
|
|
where: {plate}
|
|
|
|
}, myOptions);
|
2024-01-19 08:52:49 +00:00
|
|
|
|
|
|
|
if (!machine)
|
|
|
|
throw new Error($t('the plate does not exist', {plate}));
|
2023-11-23 12:19:59 +00:00
|
|
|
|
2024-01-16 14:43:34 +00:00
|
|
|
const machineWorker = await Self.findOne({
|
2023-11-23 12:19:59 +00:00
|
|
|
where: {
|
2024-01-19 08:52:49 +00:00
|
|
|
or: [{machineFk: machine.id}, {workerFk: userId}],
|
2024-01-16 14:43:34 +00:00
|
|
|
outTime: null,
|
2023-11-23 12:19:59 +00:00
|
|
|
}
|
2024-01-16 14:43:34 +00:00
|
|
|
}, myOptions);
|
2023-11-23 12:19:59 +00:00
|
|
|
|
|
|
|
if (machineWorker) {
|
2024-01-17 07:17:55 +00:00
|
|
|
const {maxHours} = await models.MachineWorkerConfig.findOne({fields: ['maxHours']}, myOptions);
|
|
|
|
const hoursDifference = (Date.vnNow() - machineWorker.inTime.getTime()) / (60 * 60 * 1000);
|
2024-02-19 13:46:42 +00:00
|
|
|
const isHimself = userId == machineWorker.workerFk;
|
2024-01-19 11:38:58 +00:00
|
|
|
const isSameMachine = machine.id == machineWorker.machineFk;
|
2024-01-16 14:43:34 +00:00
|
|
|
|
2024-02-19 13:46:42 +00:00
|
|
|
if (hoursDifference < maxHours && !isHimself)
|
2024-01-19 08:52:49 +00:00
|
|
|
throw new UserError($t('This machine is already in use.'));
|
2024-01-16 14:43:34 +00:00
|
|
|
|
2024-02-19 13:46:42 +00:00
|
|
|
if (hoursDifference < maxHours && isHimself && !isSameMachine)
|
2024-01-19 11:38:58 +00:00
|
|
|
throw new UserError($t('You are already using a machine'));
|
|
|
|
|
2023-11-23 12:19:59 +00:00
|
|
|
await machineWorker.updateAttributes({
|
2024-01-16 14:43:34 +00:00
|
|
|
outTime: Date.vnNew()
|
2023-11-23 12:19:59 +00:00
|
|
|
}, myOptions);
|
2024-01-16 14:43:34 +00:00
|
|
|
|
2024-01-19 11:38:58 +00:00
|
|
|
if (hoursDifference >= maxHours)
|
2024-01-17 08:01:48 +00:00
|
|
|
await models.MachineWorker.create({machineFk: machine.id, workerFk: userId}, myOptions);
|
2024-01-16 14:43:34 +00:00
|
|
|
} else
|
|
|
|
await models.MachineWorker.create({machineFk: machine.id, workerFk: userId}, myOptions);
|
2023-11-23 12:19:59 +00:00
|
|
|
|
|
|
|
if (tx) await tx.commit();
|
|
|
|
} catch (e) {
|
|
|
|
if (tx) await tx.rollback();
|
|
|
|
throw e;
|
|
|
|
}
|
|
|
|
};
|
|
|
|
};
|