This commit is contained in:
邹宗楠
2023-05-30 09:17:38 +08:00
parent f9913ead46
commit 9e2b93b6cd

View File

@@ -276,191 +276,191 @@ func (t *TcpClient) doPrint(key string) (err error) {
return err return err
} }
fn := func() { //fn := func() {
if t.TimeoutMap[key] == true { // if t.TimeoutMap[key] == true {
select { // select {
case printMsg, ok := <-t.MsgMap[key]: // case printMsg, ok := <-t.MsgMap[key]:
if !ok { // if !ok {
globals.SugarLogger.Debugf("doPrint err !ok ...") // globals.SugarLogger.Debugf("doPrint err !ok ...")
return // return
} // }
var ( // var (
data []byte // data []byte
c net.Conn // c net.Conn
) // )
if printMsg != nil { // if printMsg != nil {
if err = checkPrintMsg(db, printMsg); err == nil { // if err = checkPrintMsg(db, printMsg); err == nil {
status := t.getPrintStatus(printMsg.PrintNo) // status := t.getPrintStatus(printMsg.PrintNo)
switch status { // switch status {
//只有在线才打印内容 // //只有在线才打印内容
case printerStatusOnline: // case printerStatusOnline:
if c = t.getPrintConn(printMsg.PrintNo); c != nil { // if c = t.getPrintConn(printMsg.PrintNo); c != nil {
data, err = buildMsg(printMsg) // data, err = buildMsg(printMsg)
}
case printerStatusOffline:
err = fmt.Errorf("打印机离线!")
case printerStatusOnlineWithoutPaper:
err = fmt.Errorf("打印机缺纸!")
default:
err = fmt.Errorf("打印机状态未知!")
}
}
if err != nil {
printMsg.Status = printMsgErr
printMsg.Comment = err.Error()
dao.UpdateEntity(db, printMsg, "Status", "Comment")
delete(t.TimeoutMap, key)
} else {
if c != nil {
if _, err = c.Write(data); err != nil {
globals.SugarLogger.Debugf("handleTcpMessages err [%v]", err)
//close(t.TimeoutMap[key])
delete(t.TimeoutMap, key)
} else {
//等待回调
dataStr := <-t.CallBackMap[key]
if dataStr != "" {
a, b := getCallbackMsgInfo(dataStr)
t.changePrintMsg(dataStr, a, b)
// 查询打印机是否扣费,未扣费就扣费,已经扣费不做处理
have, err := dao.QueryOrderDeductionRecord(db, b, utils.Int64ToStr(a))
if err != nil && !have {
// 扣除打印机账号金额
if err = dao.DeductionPrintBalance(db, b); err != nil {
globals.SugarLogger.Debugf("扣除用户打印机金额错误 %s", err)
} else {
// 添加打印记录(支出记录)
if err = dao.AddPrintRecord(db, &model.PrintBillRecord{
CreatedAt: time.Now(),
UpdatedAt: time.Now(),
PrintNo: b,
PayType: 2,
PayMoney: 1, // 固定支出一分钱
OrderId: utils.Int64ToStr(a),
UserId: "",
}); err != nil {
globals.SugarLogger.Debugf("添加打印机订单支付记录错误 %s", err)
}
}
} else {
globals.SugarLogger.Debugf("查询打印机扣费记录错误 %s", err)
}
//判断音频暂停?
//收到打印成功回调后,如果消息中有音频,需要等待一下,等上一个音频播完
//暂停时间就暂时取的sound标签内内容长度/2
if sounds := regexpSoundSpan.FindStringSubmatch(printMsg.Content); len(sounds) > 0 {
sound := sounds[1]
lenTime := time.Duration(utf8.RuneCountInString(sound)) * time.Second
time.Sleep(lenTime / 2)
}
}
}
}
}
} else {
globals.SugarLogger.Debugf("msgMap is nil")
}
}
} else {
globals.SugarLogger.Debugf("doPrint timeout")
return
}
}
Poll.AddJob(fn)
//go func() {
// for {
// if t.TimeoutMap[key] == true {
// select {
// case printMsg, ok := <-t.MsgMap[key]:
// if !ok {
// globals.SugarLogger.Debugf("doPrint err !ok ...")
// return
// }
// var (
// data []byte
// c net.Conn
// )
// if printMsg != nil {
// if err = checkPrintMsg(db, printMsg); err == nil {
// status := t.getPrintStatus(printMsg.PrintNo)
// switch status {
// //只有在线才打印内容
// case printerStatusOnline:
// if c = t.getPrintConn(printMsg.PrintNo); c != nil {
// data, err = buildMsg(printMsg)
// }
// case printerStatusOffline:
// err = fmt.Errorf("打印机离线!")
// case printerStatusOnlineWithoutPaper:
// err = fmt.Errorf("打印机缺纸!")
// default:
// err = fmt.Errorf("打印机状态未知!")
// } // }
// case printerStatusOffline:
// err = fmt.Errorf("打印机离线!")
// case printerStatusOnlineWithoutPaper:
// err = fmt.Errorf("打印机缺纸!")
// default:
// err = fmt.Errorf("打印机状态未知!")
// } // }
// if err != nil { // }
// printMsg.Status = printMsgErr // if err != nil {
// printMsg.Comment = err.Error() // printMsg.Status = printMsgErr
// dao.UpdateEntity(db, printMsg, "Status", "Comment") // printMsg.Comment = err.Error()
// delete(t.TimeoutMap, key) // dao.UpdateEntity(db, printMsg, "Status", "Comment")
// } else { // delete(t.TimeoutMap, key)
// if c != nil { // } else {
// if _, err = c.Write(data); err != nil { // if c != nil {
// globals.SugarLogger.Debugf("handleTcpMessages err [%v]", err) // if _, err = c.Write(data); err != nil {
// //close(t.TimeoutMap[key]) // globals.SugarLogger.Debugf("handleTcpMessages err [%v]", err)
// delete(t.TimeoutMap, key) // //close(t.TimeoutMap[key])
// } else { // delete(t.TimeoutMap, key)
// //等待回调 // } else {
// dataStr := <-t.CallBackMap[key] // //等待回调
// if dataStr != "" { // dataStr := <-t.CallBackMap[key]
// a, b := getCallbackMsgInfo(dataStr) // if dataStr != "" {
// t.changePrintMsg(dataStr, a, b) // a, b := getCallbackMsgInfo(dataStr)
// // 查询打印机是否扣费,未扣费就扣费,已经扣费不做处理 // t.changePrintMsg(dataStr, a, b)
// have, err := dao.QueryOrderDeductionRecord(db, b, utils.Int64ToStr(a)) // // 查询打印机是否扣费,未扣费就扣费,已经扣费不做处理
// if err != nil && !have { // have, err := dao.QueryOrderDeductionRecord(db, b, utils.Int64ToStr(a))
// // 扣除打印机账号金额 // if err != nil && !have {
// if err = dao.DeductionPrintBalance(db, b); err != nil { // // 扣除打印机账号金额
// globals.SugarLogger.Debugf("扣除用户打印机金额错误 %s", err) // if err = dao.DeductionPrintBalance(db, b); err != nil {
// } else { // globals.SugarLogger.Debugf("扣除用户打印机金额错误 %s", err)
// // 添加打印记录(支出记录)
// if err = dao.AddPrintRecord(db, &model.PrintBillRecord{
// CreatedAt: time.Now(),
// UpdatedAt: time.Now(),
// PrintNo: b,
// PayType: 2,
// PayMoney: 1, // 固定支出一分钱
// OrderId: utils.Int64ToStr(a),
// UserId: "",
// }); err != nil {
// globals.SugarLogger.Debugf("添加打印机订单支付记录错误 %s", err)
// }
// }
// } else { // } else {
// globals.SugarLogger.Debugf("查询打印机扣费记录错误 %s", err) // // 添加打印记录(支出记录)
// } // if err = dao.AddPrintRecord(db, &model.PrintBillRecord{
// //判断音频暂停? // CreatedAt: time.Now(),
// //收到打印成功回调后,如果消息中有音频,需要等待一下,等上一个音频播完 // UpdatedAt: time.Now(),
// //暂停时间就暂时取的sound标签内内容长度/2 // PrintNo: b,
// if sounds := regexpSoundSpan.FindStringSubmatch(printMsg.Content); len(sounds) > 0 { // PayType: 2,
// sound := sounds[1] // PayMoney: 1, // 固定支出一分钱
// lenTime := time.Duration(utf8.RuneCountInString(sound)) * time.Second // OrderId: utils.Int64ToStr(a),
// time.Sleep(lenTime / 2) // UserId: "",
// }); err != nil {
// globals.SugarLogger.Debugf("添加打印机订单支付记录错误 %s", err)
// }
// } // }
// } else {
// globals.SugarLogger.Debugf("查询打印机扣费记录错误 %s", err)
// }
// //判断音频暂停?
// //收到打印成功回调后,如果消息中有音频,需要等待一下,等上一个音频播完
// //暂停时间就暂时取的sound标签内内容长度/2
// if sounds := regexpSoundSpan.FindStringSubmatch(printMsg.Content); len(sounds) > 0 {
// sound := sounds[1]
// lenTime := time.Duration(utf8.RuneCountInString(sound)) * time.Second
// time.Sleep(lenTime / 2)
// } // }
// } // }
// } // }
// } // }
// } else {
// globals.SugarLogger.Debugf("msgMap is nil")
// } // }
// } else {
// globals.SugarLogger.Debugf("msgMap is nil")
// } // }
// } else {
// globals.SugarLogger.Debugf("doPrint timeout")
// return
// } // }
// // } else {
// globals.SugarLogger.Debugf("doPrint timeout")
// return
// } // }
//}() //}
//
//Poll.AddJob(fn)
go func() {
for {
if t.TimeoutMap[key] == true {
select {
case printMsg, ok := <-t.MsgMap[key]:
if !ok {
globals.SugarLogger.Debugf("doPrint err !ok ...")
return
}
var (
data []byte
c net.Conn
)
if printMsg != nil {
if err = checkPrintMsg(db, printMsg); err == nil {
status := t.getPrintStatus(printMsg.PrintNo)
switch status {
//只有在线才打印内容
case printerStatusOnline:
if c = t.getPrintConn(printMsg.PrintNo); c != nil {
data, err = buildMsg(printMsg)
}
case printerStatusOffline:
err = fmt.Errorf("打印机离线!")
case printerStatusOnlineWithoutPaper:
err = fmt.Errorf("打印机缺纸!")
default:
err = fmt.Errorf("打印机状态未知!")
}
}
if err != nil {
printMsg.Status = printMsgErr
printMsg.Comment = err.Error()
dao.UpdateEntity(db, printMsg, "Status", "Comment")
delete(t.TimeoutMap, key)
} else {
if c != nil {
if _, err = c.Write(data); err != nil {
globals.SugarLogger.Debugf("handleTcpMessages err [%v]", err)
//close(t.TimeoutMap[key])
delete(t.TimeoutMap, key)
} else {
//等待回调
dataStr := <-t.CallBackMap[key]
if dataStr != "" {
a, b := getCallbackMsgInfo(dataStr)
t.changePrintMsg(dataStr, a, b)
// 查询打印机是否扣费,未扣费就扣费,已经扣费不做处理
have, err := dao.QueryOrderDeductionRecord(db, b, utils.Int64ToStr(a))
if err != nil && !have {
// 扣除打印机账号金额
if err = dao.DeductionPrintBalance(db, b); err != nil {
globals.SugarLogger.Debugf("扣除用户打印机金额错误 %s", err)
} else {
// 添加打印记录(支出记录)
if err = dao.AddPrintRecord(db, &model.PrintBillRecord{
CreatedAt: time.Now(),
UpdatedAt: time.Now(),
PrintNo: b,
PayType: 2,
PayMoney: 1, // 固定支出一分钱
OrderId: utils.Int64ToStr(a),
UserId: "",
}); err != nil {
globals.SugarLogger.Debugf("添加打印机订单支付记录错误 %s", err)
}
}
} else {
globals.SugarLogger.Debugf("查询打印机扣费记录错误 %s", err)
}
//判断音频暂停?
//收到打印成功回调后,如果消息中有音频,需要等待一下,等上一个音频播完
//暂停时间就暂时取的sound标签内内容长度/2
if sounds := regexpSoundSpan.FindStringSubmatch(printMsg.Content); len(sounds) > 0 {
sound := sounds[1]
lenTime := time.Duration(utf8.RuneCountInString(sound)) * time.Second
time.Sleep(lenTime / 2)
}
}
}
}
}
} else {
globals.SugarLogger.Debugf("msgMap is nil")
}
}
} else {
globals.SugarLogger.Debugf("doPrint timeout")
return
}
}
}()
return err return err
} }