/* * This program is free software: you can redistribute it and/or modify it under * the terms of the GNU General Public License as published by the Free Software * Foundation, either version 3 of the License, or (at your option) any later * version. * * This program is distributed in the hope that it will be useful, but WITHOUT * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or FITNESS * FOR A PARTICULAR PURPOSE. See the GNU General Public License for more * details. * * You should have received a copy of the GNU General Public License along with * this program. If not, see . */ package com.l2jserver.gameserver.model.itemcontainer; import java.sql.Connection; import java.sql.PreparedStatement; import java.sql.ResultSet; import java.util.logging.Level; import com.l2jserver.L2DatabaseFactory; import com.l2jserver.gameserver.model.L2ItemInstance; import com.l2jserver.gameserver.model.L2ItemInstance.ItemLocation; import com.l2jserver.gameserver.model.L2World; import com.l2jserver.gameserver.model.actor.instance.L2PcInstance; /** * * @author DS * */ public class Mail extends ItemContainer { private final int _ownerId; private int _messageId; public Mail(int objectId, int messageId) { _ownerId = objectId; _messageId = messageId; } @Override public String getName() { return "Mail"; } @Override public L2PcInstance getOwner() { return null; } @Override public ItemLocation getBaseLocation() { return ItemLocation.MAIL; } public int getMessageId() { return _messageId; } public void setNewMessageId(int messageId) { _messageId = messageId; for (L2ItemInstance item : _items) { if (item == null) continue; item.setLocation(getBaseLocation(), messageId); } updateDatabase(); } public void returnToWh(ItemContainer wh) { for (L2ItemInstance item : _items) { if (item == null) continue; if (wh == null) item.setLocation(ItemLocation.WAREHOUSE); else transferItem("Expire", item.getObjectId(), item.getCount(), wh, null, null); } } @Override protected void addItem(L2ItemInstance item) { super.addItem(item); item.setLocation(getBaseLocation(), _messageId); } /* * Allow saving of the items without owner */ @Override public void updateDatabase() { for (L2ItemInstance item : _items) { if (item != null) { item.updateDatabase(true); } } } @Override public void restore() { Connection con = null; PreparedStatement statement = null; try { con = L2DatabaseFactory.getInstance().getConnection(); statement = con.prepareStatement("SELECT object_id, item_id, count, enchant_level, loc, loc_data, custom_type1, custom_type2, mana_left, time FROM items WHERE owner_id=? AND loc=? AND loc_data=?"); statement.setInt(1, getOwnerId()); statement.setString(2, getBaseLocation().name()); statement.setInt(3, getMessageId()); ResultSet inv = statement.executeQuery(); L2ItemInstance item; while (inv.next()) { item = L2ItemInstance.restoreFromDb(getOwnerId(), inv); if (item == null) continue; L2World.getInstance().storeObject(item); // If stackable item is found just add to current quantity if (item.isStackable() && getItemByItemId(item.getItemId()) != null) addItem("Restore", item, null, null); else addItem(item); } statement.close(); } catch (Exception e) { _log.log(Level.WARNING, "could not restore container:", e); } finally { L2DatabaseFactory.close(con); } } @Override public int getOwnerId() { return _ownerId; } }