Added commands to delete and add ranks, set spawn, and added check for wether a player is in a faction or not

This commit is contained in:
shamoanjac 2016-08-07 19:22:31 +02:00
parent 418f67ff7e
commit 1145203353
2 changed files with 110 additions and 15 deletions

View File

@ -30,6 +30,7 @@ factionsmod.register_command = function(cmd_name, cmd)
faction_permissions = {}, faction_permissions = {},
global_privileges = {}, global_privileges = {},
format = {}, format = {},
infaction = true,
description = "This command has no description.", description = "This command has no description.",
run = function(self, player, argv) run = function(self, player, argv)
-- check global privileges -- check global privileges
@ -79,9 +80,14 @@ factionsmod.register_command = function(cmd_name, cmd)
table.insert(args.other, argv[i]) table.insert(args.other, argv[i])
end end
-- checks permissions -- checks if player in faction
local player_faction = factionsmod.players[faction] local player_faction = factionsmod.players[faction]
if not player_faction and self.infaction then
--TODO: error message
return false
end
-- checks permissions
if #faction_permissions > 1 and not player_faction then if #faction_permissions > 1 and not player_faction then
minetest.chat_send_player(player, "You are not part of any faction") minetest.chat_send_player(player, "You are not part of any faction")
return false return false
@ -205,10 +211,7 @@ factionsmod.register_command("list", {
factionsmod.register_command("version", { factionsmod.register_command("version", {
description = "Displays mod version.", description = "Displays mod version.",
on_success = function(player, faction, pos, chunkpos, args) on_success = function(player, faction, pos, chunkpos, args)
if cmd == "version" then
minetest.chat_send_player(player, "factionsmod: version " .. factionsmod_version , false) minetest.chat_send_player(player, "factionsmod: version " .. factionsmod_version , false)
return true
end
end end
}) })
@ -227,12 +230,7 @@ factionsmod.register_command("info", {
factionsmod.register_command("leave", { factionsmod.register_command("leave", {
description = "Leave your faction." description = "Leave your faction."
on_success = function(player, faction, pos, chunkpos, args) on_success = function(player, faction, pos, chunkpos, args)
if faction then
faction:remove_player(player) faction:remove_player(player)
else
--TODO: error (not in a faction)
return false
end
--TODO: message? --TODO: message?
return true return true
end end
@ -259,6 +257,7 @@ factionsmod.register_command("kick", {
--create new faction --create new faction
factionsmod.register_command("create", { factionsmod.register_command("create", {
format = {"string"}, format = {"string"},
infaction = false,
description = "Create a new faction.", description = "Create a new faction.",
on_success = function(player, faction, pos, chunkpos, args) on_success = function(player, faction, pos, chunkpos, args)
if faction then if faction then
@ -281,6 +280,7 @@ factionsmod.register_command("create", {
factionsmod.register_commmand("join", { factionsmod.register_commmand("join", {
format = {"faction"}, format = {"faction"},
description = "Join a faction.", description = "Join a faction.",
infaction = false,
on_success = function(player, faction, pos, chunkpos, args) on_success = function(player, faction, pos, chunkpos, args)
local new_faction = args.factions[1] local new_faction = args.factions[1]
if new_faction:can_join(player) then if new_faction:can_join(player) then
@ -370,6 +370,74 @@ factionsmod.register_command("delete", {
end end
}) })
factionsmod.register_command("ranks", {
description = "List ranks within your faction",
on_success = function(player, faction, pos, chunkpos, args)
if not faction then
--TODO: error message
return false
end
for rank, permissions in pairs(faction.ranks) do
minetest.chat_send_player(player:get_player_name(), rank..": "..table.concat(permissions, " "))
end
return true
end
})
factionsmod.register_command("who", {
description = "List players in your faction, and their ranks.",
on_success = function(player, faction, pos, chunkpos, args)
if not faction then
--TODO: error message
return false
end
for player, rank in ipairs(faction.players) do
minetest.chat_send_player(player:get_player_name(), player.." ("..rank..")")
end
return true
end
})
factionsmod.register_command("newrank", {
description = "Add a new rank.",
format = {"string"},
faction_permissions = {"ranks"},
on_success = function(player, faction, pos, chunkpos, args)
local rank = args.strings[1]
if faction.ranks[rank] then
--TODO: rank already exists
return false
end
faction:new_rank(rank, args.other)
return true
end
})
factionsmod.register_command("delrank", {
description = "Replace and delete a rank.",
format = {"string", "string"},
faction_permissions = {"ranks"},
on_success = function(player, faction, pos, chunkpos, args)
local rank = args.strings[1]
local newrank = args.string[2]
if not faction.ranks[rank] or not faction.ranks[rank] then
--TODO: error (one of either ranks do not exist)
return false
end
faction:delete_rank(rank, newrank)
return true
end
})
factionsmod.register_command("setspawn", {
description = "Set the faction's spawn",
faction_permissions = {"spawn"},
on_success = function(player, faction, pos, chunkpos, args)
faction:set_spawn(pos)
return true
end
})
------------------------------------------------------------------------------- -------------------------------------------------------------------------------
-- name: cmdhandler(playername,parameter) -- name: cmdhandler(playername,parameter)
-- --

View File

@ -53,7 +53,7 @@ factionsmod.new_faction = function(name)
name = name, name = name,
power = 0., power = 0.,
players = {}, players = {},
ranks = {["leader"] = {"disband", "claim", "playerlist", "build", "edit"}, ranks = {["leader"] = {"disband", "claim", "playerlist", "build", "edit", "ranks"},
["member"] = {"build"} ["member"] = {"build"}
}, },
leader = nil, leader = nil,
@ -64,7 +64,8 @@ factionsmod.new_faction = function(name)
land = {}, land = {},
allies = {}, allies = {},
enemies = {}, enemies = {},
join_free = false join_free = false,
spawn = nil,
---------------------- ----------------------
-- methods -- methods
@ -157,7 +158,24 @@ factionsmod.new_faction = function(name)
end, end,
end_enemy = function(self, faction) end_enemy = function(self, faction)
self.enemies[faction] = nil self.enemies[faction] = nil
self:on_end_enemy[faction] self:on_end_enemy(faction)
end,
set_spawn = function(self, pos)
self.spawn = pos
self:on_set_spawn()
end,
add_rank = function(self, rank, perms)
self.ranks[rank] = perms
self:on_new_rank(rank)
end,
delete_rank = function(self, rank, newrank)
for player, r in pairs(self.players) do
if r == rank then
self.players[player] = newrank
end
end
self.ranks[rank] = nil
self:on_delete_rank(rank, newrank)
end, end,
----------------------- -----------------------
@ -198,6 +216,15 @@ factionsmod.new_faction = function(name)
on_end_alliance = function(self, faction) on_end_alliance = function(self, faction)
--TODO: implement --TODO: implement
end, end,
on_set_spawn = function(self)
--TODO: implement
end,
on_add_rank = function(self, rank)
--TODO: implement
end,
on_delete_rank = function(self, rank, newrank)
--TODO: implement
end,
} }
factionsmod[name] = faction factionsmod[name] = faction
return faction return faction