mirror of
https://github.com/Mezeporta/Erupe.git
synced 2025-12-13 15:34:38 +01:00
rewrite ReadMercenaryW handler
This commit is contained in:
@@ -157,60 +157,60 @@ func handleMsgMhfSaveMercenary(s *Session, p mhfpacket.MHFPacket) {
|
|||||||
|
|
||||||
func handleMsgMhfReadMercenaryW(s *Session, p mhfpacket.MHFPacket) {
|
func handleMsgMhfReadMercenaryW(s *Session, p mhfpacket.MHFPacket) {
|
||||||
pkt := p.(*mhfpacket.MsgMhfReadMercenaryW)
|
pkt := p.(*mhfpacket.MsgMhfReadMercenaryW)
|
||||||
if pkt.Op > 0 {
|
bf := byteframe.NewByteFrame()
|
||||||
bf := byteframe.NewByteFrame()
|
|
||||||
var pactID uint32
|
|
||||||
var name string
|
|
||||||
var cid uint32
|
|
||||||
|
|
||||||
s.server.db.QueryRow("SELECT pact_id FROM characters WHERE id=$1", s.charID).Scan(&pactID)
|
var pactID, cid uint32
|
||||||
if pactID > 0 {
|
var name string
|
||||||
s.server.db.QueryRow("SELECT name, id FROM characters WHERE rasta_id = $1", pactID).Scan(&name, &cid)
|
s.server.db.QueryRow("SELECT pact_id FROM characters WHERE id=$1", s.charID).Scan(&pactID)
|
||||||
bf.WriteUint8(1) // numLends
|
if pactID > 0 {
|
||||||
bf.WriteUint32(pactID)
|
s.server.db.QueryRow("SELECT name, id FROM characters WHERE rasta_id = $1", pactID).Scan(&name, &cid)
|
||||||
bf.WriteUint32(cid)
|
bf.WriteUint8(1) // numLends
|
||||||
bf.WriteBool(false) // ?
|
bf.WriteUint32(pactID)
|
||||||
bf.WriteUint32(uint32(TimeAdjusted().Add(time.Hour * 24 * -8).Unix()))
|
bf.WriteUint32(cid)
|
||||||
bf.WriteUint32(uint32(TimeAdjusted().Add(time.Hour * 24 * -1).Unix()))
|
bf.WriteBool(false) // ?
|
||||||
bf.WriteBytes(stringsupport.PaddedString(name, 18, true))
|
bf.WriteUint32(uint32(TimeAdjusted().Add(time.Hour * 24 * -8).Unix()))
|
||||||
} else {
|
bf.WriteUint32(uint32(TimeAdjusted().Add(time.Hour * 24 * -1).Unix()))
|
||||||
bf.WriteUint8(0)
|
bf.WriteBytes(stringsupport.PaddedString(name, 18, true))
|
||||||
}
|
|
||||||
|
|
||||||
if pkt.Op < 2 {
|
|
||||||
var loans uint8
|
|
||||||
temp := byteframe.NewByteFrame()
|
|
||||||
rows, _ := s.server.db.Query("SELECT name, id, pact_id FROM characters WHERE pact_id=(SELECT rasta_id FROM characters WHERE id=$1)", s.charID)
|
|
||||||
for rows.Next() {
|
|
||||||
loans++
|
|
||||||
rows.Scan(&name, &cid, &pactID)
|
|
||||||
temp.WriteUint32(pactID)
|
|
||||||
temp.WriteUint32(cid)
|
|
||||||
temp.WriteUint32(uint32(TimeAdjusted().Add(time.Hour * 24 * -8).Unix()))
|
|
||||||
temp.WriteUint32(uint32(TimeAdjusted().Add(time.Hour * 24 * -1).Unix()))
|
|
||||||
temp.WriteBytes(stringsupport.PaddedString(name, 18, true))
|
|
||||||
}
|
|
||||||
bf.WriteUint8(loans)
|
|
||||||
bf.WriteBytes(temp.Data())
|
|
||||||
}
|
|
||||||
doAckBufSucceed(s, pkt.AckHandle, bf.Data())
|
|
||||||
return
|
|
||||||
}
|
|
||||||
var data []byte
|
|
||||||
var gcp uint32
|
|
||||||
s.server.db.QueryRow("SELECT savemercenary FROM characters WHERE id=$1", s.charID).Scan(&data)
|
|
||||||
s.server.db.QueryRow("SELECT COALESCE(gcp, 0) FROM characters WHERE id=$1", s.charID).Scan(&gcp)
|
|
||||||
|
|
||||||
resp := byteframe.NewByteFrame()
|
|
||||||
resp.WriteUint16(0)
|
|
||||||
if len(data) == 0 {
|
|
||||||
resp.WriteBool(false)
|
|
||||||
} else {
|
} else {
|
||||||
resp.WriteBool(true)
|
bf.WriteUint8(0)
|
||||||
resp.WriteBytes(data)
|
|
||||||
}
|
}
|
||||||
resp.WriteUint32(gcp)
|
|
||||||
doAckBufSucceed(s, pkt.AckHandle, resp.Data())
|
var loans uint8
|
||||||
|
temp := byteframe.NewByteFrame()
|
||||||
|
if pkt.Op < 2 {
|
||||||
|
rows, _ := s.server.db.Query("SELECT name, id, pact_id FROM characters WHERE pact_id=(SELECT rasta_id FROM characters WHERE id=$1)", s.charID)
|
||||||
|
for rows.Next() {
|
||||||
|
err := rows.Scan(&name, &cid, &pactID)
|
||||||
|
if err != nil {
|
||||||
|
continue
|
||||||
|
}
|
||||||
|
loans++
|
||||||
|
temp.WriteUint32(pactID)
|
||||||
|
temp.WriteUint32(cid)
|
||||||
|
temp.WriteUint32(uint32(TimeAdjusted().Add(time.Hour * 24 * -8).Unix()))
|
||||||
|
temp.WriteUint32(uint32(TimeAdjusted().Add(time.Hour * 24 * -1).Unix()))
|
||||||
|
temp.WriteBytes(stringsupport.PaddedString(name, 18, true))
|
||||||
|
}
|
||||||
|
}
|
||||||
|
bf.WriteUint8(loans)
|
||||||
|
bf.WriteBytes(temp.Data())
|
||||||
|
|
||||||
|
if pkt.Op < 1 {
|
||||||
|
var data []byte
|
||||||
|
var gcp uint32
|
||||||
|
s.server.db.QueryRow("SELECT savemercenary FROM characters WHERE id=$1", s.charID).Scan(&data)
|
||||||
|
s.server.db.QueryRow("SELECT COALESCE(gcp, 0) FROM characters WHERE id=$1", s.charID).Scan(&gcp)
|
||||||
|
|
||||||
|
if len(data) == 0 {
|
||||||
|
bf.WriteBool(false)
|
||||||
|
} else {
|
||||||
|
bf.WriteBool(true)
|
||||||
|
bf.WriteBytes(data)
|
||||||
|
}
|
||||||
|
bf.WriteUint32(gcp)
|
||||||
|
}
|
||||||
|
|
||||||
|
doAckBufSucceed(s, pkt.AckHandle, bf.Data())
|
||||||
}
|
}
|
||||||
|
|
||||||
func handleMsgMhfReadMercenaryM(s *Session, p mhfpacket.MHFPacket) {
|
func handleMsgMhfReadMercenaryM(s *Session, p mhfpacket.MHFPacket) {
|
||||||
|
|||||||
Reference in New Issue
Block a user