248 lines
8.1 KiB
Go
248 lines
8.1 KiB
Go
|
package service
|
|||
|
|
|||
|
import (
|
|||
|
"context"
|
|||
|
"time"
|
|||
|
|
|||
|
"go-common/app/admin/ep/merlin/model"
|
|||
|
"go-common/library/ecode"
|
|||
|
)
|
|||
|
|
|||
|
// DelayMachineEndTime Delay Machine End Time.
|
|||
|
func (s *Service) DelayMachineEndTime(c context.Context, machineID int64, username string) (status int, err error) {
|
|||
|
var (
|
|||
|
machine *model.Machine
|
|||
|
machineLog = &model.MachineLog{}
|
|||
|
)
|
|||
|
status = -1
|
|||
|
//查询机器延期状态
|
|||
|
if machine, err = s.dao.QueryMachine(machineID); err != nil {
|
|||
|
return
|
|||
|
}
|
|||
|
|
|||
|
//机器必须存在,机器状态必须是有效的,延期状态必须为可自动延期,结束时间必须是前后7天之内
|
|||
|
if machine == nil || machine.DelayStatus != model.DelayStatusAuto || machine.Status < 0 || machine.EndTime.Before(time.Now().AddDate(0, 0, -8)) || machine.EndTime.After(time.Now().AddDate(0, 0, 8)) {
|
|||
|
err = ecode.MerlinDelayMachineErr
|
|||
|
return
|
|||
|
}
|
|||
|
|
|||
|
//执行延期操作
|
|||
|
if err = s.dao.UpdateMachineEndTime(machineID, model.DelayStatusApply, machine.EndTime.AddDate(0, 0, 30)); err != nil {
|
|||
|
machineLog.OperateResult = model.OperationFailedForMachineLog
|
|||
|
} else {
|
|||
|
machineLog.OperateResult = model.OperationSuccessForMachineLog
|
|||
|
status = 0
|
|||
|
}
|
|||
|
|
|||
|
//记录操作日志
|
|||
|
machineLog.OperateType = model.DelayMachineEndTime
|
|||
|
machineLog.Username = username
|
|||
|
machineLog.MachineID = machineID
|
|||
|
err = s.dao.InsertMachineLog(machineLog)
|
|||
|
return
|
|||
|
|
|||
|
}
|
|||
|
|
|||
|
// ApplyDelayMachineEndTime Apply Delay Machine End Time.
|
|||
|
func (s *Service) ApplyDelayMachineEndTime(c context.Context, username string, applyEndTime *model.ApplyEndTimeRequest) (status int, err error) {
|
|||
|
var (
|
|||
|
machine *model.Machine
|
|||
|
machineLog = &model.MachineLog{}
|
|||
|
)
|
|||
|
|
|||
|
status = -1
|
|||
|
//查询机器延期状态
|
|||
|
if machine, err = s.dao.QueryMachine(applyEndTime.MachineID); err != nil {
|
|||
|
return
|
|||
|
}
|
|||
|
|
|||
|
//申请延期时,机器必须手动申请延期过,且机器状态为正常
|
|||
|
if machine == nil || machine.DelayStatus != model.DelayStatusApply || machine.Status < 0 {
|
|||
|
err = ecode.MerlinApplyMachineErr
|
|||
|
return
|
|||
|
}
|
|||
|
machineLog.OperateResult = model.OperationFailedForMachineLog
|
|||
|
|
|||
|
var applyET time.Time
|
|||
|
if applyET, err = time.ParseInLocation(model.TimeFormat, applyEndTime.ApplyEndTime, time.Local); err != nil {
|
|||
|
return
|
|||
|
}
|
|||
|
|
|||
|
//延长日期超过过期时间三个月或小于当前过期时间,驳回
|
|||
|
if machine.EndTime.AddDate(0, 3, 1).Before(applyET) || machine.EndTime.After(applyET) {
|
|||
|
err = ecode.MerlinApplyMachineByApplyEndTimeMore3MErr
|
|||
|
return
|
|||
|
}
|
|||
|
|
|||
|
ar := &model.ApplicationRecord{
|
|||
|
Applicant: username,
|
|||
|
MachineID: machine.ID,
|
|||
|
ApplyEndTime: applyET,
|
|||
|
Status: model.ApplyDelayInit,
|
|||
|
Auditor: applyEndTime.Auditor,
|
|||
|
}
|
|||
|
|
|||
|
//添加延期申请记录
|
|||
|
if err = s.dao.InsertApplicationRecordAndUpdateMachineDelayStatus(ar, machine.ID, model.DelayStatusDisable); err == nil {
|
|||
|
machineLog.OperateResult = model.OperationSuccessForMachineLog
|
|||
|
status = 0
|
|||
|
//发送邮件通知
|
|||
|
s.SendMailApplyDelayMachineEndTime(c, applyEndTime.Auditor, username, machine.ID, machine.EndTime, applyET)
|
|||
|
|
|||
|
}
|
|||
|
//记录操作日志
|
|||
|
machineLog.OperateType = model.DelayMachineEndTime
|
|||
|
machineLog.Username = username
|
|||
|
machineLog.MachineID = machine.ID
|
|||
|
if err = s.dao.InsertMachineLog(machineLog); err != nil {
|
|||
|
return
|
|||
|
}
|
|||
|
|
|||
|
return
|
|||
|
}
|
|||
|
|
|||
|
// CancelMachineEndTime Cancel Machine End Time.
|
|||
|
func (s *Service) CancelMachineEndTime(c context.Context, auditID int64, username string) (status int, err error) {
|
|||
|
var (
|
|||
|
applicationRecord *model.ApplicationRecord
|
|||
|
machineLog = &model.MachineLog{}
|
|||
|
machine *model.Machine
|
|||
|
)
|
|||
|
status = -1
|
|||
|
|
|||
|
if applicationRecord, err = s.dao.FindApplicationRecordsByID(auditID); err != nil {
|
|||
|
return
|
|||
|
}
|
|||
|
|
|||
|
//查询机器延期状态
|
|||
|
if machine, err = s.dao.QueryMachine(applicationRecord.MachineID); err != nil {
|
|||
|
return
|
|||
|
}
|
|||
|
|
|||
|
//取消延期时,审批状态应为 ApplyDelayInit,且用户名是当时申请延期名,机器状态为正常
|
|||
|
if applicationRecord == nil || applicationRecord.Status != model.ApplyDelayInit || applicationRecord.Applicant != username || machine.Status < 0 {
|
|||
|
err = ecode.MerlinCancelMachineErr
|
|||
|
return
|
|||
|
}
|
|||
|
machineLog.OperateResult = model.OperationFailedForMachineLog
|
|||
|
|
|||
|
if err = s.dao.UpdateAuditStatusAndUpdateMachineDelayStatus(applicationRecord.MachineID, auditID, model.DelayStatusApply, model.ApplyDelayCancel); err == nil {
|
|||
|
machineLog.OperateResult = model.OperationSuccessForMachineLog
|
|||
|
status = 0
|
|||
|
}
|
|||
|
//记录操作日志
|
|||
|
machineLog.OperateType = model.CancelDelayMachineEndTime
|
|||
|
machineLog.Username = username
|
|||
|
machineLog.MachineID = applicationRecord.MachineID
|
|||
|
if err = s.dao.InsertMachineLog(machineLog); err != nil {
|
|||
|
return
|
|||
|
}
|
|||
|
|
|||
|
return
|
|||
|
|
|||
|
}
|
|||
|
|
|||
|
// AuditMachineEndTime Audit Machine End Time.
|
|||
|
func (s *Service) AuditMachineEndTime(c context.Context, auditID int64, username string, auditResult bool, comment string) (status int, err error) {
|
|||
|
var (
|
|||
|
applicationRecord *model.ApplicationRecord
|
|||
|
machineLog = &model.MachineLog{}
|
|||
|
machine *model.Machine
|
|||
|
)
|
|||
|
status = -1
|
|||
|
if applicationRecord, err = s.dao.FindApplicationRecordsByID(auditID); err != nil {
|
|||
|
return
|
|||
|
}
|
|||
|
|
|||
|
//查询机器延期状态
|
|||
|
if machine, err = s.dao.QueryMachine(applicationRecord.MachineID); err != nil {
|
|||
|
return
|
|||
|
}
|
|||
|
|
|||
|
//审核时,延期状态必须为ApplyDelayInit,同时用户名为审核者名一致,机器状态为正常
|
|||
|
if applicationRecord == nil || applicationRecord.Status != model.ApplyDelayInit || applicationRecord.Auditor != username || machine.Status < 0 {
|
|||
|
err = ecode.MerlinAuditMachineErr
|
|||
|
return
|
|||
|
}
|
|||
|
machineLog.OperateResult = model.OperationFailedForMachineLog
|
|||
|
|
|||
|
if auditResult {
|
|||
|
//批准 //修改机器状态和延期时间,审批状态
|
|||
|
err = s.dao.UpdateAuditStatusAndUpdateMachineEndTime(applicationRecord.MachineID, auditID, model.DelayStatusApply, model.ApplyDelayApprove, applicationRecord.ApplyEndTime, comment)
|
|||
|
} else {
|
|||
|
//驳回 //修改机器状态,审批状态
|
|||
|
err = s.dao.UpdateAuditStatusAndUpdateMachineDelayStatusComment(applicationRecord.MachineID, auditID, model.DelayStatusApply, model.ApplyDelayDecline, comment)
|
|||
|
}
|
|||
|
|
|||
|
//发送邮件通知
|
|||
|
if err == nil {
|
|||
|
machineLog.OperateResult = model.OperationSuccessForMachineLog
|
|||
|
status = 0
|
|||
|
s.SendMailAuditResult(c, applicationRecord.Auditor, applicationRecord.Applicant, applicationRecord.MachineID, auditResult)
|
|||
|
}
|
|||
|
//记录操作日志
|
|||
|
machineLog.OperateType = model.AuditDelayMachineEndTime
|
|||
|
machineLog.Username = username
|
|||
|
machineLog.MachineID = applicationRecord.MachineID
|
|||
|
if err = s.dao.InsertMachineLog(machineLog); err != nil {
|
|||
|
return
|
|||
|
}
|
|||
|
|
|||
|
return
|
|||
|
|
|||
|
}
|
|||
|
|
|||
|
// GetApplicationRecordsByApplicant Get Application Records By Applicant.
|
|||
|
func (s *Service) GetApplicationRecordsByApplicant(c context.Context, username string, pn, ps int) (p *model.PaginateApplicationRecord, err error) {
|
|||
|
var (
|
|||
|
total int64
|
|||
|
applicationRecords []*model.ApplicationRecord
|
|||
|
)
|
|||
|
if total, applicationRecords, err = s.dao.FindApplicationRecordsByApplicant(username, pn, ps); err != nil {
|
|||
|
return
|
|||
|
}
|
|||
|
p = &model.PaginateApplicationRecord{
|
|||
|
PageNum: pn,
|
|||
|
PageSize: ps,
|
|||
|
Total: total,
|
|||
|
ApplicationRecords: applicationRecords,
|
|||
|
}
|
|||
|
return
|
|||
|
}
|
|||
|
|
|||
|
// GetApplicationRecordsByAuditor Get Application Records By Auditor.
|
|||
|
func (s *Service) GetApplicationRecordsByAuditor(c context.Context, username string, pn, ps int) (p *model.PaginateApplicationRecord, err error) {
|
|||
|
var (
|
|||
|
total int64
|
|||
|
applicationRecords []*model.ApplicationRecord
|
|||
|
)
|
|||
|
if total, applicationRecords, err = s.dao.FindApplicationRecordsByAuditor(username, pn, ps); err != nil {
|
|||
|
return
|
|||
|
}
|
|||
|
p = &model.PaginateApplicationRecord{
|
|||
|
PageNum: pn,
|
|||
|
PageSize: ps,
|
|||
|
Total: total,
|
|||
|
ApplicationRecords: applicationRecords,
|
|||
|
}
|
|||
|
return
|
|||
|
}
|
|||
|
|
|||
|
// GetApplicationRecordsByMachineID Get Application Records By MachineID.
|
|||
|
func (s *Service) GetApplicationRecordsByMachineID(c context.Context, machineID int64, pn, ps int) (p *model.PaginateApplicationRecord, err error) {
|
|||
|
var (
|
|||
|
total int64
|
|||
|
applicationRecords []*model.ApplicationRecord
|
|||
|
)
|
|||
|
if total, applicationRecords, err = s.dao.FindApplicationRecordsByMachineID(machineID, pn, ps); err != nil {
|
|||
|
return
|
|||
|
}
|
|||
|
p = &model.PaginateApplicationRecord{
|
|||
|
PageNum: pn,
|
|||
|
PageSize: ps,
|
|||
|
Total: total,
|
|||
|
ApplicationRecords: applicationRecords,
|
|||
|
}
|
|||
|
return
|
|||
|
}
|