|
|
|
package engine.net.client.handlers;
|
|
|
|
|
|
|
|
import engine.exception.MsgSendException;
|
|
|
|
import engine.gameManager.DbManager;
|
|
|
|
import engine.math.Vector3fImmutable;
|
|
|
|
import engine.net.client.ClientConnection;
|
|
|
|
import engine.net.client.msg.ClientNetMsg;
|
|
|
|
import engine.net.client.msg.PetitionReceivedMsg;
|
|
|
|
import org.pmw.tinylog.Logger;
|
|
|
|
|
|
|
|
public class PetitionReceivedMsgHandler extends AbstractClientMsgHandler {
|
|
|
|
|
|
|
|
public PetitionReceivedMsgHandler() {
|
|
|
|
super(PetitionReceivedMsg.class);
|
|
|
|
}
|
|
|
|
|
|
|
|
@Override
|
|
|
|
protected boolean _handleNetMsg(ClientNetMsg msg, ClientConnection origin) throws MsgSendException {
|
|
|
|
String originAccount = origin.getAccount().getUname();
|
|
|
|
String originCharacter = origin.getPlayerCharacter().getName();
|
|
|
|
Vector3fImmutable playerLocation = origin.getPlayerCharacter().getLoc();
|
|
|
|
String primaryReportType;
|
|
|
|
switch(((PetitionReceivedMsg) msg).getType()){
|
|
|
|
case 1: // TYPE_GENERAL_HELP
|
|
|
|
primaryReportType = "GENERAL";
|
|
|
|
break;
|
|
|
|
case 2: // TYPE_FEEDBACK
|
|
|
|
primaryReportType = "FEEDBACK";
|
|
|
|
break;
|
|
|
|
case 3: // TYPE_STUCK
|
|
|
|
primaryReportType = "STUCK";
|
|
|
|
break;
|
|
|
|
case 4: // TYPE_HARASSMENT
|
|
|
|
primaryReportType = "HARASSMENT";
|
|
|
|
break;
|
|
|
|
case 5: // TYPE_EXPLOIT
|
|
|
|
primaryReportType = "EXPLOIT";
|
|
|
|
break;
|
|
|
|
case 6: // TYPE_BUG
|
|
|
|
primaryReportType = "BUG";
|
|
|
|
break;
|
|
|
|
case 7: // TYPE_GAME_STOPPER
|
|
|
|
primaryReportType = "GAME STOPPER";
|
|
|
|
break;
|
|
|
|
case 8: // TYPE_TECH_SUPPORT
|
|
|
|
primaryReportType = "TECH SUPPORT";
|
|
|
|
break;
|
|
|
|
default: // INVALID_TYPE cannot process this
|
|
|
|
primaryReportType = "NONE";
|
|
|
|
return false;
|
|
|
|
}
|
|
|
|
String subType;
|
|
|
|
switch (((PetitionReceivedMsg)msg).getSubType()) {
|
|
|
|
case 1: // SUBTYPE_EXPLOIT_DUPE
|
|
|
|
subType = "DUPE";
|
|
|
|
break;
|
|
|
|
case 2: // SUBTYPE_EXPLOIT_LEVELING
|
|
|
|
subType = "LEVELLING";
|
|
|
|
break;
|
|
|
|
case 3: // SUBTYPE_EXPLOIT_SKILL_GAIN
|
|
|
|
subType = "SKILL GAIN";
|
|
|
|
break;
|
|
|
|
case 4: // SUBTYPE_EXPLOIT_KILLING
|
|
|
|
subType = "KILLING";
|
|
|
|
break;
|
|
|
|
case 5: // SUBTYPE_EXPLOIT_POLICY
|
|
|
|
subType = "POLICY";
|
|
|
|
break;
|
|
|
|
case 6: // SUBTYPE_EXPLOIT_OTHER
|
|
|
|
subType = "OTHER";
|
|
|
|
break;
|
|
|
|
case 7: // SUBTYPE_TECH_VIDEO
|
|
|
|
subType = "VIDEO";
|
|
|
|
break;
|
|
|
|
case 8: // SUBTYPE_TECH_SOUND
|
|
|
|
subType = "SOUND";
|
|
|
|
break;
|
|
|
|
case 9: // SUBTYPE_TECH_NETWORK
|
|
|
|
subType = "NETWORK";
|
|
|
|
break;
|
|
|
|
case 10: // SUBTYPE_TECH_OTHER
|
|
|
|
subType = "OTHER";
|
|
|
|
break;
|
|
|
|
default: // INVALID_SUB_TYPE
|
|
|
|
subType = "NONE";
|
|
|
|
break;
|
|
|
|
}
|
|
|
|
String report = "ACCOUNT: " + originAccount + " CHARACTER: " + originCharacter + " LOCATION: " + playerLocation + " PRIMARY TYPE: " + primaryReportType + " SUB TYPE: " + subType + " MESSAGE: " + ((PetitionReceivedMsg) msg).getMessage();
|
|
|
|
Logger.info(report);
|
|
|
|
return true;
|
|
|
|
}
|
|
|
|
private void logBugReport(PetitionReceivedMsg msg){
|
|
|
|
|
|
|
|
}
|
|
|
|
}
|