Arcturus-Community/src/main/java/com/eu/habbo/messages/rcon/GiveBadge.java

108 lines
4.0 KiB
Java
Raw Normal View History

2018-07-06 15:30:00 +02:00
package com.eu.habbo.messages.rcon;
import com.eu.habbo.Emulator;
import com.eu.habbo.habbohotel.users.Habbo;
import com.eu.habbo.habbohotel.users.HabboBadge;
import com.eu.habbo.messages.outgoing.users.AddUserBadgeComposer;
import com.google.gson.Gson;
import java.sql.*;
public class GiveBadge extends RCONMessage<GiveBadge.GiveBadgeJSON>
{
2018-07-08 23:32:00 +02:00
2018-07-06 15:30:00 +02:00
public GiveBadge()
{
super(GiveBadgeJSON.class);
}
@Override
public void handle(Gson gson, GiveBadgeJSON json)
{
if (json.user_id == -1)
{
this.status = RCONMessage.HABBO_NOT_FOUND;
return;
}
if (json.badge.isEmpty())
{
this.status = RCONMessage.SYSTEM_ERROR;
return;
}
Habbo habbo = Emulator.getGameEnvironment().getHabboManager().getHabbo(json.user_id);
String username = json.user_id + "";
if(habbo != null)
{
username = habbo.getHabboInfo().getUsername();
for (String badgeCode : json.badge.split(";"))
{
if (habbo.getInventory().getBadgesComponent().hasBadge(badgeCode))
{
this.status = RCONMessage.STATUS_ERROR;
this.message += Emulator.getTexts().getValue("commands.error.cmd_badge.already_owned").replace("%user%", username).replace("%badge%", badgeCode) + "\r";
continue;
}
HabboBadge badge = new HabboBadge(0, badgeCode, 0, habbo);
badge.run();
habbo.getInventory().getBadgesComponent().addBadge(badge);
habbo.getClient().sendResponse(new AddUserBadgeComposer(badge));
this.message = Emulator.getTexts().getValue("commands.succes.cmd_badge.given").replace("%user%", username).replace("%badge%", badgeCode);
}
}
else
{
try (Connection connection = Emulator.getDatabase().getDataSource().getConnection())
{
for (String badgeCode : json.badge.split(";"))
{
boolean found = false;
try (PreparedStatement statement = connection.prepareStatement("SELECT COUNT(slot_id) FROM users_badges INNER JOIN users ON users.id = user_id WHERE users.id = ? AND badge_code = ? LIMIT 1"))
{
statement.setInt(1, json.user_id);
statement.setString(2, badgeCode);
try (ResultSet set = statement.executeQuery())
{
found = set.next();
}
}
if (found)
{
this.status = RCONMessage.STATUS_ERROR;
this.message += Emulator.getTexts().getValue("commands.error.cmd_badge.already_owns").replace("%user%", username).replace("%badge%", badgeCode) + "\r";
} else
{
try (PreparedStatement statement = connection.prepareStatement("INSERT INTO users_badges VALUES (null, (SELECT id FROM users WHERE users.id = ? LIMIT 1), 0, ?)", Statement.RETURN_GENERATED_KEYS))
{
statement.setInt(1, json.user_id);
statement.setString(2, badgeCode);
statement.execute();
}
this.message = Emulator.getTexts().getValue("commands.succes.cmd_badge.given").replace("%user%", username).replace("%badge%", badgeCode);
}
}
}
catch (SQLException e)
{
Emulator.getLogging().logSQLException(e);
this.status = RCONMessage.STATUS_ERROR;
this.message = e.getMessage();
}
}
}
public class GiveBadgeJSON
{
public int user_id = -1;
public String badge;
}
}