mirror of
https://github.com/Mezeporta/Erupe.git
synced 2025-12-13 23:44:52 +01:00
initial mercenaries build
This commit is contained in:
5
patch-schema/mercenary.sql
Normal file
5
patch-schema/mercenary.sql
Normal file
@@ -0,0 +1,5 @@
|
|||||||
|
BEGIN;
|
||||||
|
|
||||||
|
CREATE SEQUENCE IF NOT EXISTS public.rasta_id_seq;
|
||||||
|
|
||||||
|
END;
|
||||||
@@ -9,7 +9,6 @@ import (
|
|||||||
"go.uber.org/zap"
|
"go.uber.org/zap"
|
||||||
"io"
|
"io"
|
||||||
"io/ioutil"
|
"io/ioutil"
|
||||||
"math/rand"
|
|
||||||
"os"
|
"os"
|
||||||
"path/filepath"
|
"path/filepath"
|
||||||
)
|
)
|
||||||
@@ -132,8 +131,11 @@ func handleMsgMhfCreateMercenary(s *Session, p mhfpacket.MHFPacket) {
|
|||||||
|
|
||||||
bf := byteframe.NewByteFrame()
|
bf := byteframe.NewByteFrame()
|
||||||
|
|
||||||
bf.WriteUint32(0x00) // Unk
|
var nextID uint32
|
||||||
bf.WriteUint32(rand.Uint32()) // Partner ID?
|
s.server.db.QueryRow("SELECT nextval('rasta_id_seq')").Scan(&nextID)
|
||||||
|
|
||||||
|
bf.WriteUint32(nextID) // New MercID
|
||||||
|
bf.WriteUint32(0xDEADBEEF) // Unk
|
||||||
|
|
||||||
doAckSimpleSucceed(s, pkt.AckHandle, bf.Data())
|
doAckSimpleSucceed(s, pkt.AckHandle, bf.Data())
|
||||||
}
|
}
|
||||||
@@ -141,24 +143,16 @@ func handleMsgMhfCreateMercenary(s *Session, p mhfpacket.MHFPacket) {
|
|||||||
func handleMsgMhfSaveMercenary(s *Session, p mhfpacket.MHFPacket) {
|
func handleMsgMhfSaveMercenary(s *Session, p mhfpacket.MHFPacket) {
|
||||||
pkt := p.(*mhfpacket.MsgMhfSaveMercenary)
|
pkt := p.(*mhfpacket.MsgMhfSaveMercenary)
|
||||||
bf := byteframe.NewByteFrameFromBytes(pkt.RawDataPayload)
|
bf := byteframe.NewByteFrameFromBytes(pkt.RawDataPayload)
|
||||||
GCPValue := bf.ReadUint32()
|
GCP := bf.ReadUint32()
|
||||||
_ = bf.ReadUint32() // unk
|
_ = bf.ReadUint32() // unk
|
||||||
MercDataSize := bf.ReadUint32()
|
MercDataSize := bf.ReadUint32()
|
||||||
MercData := bf.ReadBytes(uint(MercDataSize))
|
MercData := bf.ReadBytes(uint(MercDataSize))
|
||||||
_ = bf.ReadUint32() // unk
|
_ = bf.ReadUint32() // unk
|
||||||
|
|
||||||
if MercDataSize > 0 {
|
if MercDataSize > 0 {
|
||||||
// the save packet has an extra null byte after its size
|
s.server.db.Exec("UPDATE characters SET savemercenary=$1 WHERE id=$2", MercData[:MercDataSize], s.charID)
|
||||||
_, err := s.server.db.Exec("UPDATE characters SET savemercenary=$1 WHERE id=$2", MercData[:MercDataSize], s.charID)
|
|
||||||
if err != nil {
|
|
||||||
s.logger.Fatal("Failed to update savemercenary and gcp in db", zap.Error(err))
|
|
||||||
}
|
|
||||||
}
|
|
||||||
// gcp value is always present regardless
|
|
||||||
_, err := s.server.db.Exec("UPDATE characters SET gcp=$1 WHERE id=$2", GCPValue, s.charID)
|
|
||||||
if err != nil {
|
|
||||||
s.logger.Fatal("Failed to update savemercenary and gcp in db", zap.Error(err))
|
|
||||||
}
|
}
|
||||||
|
s.server.db.Exec("UPDATE characters SET gcp=$1 WHERE id=$2", GCP, s.charID)
|
||||||
doAckSimpleSucceed(s, pkt.AckHandle, []byte{0x00, 0x00, 0x00, 0x00})
|
doAckSimpleSucceed(s, pkt.AckHandle, []byte{0x00, 0x00, 0x00, 0x00})
|
||||||
}
|
}
|
||||||
|
|
||||||
@@ -166,31 +160,32 @@ func handleMsgMhfReadMercenaryW(s *Session, p mhfpacket.MHFPacket) {
|
|||||||
pkt := p.(*mhfpacket.MsgMhfReadMercenaryW)
|
pkt := p.(*mhfpacket.MsgMhfReadMercenaryW)
|
||||||
var data []byte
|
var data []byte
|
||||||
var gcp uint32
|
var gcp uint32
|
||||||
// still has issues
|
s.server.db.QueryRow("SELECT savemercenary FROM characters WHERE id = $1", s.charID).Scan(&data)
|
||||||
err := 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 err != nil {
|
|
||||||
s.logger.Fatal("Failed to get savemercenary data from db", zap.Error(err))
|
|
||||||
}
|
|
||||||
|
|
||||||
err = s.server.db.QueryRow("SELECT COALESCE(gcp, 0) FROM characters WHERE id = $1", s.charID).Scan(&gcp)
|
|
||||||
if err != nil {
|
|
||||||
panic(err)
|
|
||||||
}
|
|
||||||
if len(data) == 0 {
|
|
||||||
data = []byte{0x00}
|
|
||||||
}
|
|
||||||
|
|
||||||
resp := byteframe.NewByteFrame()
|
resp := byteframe.NewByteFrame()
|
||||||
resp.WriteBytes(data)
|
|
||||||
resp.WriteUint16(0)
|
resp.WriteUint16(0)
|
||||||
|
if len(data) == 0 {
|
||||||
|
resp.WriteBool(false)
|
||||||
|
} else {
|
||||||
|
resp.WriteBool(true)
|
||||||
|
resp.WriteBytes(data)
|
||||||
|
}
|
||||||
resp.WriteUint32(gcp)
|
resp.WriteUint32(gcp)
|
||||||
doAckBufSucceed(s, pkt.AckHandle, resp.Data())
|
doAckBufSucceed(s, pkt.AckHandle, resp.Data())
|
||||||
}
|
}
|
||||||
|
|
||||||
func handleMsgMhfReadMercenaryM(s *Session, p mhfpacket.MHFPacket) {
|
func handleMsgMhfReadMercenaryM(s *Session, p mhfpacket.MHFPacket) {
|
||||||
pkt := p.(*mhfpacket.MsgMhfReadMercenaryM)
|
pkt := p.(*mhfpacket.MsgMhfReadMercenaryM)
|
||||||
// accessing actual rasta data of someone else still unsure of the formatting of this
|
var data []byte
|
||||||
doAckBufSucceed(s, pkt.AckHandle, []byte{0x00, 0x00, 0x00, 0x00})
|
s.server.db.QueryRow("SELECT savemercenary FROM characters WHERE id = $1", pkt.CharID).Scan(&data)
|
||||||
|
resp := byteframe.NewByteFrame()
|
||||||
|
if len(data) == 0 {
|
||||||
|
resp.WriteBool(false)
|
||||||
|
} else {
|
||||||
|
resp.WriteBytes(data[4:])
|
||||||
|
}
|
||||||
|
doAckBufSucceed(s, pkt.AckHandle, resp.Data())
|
||||||
}
|
}
|
||||||
|
|
||||||
func handleMsgMhfContractMercenary(s *Session, p mhfpacket.MHFPacket) {}
|
func handleMsgMhfContractMercenary(s *Session, p mhfpacket.MHFPacket) {}
|
||||||
|
|||||||
Reference in New Issue
Block a user