mirror of
https://git.krews.org/morningstar/Arcturus-Community.git
synced 2024-10-24 11:43:06 +02:00
114 lines
4.2 KiB
Java
114 lines
4.2 KiB
Java
|
package com.eu.habbo.messages.rcon;
|
||
|
|
||
|
import com.eu.habbo.Emulator;
|
||
|
import com.eu.habbo.habbohotel.rooms.RoomChatMessage;
|
||
|
import com.eu.habbo.habbohotel.rooms.RoomChatMessageBubbles;
|
||
|
import com.eu.habbo.habbohotel.users.Habbo;
|
||
|
import com.eu.habbo.habbohotel.users.HabboBadge;
|
||
|
import com.eu.habbo.messages.outgoing.rooms.users.RoomUserWhisperComposer;
|
||
|
import com.eu.habbo.messages.outgoing.users.AddUserBadgeComposer;
|
||
|
import com.google.gson.Gson;
|
||
|
|
||
|
import java.sql.*;
|
||
|
|
||
|
public class GiveBadge extends RCONMessage<GiveBadge.GiveBadgeJSON>
|
||
|
{
|
||
|
/**
|
||
|
* Sends a badge to an user.
|
||
|
* Insers it if the user is not found.
|
||
|
*/
|
||
|
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;
|
||
|
}
|
||
|
}
|