UNPKG

@nocobase/plugin-workflow

Version:

A powerful BPM tool that provides foundational support for business automation, with the capability to extend unlimited triggers and nodes.

62 lines (60 loc) 2.16 kB
/** * This file is part of the NocoBase (R) project. * Copyright (c) 2020-2024 NocoBase Co., Ltd. * Authors: NocoBase Team. * * This project is dual-licensed under AGPL-3.0 and NocoBase Commercial License. * For more information, please refer to: https://www.nocobase.com/agreement. */ var __defProp = Object.defineProperty; var __getOwnPropDesc = Object.getOwnPropertyDescriptor; var __getOwnPropNames = Object.getOwnPropertyNames; var __hasOwnProp = Object.prototype.hasOwnProperty; var __export = (target, all) => { for (var name in all) __defProp(target, name, { get: all[name], enumerable: true }); }; var __copyProps = (to, from, except, desc) => { if (from && typeof from === "object" || typeof from === "function") { for (let key of __getOwnPropNames(from)) if (!__hasOwnProp.call(to, key) && key !== except) __defProp(to, key, { get: () => from[key], enumerable: !(desc = __getOwnPropDesc(from, key)) || desc.enumerable }); } return to; }; var __toCommonJS = (mod) => __copyProps(__defProp({}, "__esModule", { value: true }), mod); var add_missed_stats_exports = {}; __export(add_missed_stats_exports, { default: () => add_missed_stats_default }); module.exports = __toCommonJS(add_missed_stats_exports); var import_server = require("@nocobase/server"); class add_missed_stats_default extends import_server.Migration { appVersion = "<1.8.0"; on = "afterLoad"; async up() { const { db } = this.context; const WorkflowRepo = db.getRepository("workflows"); const ExecutionRepo = db.getRepository("executions"); await db.sequelize.transaction(async (transaction) => { const workflows = await WorkflowRepo.find({ filter: { current: true }, appends: ["stats"], transaction }); for (const workflow of workflows) { if (!workflow.stats) { const executed = await ExecutionRepo.count({ filter: { key: workflow.key }, transaction }) || workflow.allExecuted || 0; await workflow.createStats({ executed }, { transaction }); } } }); } }