Support define offline and issue table by config

This commit is contained in:
r0n1n7an 2024-01-19 14:56:40 +08:00
parent 0167b0cec3
commit cca73fb840
6 changed files with 53 additions and 49 deletions

Binary file not shown.

View File

@ -434,8 +434,8 @@ func handleGetUutInfo(w http.ResponseWriter, r *http.Request) {
switch params["ACTION"] {
case "QueryByFilter":
rst = ews.GetUutInfo(cfg, logger, host, addr, uri, params)
case "GetDefectReport":
rst = ews.GetDefectReport(cfg, logger, host, addr, uri, params)
case "GetIssueReport":
rst = ews.GetIssueReport(cfg, logger, host, addr, uri, params)
case "GetOfflineReport":
rst = ews.GetOfflineReport(cfg, logger, host, addr, uri, params)
default:

View File

@ -12,8 +12,10 @@ MySQL:
Database: ewsv3_f716
User: apisvc
Password: wcqte
OfflineTable: v_offline
IssueTable: v_issue
Remark:
Columns_UutInfo: [usn,mac,ipaddr,status,message,first_ack,last_ack,last_change,last_transfer]
Columns_UutInfo: [usn,mac,ipaddr,status,message,first_ack,last_ack,last_change]
Columns_LocInfo: [mac,line,col,row,num,last_found]
USER_RO: ewsv3:ewsv3
USER_RW: apisvc:wcqte

View File

@ -29,7 +29,7 @@
<select name="ACTION" id="ACTION">
<!--option value="" selected="true">* 选择查询类型 *</option-->
<option value="QueryByFilter" selected="true">条件查询</option>
<option value="GetDefectReport">实时异常报表</option>
<option value="GetIssueReport">实时异常报表</option>
<option value="GetOfflineReport">实时离线报表</option>
</select>&nbsp;
</li>
@ -37,9 +37,9 @@
<!--label for="KEY">查询条件: </label>&nbsp;-->
<select name="KEY" id="KEY">
<!--option value="" selected="true">* 选择查询条件 *</option-->
<option value="USN" selected="true">By SN</option>
<option value="USN" selected="true">By USN</option>
<option value="MAC">By MAC</option>
<option value="MO">By MO</option>
<option value="SKU">By SKU</option>
</select>&nbsp;
<input type="text" name="VALUE" id="VALUE" />&nbsp;
</li>

View File

@ -20,4 +20,6 @@ type MySQL struct {
Database string `yaml:"Database"`
User string `yaml:"User"`
Password string `yaml:"Password"`
IssueTable string `yaml:"IssueTable"`
OfflineTable string `yaml:"OfflineTable"`
}

View File

@ -30,7 +30,7 @@ type UutInfo struct {
LastChg string
}
type DefectInfo struct {
type ReportInfo struct {
USN string
PartNO string
MfgMO string
@ -506,7 +506,7 @@ func (e *EWS) GetUutInfo(cfg cnf.Cfg, logger *log.Logger, host string, addr stri
return rst
}
func (e *EWS) GetDefectReport(cfg cnf.Cfg, logger *log.Logger, host string, addr string, uri string, params map[string]string) map[string]string {
func (e *EWS) GetIssueReport(cfg cnf.Cfg, logger *log.Logger, host string, addr string, uri string, params map[string]string) map[string]string {
rst := map[string]string{"RESULT": ""}
dsn := fmt.Sprintf("%s:%s@tcp(%s:%s)/%s",
@ -532,12 +532,12 @@ func (e *EWS) GetDefectReport(cfg cnf.Cfg, logger *log.Logger, host string, addr
return rst
}
di := new(DefectInfo)
ri := new(ReportInfo)
defect := ""
rows, err := dbo.Query(
rows, err := dbo.Query(fmt.Sprintf(
`SELECT usn,partno,mo,sku,line,location,item,status,message,first_ack,last_ack,last_change,diffmins
FROM v_ngreport
ORDER BY diffmins ASC;`)
FROM %s
ORDER BY diffmins ASC;`, cfg.MySQL.IssueTable))
if err != nil {
logger.Printf("[ERR] %s; %s; %#v; %s\r\n", addr, uri, params, err.Error())
rst["RESULT"] = "NG"
@ -549,25 +549,25 @@ func (e *EWS) GetDefectReport(cfg cnf.Cfg, logger *log.Logger, host string, addr
num := 1
for rows.Next() {
err := rows.Scan(
&di.USN,
&di.PartNO,
&di.MfgMO,
&di.SKU,
&di.Line,
&di.Location,
&di.Item,
&di.Status,
&di.Message,
&di.FirstAck,
&di.LastAck,
&di.LastChg,
&di.DiffMins,
&ri.USN,
&ri.PartNO,
&ri.MfgMO,
&ri.SKU,
&ri.Line,
&ri.Location,
&ri.Item,
&ri.Status,
&ri.Message,
&ri.FirstAck,
&ri.LastAck,
&ri.LastChg,
&ri.DiffMins,
)
if err != nil {
break
}
temp := fmt.Sprintf(`<tr><td>%d</td><td>%s</td><td>%s</td><td>%s</td><td>%s</td><td>%s</td><td>%s</td><td>%s</td><td>%s</td><td>%s</td><td>%s</td><td>%s</td><td>%s</td><td>%s</td></tr>%s`,
num, di.USN, di.PartNO, di.MfgMO, di.SKU, di.Line, di.Location, di.Item, di.Status, di.Message, di.FirstAck, di.LastAck, di.LastChg, di.DiffMins, "\r\n")
num, ri.USN, ri.PartNO, ri.MfgMO, ri.SKU, ri.Line, ri.Location, ri.Item, ri.Status, ri.Message, ri.FirstAck, ri.LastAck, ri.LastChg, ri.DiffMins, "\r\n")
defect = defect + temp
num += 1
}
@ -603,12 +603,12 @@ func (e *EWS) GetOfflineReport(cfg cnf.Cfg, logger *log.Logger, host string, add
return rst
}
di := new(DefectInfo)
ri := new(ReportInfo)
offline := ""
rows, err := dbo.Query(
rows, err := dbo.Query(fmt.Sprintf(
`SELECT usn,partno,mo,sku,line,location,item,status,message,first_ack,last_ack,last_change,diffmins
FROM v_offline
ORDER BY diffmins DESC;`)
FROM %s
ORDER BY diffmins DESC;`, cfg.MySQL.OfflineTable))
if err != nil {
logger.Printf("[ERR] %s; %s; %#v; %s\r\n", addr, uri, params, err.Error())
rst["RESULT"] = "NG"
@ -620,25 +620,25 @@ func (e *EWS) GetOfflineReport(cfg cnf.Cfg, logger *log.Logger, host string, add
num := 1
for rows.Next() {
err := rows.Scan(
&di.USN,
&di.PartNO,
&di.MfgMO,
&di.SKU,
&di.Line,
&di.Location,
&di.Item,
&di.Status,
&di.Message,
&di.FirstAck,
&di.LastAck,
&di.LastChg,
&di.DiffMins,
&ri.USN,
&ri.PartNO,
&ri.MfgMO,
&ri.SKU,
&ri.Line,
&ri.Location,
&ri.Item,
&ri.Status,
&ri.Message,
&ri.FirstAck,
&ri.LastAck,
&ri.LastChg,
&ri.DiffMins,
)
if err != nil {
break
}
temp := fmt.Sprintf(`<tr><td>%d</td><td>%s</td><td>%s</td><td>%s</td><td>%s</td><td>%s</td><td>%s</td><td>%s</td><td>%s</td><td>%s</td><td>%s</td><td>%s</td><td>%s</td><td>%s</td></tr>%s`,
num, di.USN, di.PartNO, di.MfgMO, di.SKU, di.Line, di.Location, di.Item, di.Status, di.Message, di.FirstAck, di.LastAck, di.LastChg, di.DiffMins, "\r\n")
num, ri.USN, ri.PartNO, ri.MfgMO, ri.SKU, ri.Line, ri.Location, ri.Item, ri.Status, ri.Message, ri.FirstAck, ri.LastAck, ri.LastChg, ri.DiffMins, "\r\n")
offline = offline + temp
num += 1
}