2 * Copyright (C) 2005-2009 MaNGOS <http://getmangos.com/>
4 * This program is free software; you can redistribute it and/or modify
5 * it under the terms of the GNU General Public License as published by
6 * the Free Software Foundation; either version 2 of the License, or
7 * (at your option) any later version.
9 * This program is distributed in the hope that it will be useful,
10 * but WITHOUT ANY WARRANTY; without even the implied warranty of
11 * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
12 * GNU General Public License for more details.
14 * You should have received a copy of the GNU General Public License
15 * along with this program; if not, write to the Free Software
16 * Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA 02111-1307 USA
21 #include "WorldPacket.h"
23 #include "GMTicketMgr.h"
24 #include "ObjectAccessor.h"
28 void WorldSession::SendGMTicketGetTicket(uint32 status
, char const* text
)
30 int len
= text
? strlen(text
) : 0;
31 WorldPacket
data( SMSG_GMTICKET_GETTICKET
, (4+len
+1+4+2+4+4) );
32 data
<< uint32(status
); // standard 0x0A, 0x06 if text present
35 data
<< text
; // ticket text
36 data
<< uint8(0x7); // ticket category
37 data
<< float(0); // time from ticket creation?
38 data
<< float(0); // const
39 data
<< float(0); // const
40 data
<< uint8(0); // const
41 data
<< uint8(0); // const
46 void WorldSession::HandleGMTicketGetTicketOpcode( WorldPacket
& /*recv_data*/ )
48 WorldPacket
data( SMSG_QUERY_TIME_RESPONSE
, 4+4 );
49 data
<< (uint32
)time(NULL
);
53 GMTicket
* ticket
= ticketmgr
.GetGMTicket(GetPlayer()->GetGUIDLow());
55 SendGMTicketGetTicket(0x06,ticket
->GetText());
57 SendGMTicketGetTicket(0x0A,0);
60 void WorldSession::HandleGMTicketUpdateTextOpcode( WorldPacket
& recv_data
)
62 CHECK_PACKET_SIZE(recv_data
,1);
64 std::string ticketText
;
65 recv_data
>> ticketText
;
67 if(GMTicket
* ticket
= ticketmgr
.GetGMTicket(GetPlayer()->GetGUIDLow()))
68 ticket
->SetText(ticketText
.c_str());
70 sLog
.outError("Ticket update: Player %s (GUID: %u) doesn't have active ticket", GetPlayer()->GetName(), GetPlayer()->GetGUIDLow());
73 void WorldSession::HandleGMTicketDeleteOpcode( WorldPacket
& /*recv_data*/ )
75 ticketmgr
.Delete(GetPlayer()->GetGUIDLow());
77 WorldPacket
data( SMSG_GMTICKET_DELETETICKET
, 4 );
81 SendGMTicketGetTicket(0x0A, 0);
84 void WorldSession::HandleGMTicketCreateOpcode( WorldPacket
& recv_data
)
86 CHECK_PACKET_SIZE(recv_data
, 4*4+1+2*4);
90 std::string ticketText
= "";
93 recv_data
>> map
>> x
>> y
>> z
; // last check 2.4.3
94 recv_data
>> ticketText
;
97 CHECK_PACKET_SIZE(recv_data
,4*4+(ticketText
.size()+1)+2*4);
99 recv_data
>> unk1
>> unk2
;
100 // note: the packet might contain more data, but the exact structure of that is unknown
102 sLog
.outDebug("TicketCreate: map %u, x %f, y %f, z %f, text %s, unk1 %u, unk2 %u", map
, x
, y
, z
, ticketText
.c_str(), unk1
, unk2
);
104 if(ticketmgr
.GetGMTicket(GetPlayer()->GetGUIDLow()))
106 WorldPacket
data( SMSG_GMTICKET_CREATE
, 4 );
112 ticketmgr
.Create(_player
->GetGUIDLow(), ticketText
.c_str());
114 WorldPacket
data( SMSG_QUERY_TIME_RESPONSE
, 4+4 );
115 data
<< (uint32
)time(NULL
);
119 data
.Initialize( SMSG_GMTICKET_CREATE
, 4 );
122 DEBUG_LOG("update the ticket");
124 //TODO: Guard player map
125 HashMapHolder
<Player
>::MapType
&m
= ObjectAccessor::Instance().GetPlayers();
126 for(HashMapHolder
<Player
>::MapType::iterator itr
= m
.begin(); itr
!= m
.end(); ++itr
)
128 if(itr
->second
->GetSession()->GetSecurity() >= SEC_GAMEMASTER
&& itr
->second
->isAcceptTickets())
129 ChatHandler(itr
->second
).PSendSysMessage(LANG_COMMAND_TICKETNEW
,GetPlayer()->GetName());
133 void WorldSession::HandleGMTicketSystemStatusOpcode( WorldPacket
& /*recv_data*/ )
135 WorldPacket
data( SMSG_GMTICKET_SYSTEMSTATUS
,4 );
136 data
<< uint32(1); // we can also disable ticket system by sending 0 value
141 void WorldSession::HandleGMSurveySubmit( WorldPacket
& recv_data
)
143 // GM survey is shown after SMSG_GM_TICKET_STATUS_UPDATE with status = 3
144 CHECK_PACKET_SIZE(recv_data
,4+4);
146 recv_data
>> x
; // answer range? (6 = 0-5?)
147 sLog
.outDebug("SURVEY: X = %u", x
);
150 memset(result
, 0, sizeof(result
));
151 for( int i
= 0; i
< 10; ++i
)
153 CHECK_PACKET_SIZE(recv_data
,recv_data
.rpos()+4);
155 recv_data
>> questionID
; // GMSurveyQuestions.dbc
159 CHECK_PACKET_SIZE(recv_data
,recv_data
.rpos()+1+1);
161 std::string unk_text
;
162 recv_data
>> value
; // answer
163 recv_data
>> unk_text
; // always empty?
166 sLog
.outDebug("SURVEY: ID %u, value %u, text %s", questionID
, value
, unk_text
.c_str());
169 CHECK_PACKET_SIZE(recv_data
,recv_data
.rpos()+1);
171 recv_data
>> comment
; // addional comment
172 sLog
.outDebug("SURVEY: comment %s", comment
.c_str());
174 // TODO: chart this data in some way