/******************************************************************************* * Copyright (C) 2013 JMaNGOS <http://jmangos.org/> * * 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 2 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 <http://www.gnu.org/licenses/>. ******************************************************************************/ package org.jmangos.realm.service; import java.util.HashMap; import java.util.List; import javax.annotation.PostConstruct; import org.jmangos.commons.dataholder.DataLoadService; import org.jmangos.commons.entities.PlayerLevelInfo; import org.jmangos.commons.entities.pk.PlayerLevelInfoPK; import org.jmangos.commons.enums.Classes; import org.jmangos.commons.enums.Races; import org.jmangos.world.services.PlayerLevelInfoService; import org.slf4j.Logger; import org.slf4j.LoggerFactory; import org.springframework.beans.factory.annotation.Autowired; import org.springframework.stereotype.Component; /** * The Class PlayerLevelStorages. */ @Component public class PlayerLevelStorages implements DataLoadService<HashMap<PlayerLevelInfoPK, PlayerLevelInfo>> { /** The Constant log. */ private static final Logger log = LoggerFactory.getLogger(PlayerLevelStorages.class); @Autowired PlayerLevelInfoService playerLevelInfoService; /** The Player Race Class Level info. */ private HashMap<PlayerLevelInfoPK, PlayerLevelInfo> playerRCLI = new HashMap<PlayerLevelInfoPK, PlayerLevelInfo>(); /** * * @see org.jmangos.commons.service.Service#start() */ @PostConstruct @Override public void start() { load(); log.info("Loaded " + this.playerRCLI.size() + " PlayerLevelInfos"); } /** * * @see org.jmangos.commons.service.Service#stop() */ @Override public void stop() { // TODO Auto-generated method stub } /** * * @see org.jmangos.commons.dataholder.DataLoadService#load() */ @Override public HashMap<PlayerLevelInfoPK, PlayerLevelInfo> load() { final HashMap<PlayerLevelInfoPK, PlayerLevelInfo> map = new HashMap<PlayerLevelInfoPK, PlayerLevelInfo>(); final List<PlayerLevelInfo> infoList = this.playerLevelInfoService.readPlayerLevelInfos(); for (final PlayerLevelInfo levelInfo : infoList) { map.put(levelInfo.getPlayerLevelInfoPK(), levelInfo); } return this.playerRCLI = map; } /** * * @see org.jmangos.commons.dataholder.DataLoadService#reload() */ @Override public void reload() { final HashMap<PlayerLevelInfoPK, PlayerLevelInfo> playerRCLITemp = new HashMap<PlayerLevelInfoPK, PlayerLevelInfo>(); final List<PlayerLevelInfo> infoList = this.playerLevelInfoService.readPlayerLevelInfos(); for (final PlayerLevelInfo levelInfo : infoList) { playerRCLITemp.put(levelInfo.getPlayerLevelInfoPK(), levelInfo); } this.playerRCLI = playerRCLITemp; } /** * * @see org.jmangos.commons.dataholder.DataLoadService#save() */ @Override public void save() { // TODO Auto-generated method stub } /** * * @see org.jmangos.commons.dataholder.DataLoadService#get() */ @Override public HashMap<PlayerLevelInfoPK, PlayerLevelInfo> get() { // TODO Auto-generated method stub return null; } /** * Gets the. * * @param race * the race * @param clazz * the clazz * @param level * the level * @return the player level info */ public PlayerLevelInfo get(final Races race, final Classes clazz, final int level) { final PlayerLevelInfoPK cl = new PlayerLevelInfoPK(race, clazz, level); if (this.playerRCLI.containsKey(cl)) { return this.playerRCLI.get(cl); } else { log.warn("can't find proper PlayerClassLevelInfo PCLI size: " + this.playerRCLI.size()); return null; } } }