Arcturus-Community/src/main/java/com/eu/habbo/messages/incoming/polls/AnswerPollEvent.java

75 lines
2.9 KiB
Java
Raw Normal View History

2018-07-06 15:30:00 +02:00
package com.eu.habbo.messages.incoming.polls;
import com.eu.habbo.Emulator;
import com.eu.habbo.habbohotel.polls.Poll;
import com.eu.habbo.habbohotel.users.HabboBadge;
import com.eu.habbo.messages.incoming.MessageHandler;
2019-03-18 02:22:00 +01:00
import com.eu.habbo.messages.outgoing.wired.WiredRewardAlertComposer;
2018-07-06 15:30:00 +02:00
import com.eu.habbo.messages.outgoing.users.AddUserBadgeComposer;
import java.sql.Connection;
import java.sql.PreparedStatement;
import java.sql.SQLException;
public class AnswerPollEvent extends MessageHandler
{
@Override
public void handle() throws Exception
{
int pollId = this.packet.readInt();
int questionId = this.packet.readInt();
int count = this.packet.readInt();
2019-03-18 02:22:00 +01:00
StringBuilder answer = new StringBuilder();
2018-07-06 15:30:00 +02:00
for(int i = 0; i < count; i++)
{
2019-03-18 02:22:00 +01:00
answer.append(":").append(this.packet.readString());
2018-07-06 15:30:00 +02:00
}
if (pollId == 0 && questionId <= 0)
{
2019-03-18 02:22:00 +01:00
this.client.getHabbo().getHabboInfo().getCurrentRoom().handleWordQuiz(this.client.getHabbo(), answer.toString());
2018-07-06 15:30:00 +02:00
return;
}
2019-03-18 02:22:00 +01:00
answer = new StringBuilder(answer.substring(1));
2018-07-06 15:30:00 +02:00
Poll poll = Emulator.getGameEnvironment().getPollManager().getPoll(pollId);
if(poll != null)
{
try (Connection connection = Emulator.getDatabase().getDataSource().getConnection(); PreparedStatement statement = connection.prepareStatement("INSERT INTO polls_answers(poll_id, user_id, question_id, answer) VALUES(?, ?, ?, ?) ON DUPLICATE KEY UPDATE answer=VALUES(answer)"))
{
statement.setInt(1, pollId);
statement.setInt(2, this.client.getHabbo().getHabboInfo().getId());
statement.setInt(3, questionId);
2019-03-18 02:22:00 +01:00
statement.setString(4, answer.toString());
2018-07-06 15:30:00 +02:00
statement.execute();
}
catch (SQLException e)
{
Emulator.getLogging().logSQLException(e);
}
if(poll.lastQuestionId == questionId)
{
2018-12-22 11:39:00 +01:00
if(poll.badgeReward.length() > 0)
2018-07-06 15:30:00 +02:00
{
2018-12-22 11:39:00 +01:00
if(this.client.getHabbo().getInventory().getBadgesComponent().getBadge(poll.badgeReward) == null)
2018-07-06 15:30:00 +02:00
{
2018-12-22 11:39:00 +01:00
HabboBadge badge = new HabboBadge(0, poll.badgeReward, 0, this.client.getHabbo());
2018-07-06 15:30:00 +02:00
Emulator.getThreading().run(badge);
this.client.getHabbo().getInventory().getBadgesComponent().addBadge(badge);
this.client.sendResponse(new AddUserBadgeComposer(badge));
this.client.sendResponse(new WiredRewardAlertComposer(WiredRewardAlertComposer.REWARD_RECEIVED_BADGE));
}
else
{
this.client.sendResponse(new WiredRewardAlertComposer(WiredRewardAlertComposer.REWARD_ALREADY_RECEIVED));
}
}
}
}
}
}