Jump to content
  • 0

Siege Reward for aCis


Question

Posted

Hello i'm creating this code for the clan that take the castle.

 

created rewardClanWinner () method in Player.java , sure he rewards the winning clan.

 

method:


    public Clan rewardClanWinner()
    {
        for (Player player : getClan().getOnlineMembers())
        {
            if (player.isClanLeader())
            {
                for (IntIntHolder reward : Config.LEADER_REWARD_WINNER_SIEGE_CLAN)                                    
                    player.addItem("", reward.getId(), reward.getValue(), player, true);    
            }
            else
            {
                for (IntIntHolder reward : Config.REWARD_WINNER_SIEGE_CLAN)                                    
                    player.addItem("", reward.getId(), reward.getValue(), player, true);                    
            } 
        }
        
        return _clan;
    }
    

After finishing the siege, I made a restriction of the same IP plus the 2 players of the same ip wins the item, what did I do wrong?

 

method created for SiegeEnd ()

 


        // Reward Clan winner
        getRewardClanWinner();
        
    private static final Map<String, Integer> _playerIps = new ConcurrentHashMap<>();
    
    public void getRewardClanWinner()
    {
        for (Player player : World.getInstance().getPlayers())
        {
            String pIp = player.getClient().getConnection().getInetAddress().getHostAddress();

            if (!_playerIps.containsKey(pIp))
            {
                _playerIps.put(pIp, 1);
                player.rewardClanWinner().setCastle(getCastle().getOwnerId());
            }
            else
            {
                int count = _playerIps.get(pIp);

                if (count < 1)
                {
                    _playerIps.remove(pIp);
                    _playerIps.put(pIp, count + 1);
                    player.rewardClanWinner().setCastle(getCastle().getOwnerId());
                }
                else
                    player.sendMessage("Already 1 character(s) of your ip have been rewarded, so this character won't be rewarded.");
            }
        }
    }
    

It does not only reward one as I write in the code.

2 answers to this question

Recommended Posts

  • 0
Posted (edited)
	public void getRewardClanWinner()
	{
		final List<String> playerIps = new ArrayList<>();
		
		for (Player player : World.getInstance().getPlayers())
		{
			final String pIp = player.getClient().getConnection().getInetAddress().getHostAddress();
			
			if (!playerIps.contains(pIp))
			{
				playerIps.add(pIp);
				player.rewardClanWinner();
			}
		}
	}
  • I don't think it's needed to say to someone who tried to exploit, he exploited. Simply avoid the behavior.
  • ArrayList because second parameter got no use.
  • No concurrency because no needs to remove or delete in same time than add, and only one iteration is called.
  • Inner container instead of class, because no use to keep retained info. Always keep variables in lowest scope possible.

 

Another thing, you should iterate MEMBERS of WINNING CLAN instead of World.getInstance().getPlayers() and rework rewardClanWinner accordingly. The easiest way is to add parameter Clan into getRewardClanWinner, and use it inside the method instead of World.getInstance().getPlayers() .

 

Another thing, you don't reward OFFLINE members. No clue why you wouldn't, since all ONLINE members probably didn't participate to siege. So you have to either keep track about who participated, or reward everyone (OFFLINE included).

Edited by Tryskell
  • Upvote 2
  • 0
Posted
7 hours ago, Tryskell said:

	public void getRewardClanWinner()
	{
		final List<String> playerIps = new ArrayList<>();
		
		for (Player player : World.getInstance().getPlayers())
		{
			final String pIp = player.getClient().getConnection().getInetAddress().getHostAddress();
			
			if (!playerIps.contains(pIp))
			{
				playerIps.add(pIp);
				player.rewardClanWinner();
			}
		}
	}
  • I don't think it's needed to say to someone who tried to exploit, he exploited. Simply avoid the behavior.
  • ArrayList because second parameter got no use.
  • No concurrency because no needs to remove or delete in same time than add, and only one iteration is called.
  • Inner container instead of class, because no use to keep retained info. Always keep variables in lowest scope possible.

 

Another thing, you should iterate MEMBERS of WINNING CLAN instead of World.getInstance().getPlayers() and rework rewardClanWinner accordingly. The easiest way is to add parameter Clan into getRewardClanWinner, and use it inside the method instead of World.getInstance().getPlayers() .

 

Another thing, you don't reward OFFLINE members. No clue why you wouldn't, since all ONLINE members probably didn't participate to siege. So you have to either keep track about who participated, or reward everyone (OFFLINE included).

 

I will do what you said, thanks. I'm your fan

:thumbs-up::broken-heart:

Join the conversation

You can post now and register later. If you have an account, sign in now to post with your account.
Note: Your post will require moderator approval before it will be visible.

Guest
Answer this question...

×   Pasted as rich text.   Paste as plain text instead

  Only 75 emoji are allowed.

×   Your link has been automatically embedded.   Display as a link instead

×   Your previous content has been restored.   Clear editor

×   You cannot paste images directly. Upload or insert images from URL.



  • Posts

    • https://prnt.sc/Bkkc0ShGXv9m https://prnt.sc/-JFLvZXsn27A
    • Hello guys want to sell adena in L2 Reborn Signature x1  Stock =14kk good price 
    • Hi guys, I have the following problem, I want to set up two servers on the same dedicated server and I can't.   L2jacis 409 Linux Server. The first gameserver has the following configuration: # ================================================================ # Gameserver setting # ================================================================ # This is transmitted to the clients, so it has to be an IP or resolvable hostname. If this ip is resolvable by Login just leave * Hostname = 190.25.103.103 # Bind ip of the gameserver, use * to bind on all available IPs. GameserverHostname = * GameserverPort = 7777 # The Loginserver host and port. LoginHost = 127.0.0.1 LoginPort = 9014 # This is the server id that the gameserver will request. RequestServerID = 1 # If set to true, the login will give an other id to the server (if the requested id is already reserved). AcceptAlternateID = True UseBlowfishCipher = True # ================================================================ # Database informations # ================================================================ URL = jdbc:mariadb://localhost/server1 Login = server1 Password = server1 I configured the second gameserver like this:   # ================================================================ # Gameserver setting # ================================================================ # This is transmitted to the clients, so it has to be an IP or resolvable hostname. If this ip is resolvable by Login just leave * Hostname = 0.0.0.0 # Bind ip of the gameserver, use * to bind on all available IPs. GameserverHostname = * GameserverPort = 7788 # The Loginserver host and port. LoginHost = 127.0.0.1 LoginPort = 9014 # This is the server id that the gameserver will request. RequestServerID = 2 # If set to true, the login will give an other id to the server (if the requested id is already reserved). AcceptAlternateID = True UseBlowfishCipher = True # ================================================================ # Database informations # ================================================================ URL = jdbc:mariadb://localhost/server2 Login = server2 Password = server2 apart from having tested 0.0.0.0 on the second gameserver I also tried 127.0.0.1 In both cases I see the two servers in the login when I log in, but I try to enter the one with the lowest ping and it kicks me out. The other server always appears with ping 9999 and I try to enter but it doesn't do anything and it freezes the login so I have to log in again. The hexids are in their respective folders. For server 1, it has its hexid inside the gameserver config folder, and I checked that the hexid id is the same id, for example id 1 in the gameserver is also id1 for server 1, and hexid 2 has its hexid 2 for server 2. The server ports are open and listening when I turn on both gameservers. I really don't know what could be wrong. If you could give me some help I would appreciate it. Excuse my English.
    • We have both old channels from 2006-2009 with the 3rd verification function enabled, and new ones.   For availability, please contact us below: Link - Telegram Link - Facebook WhatsApp - Click here to go to WhatsApp chat
    • You can contact me on skype: niedziolek50
  • Topics

×
×
  • Create New...