Faction admins can now disband their own faction using /f disband; note that use of /f disband with another faction specified (/f disband <faction tag>) still requires the factions.disband permission, but the permission is not required for faction admins disbanding their own faction
This commit is contained in:
		
							parent
							
								
									120039b07f
								
							
						
					
					
						commit
						632e2b2d1c
					
				| @ -1,12 +1,12 @@ | |||||||
| package com.massivecraft.factions.commands; | package com.massivecraft.factions.commands; | ||||||
| 
 | 
 | ||||||
| import org.bukkit.command.CommandSender; |  | ||||||
| 
 |  | ||||||
| import com.massivecraft.factions.Conf; | import com.massivecraft.factions.Conf; | ||||||
| import com.massivecraft.factions.Faction; | import com.massivecraft.factions.Faction; | ||||||
| import com.massivecraft.factions.Factions; | import com.massivecraft.factions.Factions; | ||||||
| import com.massivecraft.factions.FPlayer; | import com.massivecraft.factions.FPlayer; | ||||||
| import com.massivecraft.factions.SpoutFeatures; | import com.massivecraft.factions.SpoutFeatures; | ||||||
|  | import com.massivecraft.factions.struct.Role; | ||||||
|  | 
 | ||||||
| 
 | 
 | ||||||
| public class FCommandDisband extends FBaseCommand { | public class FCommandDisband extends FBaseCommand { | ||||||
| 	 | 	 | ||||||
| @ -15,26 +15,45 @@ public class FCommandDisband extends FBaseCommand { | |||||||
| 		 | 		 | ||||||
| 		senderMustBePlayer = false; | 		senderMustBePlayer = false; | ||||||
| 		 | 		 | ||||||
| 		requiredParameters.add("faction tag"); | 		optionalParameters.add("faction tag"); | ||||||
| 		 | 		 | ||||||
| 		helpDescription = "Disband a faction"; | 		helpDescription = "Disband a faction"; | ||||||
| 	} | 	} | ||||||
| 	 | 	 | ||||||
| 	@Override |  | ||||||
| 	public boolean hasPermission(CommandSender sender) { |  | ||||||
| 		return Factions.hasPermDisband(sender); |  | ||||||
| 	} |  | ||||||
| 	 |  | ||||||
| 	@Override | 	@Override | ||||||
| 	public void perform() { | 	public void perform() { | ||||||
|  | 
 | ||||||
|  | 		Faction faction = null; | ||||||
|  | 
 | ||||||
| 		if( parameters.size() > 0) { | 		if( parameters.size() > 0) { | ||||||
| 			Faction faction = Faction.findByTag(parameters.get(0)); | 			faction = Faction.findByTag(parameters.get(0)); | ||||||
| 			 | 			 | ||||||
| 			if( faction == null || !faction.isNormal()) { | 			if( faction == null || !faction.isNormal()) { | ||||||
| 				sendMessage("Faction " + parameters.get(0) + "not found"); | 				sendMessage("Faction \"" + parameters.get(0) + "\" not found"); | ||||||
| 				return; | 				return; | ||||||
| 			} | 			} | ||||||
| 
 | 
 | ||||||
|  | 			if ( ! Factions.hasPermDisband(sender)) { | ||||||
|  | 				if (me.getFaction() == faction) { | ||||||
|  | 					parameters.clear(); | ||||||
|  | 				} | ||||||
|  | 				else { | ||||||
|  | 					sendMessage("You do not have sufficient permission to disband other factions."); | ||||||
|  | 					return; | ||||||
|  | 				} | ||||||
|  | 			} | ||||||
|  | 		} | ||||||
|  | 		if (parameters.isEmpty()) { | ||||||
|  | 			if ( ! assertHasFaction()) { | ||||||
|  | 				return; | ||||||
|  | 			} | ||||||
|  | 			if ( ! assertMinRole(Role.ADMIN)) { | ||||||
|  | 				return; | ||||||
|  | 			} | ||||||
|  | 
 | ||||||
|  | 			faction = me.getFaction(); | ||||||
|  | 		} | ||||||
|  | 
 | ||||||
| 		// Inform all players | 		// Inform all players | ||||||
| 		for (FPlayer fplayer : FPlayer.getAllOnline()) { | 		for (FPlayer fplayer : FPlayer.getAllOnline()) { | ||||||
| 			if (fplayer.getFaction() == faction) { | 			if (fplayer.getFaction() == faction) { | ||||||
| @ -45,7 +64,6 @@ public class FCommandDisband extends FBaseCommand { | |||||||
| 		} | 		} | ||||||
| 		Faction.delete( faction.getId() ); | 		Faction.delete( faction.getId() ); | ||||||
| 		SpoutFeatures.updateAppearances(); | 		SpoutFeatures.updateAppearances(); | ||||||
| 		} |  | ||||||
| 	} |  | ||||||
| 
 | 
 | ||||||
| 	} | 	} | ||||||
|  | } | ||||||
|  | |||||||
		Loading…
	
		Reference in New Issue
	
	Block a user