1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859606162636465666768697071727374757677787980 |
- const {getUnixTimeStamp} = require('../until/time')
- const db_user = require('../database/d_user')
- const handle = require("../until/handle");
- const {payState_cancel} = require("../maps/field");
- let orders = [];
- let payLock = false;
- let expire = 60 * 15;
- let timerHandle = null;
- function tick (t,fn){
- setTimeout(async ()=>{
- await fn();
- tick(t,fn);
- },t)
- }
- async function check(){
- if(payLock){
- return;
- }
- let nowUnix = getUnixTimeStamp();
- for (let i = 0; i < orders.length; i++) {
- let order = orders[i];
- if(!order){
- break;
- }
- if(nowUnix>order.endTime){
- let [err,result] = await handle(db_user.changeOrder(order.id,{payState:payState_cancel}));
- if(err){console.log(err)}
- console.log(`订单${order.id},超时过期`);
- }
- }
- }
- async function main(){
- let [err,result] = await handle(db_user.waitPayOrder());
- if(err){
- console.log('获取用户数据失败')
- console.error(err);
- }
- orders = result.map(order=>{
- return {
- id: order.id,
- endTime: parseInt(order.createTime) + expire
- }
- });
- tick(1000,check);
- }
- main();
- console.log('检测订单');
- async function payOrder(orderId){
- payLock=true;
- let [err,result] = await handle(db_user.payOrder(orderId));
- if(err){payLock=false;console.log(err);throw err}
- let ind = orders.findIndex(val=>val.id==orderId);
- if(ind!=-1){orders[ind] = null}
- orders = orders.filter(val=>val);
- payLock=false;
- }
- async function addOrder(orderId,createTime){
- orders.push({
- id: orderId,
- endTime: parseInt(createTime) + expire
- })
- }
- module.exports = {
- payOrder,
- addOrder,
- }
|