Compare commits
	
		
			12 Commits
		
	
	
		
			e0783cf8bf
			...
			76f8ccf8ab
		
	
	| Author | SHA1 | Date | |
|---|---|---|---|
| 76f8ccf8ab | |||
| 02b23b0371 | |||
|  | 4018c0d204 | ||
|  | c167b30ebf | ||
| 4eeb2a9d11 | |||
|  | a9c05f0e38 | ||
| 99408df96a | |||
| 42cde6a494 | |||
|  | c4d0fe020f | ||
|  | b0c229d80a | ||
|  | d7fba610a1 | ||
|  | 2a56743f65 | 
| @@ -10,7 +10,7 @@ read_globals = { | ||||
| 	"AreaStore", | ||||
| 	"default", | ||||
| 	"factions", | ||||
| 	table = { fields = { "copy", "getn" } } | ||||
| 	table = { fields = { "copy", "getn", "indexof" } } | ||||
| } | ||||
|  | ||||
| globals = { | ||||
|   | ||||
							
								
								
									
										15
									
								
								README.md
									
									
									
									
									
								
							
							
						
						
									
										15
									
								
								README.md
									
									
									
									
									
								
							| @@ -5,6 +5,11 @@ Dependencies | ||||
| ------------ | ||||
|  | ||||
| Minetest 5.0.0+ is recommended, but 0.4.16+ should work as well. | ||||
| Minetest 5.0.0+ | ||||
|  | ||||
| Optional support for following mods: | ||||
|  | ||||
|   * [playerfactions](https://git.leagueh.xyz/katp32/playerfactions/) by [katp32](https://git.leagueh.xyz/katp32) & [Kalio_42](https://git.leagueh.xyz/Kalio_42) | ||||
|  | ||||
|  | ||||
| Configuration | ||||
| @@ -105,10 +110,18 @@ Commands | ||||
|   * `/areas_cleanup` -- Removes all ownerless areas. | ||||
| 	Useful for cleaning after user deletion, for example using /remove_player. | ||||
|  | ||||
|   * `/area_open <ID>` -- Toggle open/closed the specified area for everyone. | ||||
|  | ||||
|   * `/area_faction_open <ID> <faction>` -- Toggle open/closed the specified | ||||
| 	area for members of the faction. Factions are created and managed by | ||||
| 	playerfactions mod. | ||||
|  | ||||
| License | ||||
| ------- | ||||
|  | ||||
| Copyright (C) 2013 ShadowNinja | ||||
| Copyright (C) 2013-2017 ShadowNinja | ||||
|  | ||||
| Copyright (C) 2015-2020 various contributors | ||||
|  | ||||
| Licensed under the GNU LGPL version 2.1 or later. | ||||
| See LICENSE.txt and http://www.gnu.org/licenses/lgpl-2.1.txt | ||||
|   | ||||
							
								
								
									
										37
									
								
								api.lua
									
									
									
									
									
								
							
							
						
						
									
										37
									
								
								api.lua
									
									
									
									
									
								
							| @@ -2,12 +2,21 @@ local hudHandlers = {} | ||||
|  | ||||
| ---plants to place in openfarming | ||||
| local plants = { | ||||
| 	["farming:blueberries"]="air", ["farming:carrot"]="air", ["farming:coffee_beans"]="air", | ||||
| 	["farming:corn"]="air", ["farming:cucumber"]="air", ["farming:melon_slice"]="air", | ||||
| 	["farming:beetroot"]="air", ["farming:blueberries"]="air", ["farming:cabbage"]="air", | ||||
| 	["farming:carrot"]="air", ["farming:chili_pepper"]="air", ["farming:coffee_beans"]="air", | ||||
| 	["farming:corn"]="air", ["farming:cucumber"]="air", ["farming:garlic_clove"]="air", | ||||
| 	["farming:melon_slice"]="air", ["farming:onion"]="air", ["default:papyrus"]="air", | ||||
| 	["farming:pea_pod"]="air",	["farming:peppercorn"]="air", ["farming:pineapple_top"]="air", | ||||
| 	["farming:potato"]="air", ["farming:pumpkin_slice"]="air", ["farming:raspberries"]="air", | ||||
| 	["farming:rhubarb"]="air",	["farming:tomato"]="air", ["farming:seed_cotton"]="air", | ||||
| 	["farming:seed_wheat"]="air",["default:papyrus"]="air", ["farming:trellis"]="air", | ||||
| 	["farming:grapes"]="farming:trellis", ["farming:beanpole"]="air", ["farming:beans"]="farming:beanpole", | ||||
| 	["farming:rhubarb"]="air", | ||||
| 	["farming:seed_barley"]="air", ["farming:seed_cotton"]="air", ["farming:seed_hemp"]="air", | ||||
| 	["farming:seed_mint"]="air", ["farming:seed_oat"]="air", ["farming:seed_rice"]="air", | ||||
| 	["farming:seed_rye"]="air", ["farming:seed_wheat"]="air", | ||||
| 	["farming:tomato"]="air", | ||||
| 	["farming:trellis"]="air", ["farming:grapes"]="farming:trellis", | ||||
| 	["farming:beanpole"]="air", ["farming:beans"]="farming:beanpole", | ||||
| 	["morefarming:seed_wildcarrot"]="air", ["morefarming:seed_teosinte"]="air", | ||||
| 	["morefarming:seed_carrot"]="air", ["morefarming:seed_corn"]="air", | ||||
| } | ||||
|  | ||||
| areas.registered_on_adds = {} | ||||
| @@ -120,9 +129,21 @@ function areas:canInteract(pos, name) | ||||
| 				return true | ||||
| 			end | ||||
| 		elseif areas.factions_available and area.faction_open then | ||||
| 			local faction_name = factions.get_player_faction(area.owner) | ||||
| 			if faction_name ~= nil and faction_name == factions.get_player_faction(name) then | ||||
| 				return true | ||||
| 			if (factions.version or 0) < 2 then | ||||
| 				local faction_name = factions.get_player_faction(name) | ||||
| 				if faction_name then | ||||
| 					for _, fname in ipairs(area.faction_open or {}) do | ||||
| 						if faction_name == fname then | ||||
| 							return true | ||||
| 						end | ||||
| 					end | ||||
| 				end | ||||
| 			else | ||||
| 				for _, fname in ipairs(area.faction_open or {}) do | ||||
| 					if factions.player_is_in_faction(fname, name) then | ||||
| 						return true | ||||
| 					end | ||||
| 				end | ||||
| 			end | ||||
| 		end | ||||
| 		owned = true | ||||
|   | ||||
| @@ -308,11 +308,15 @@ minetest.register_chatcommand( | ||||
|  | ||||
| if areas.factions_available then | ||||
| 	minetest.register_chatcommand("area_faction_open", { | ||||
| 		params = S("<ID>"), | ||||
| 		params = S("<ID> [faction_name]"), | ||||
| 		description = S("Toggle an area open/closed for members in your faction."), | ||||
| 		func = function(name, param) | ||||
| 			local id = tonumber(param) | ||||
| 			if not id then | ||||
| 			local params = param:split(" ") | ||||
|  | ||||
| 			local id = tonumber(params[1]) | ||||
| 			local faction_name = params[2] | ||||
|  | ||||
| 			if not id or not faction_name then | ||||
| 				return false, S("Invalid usage, see /help @1.", "area_faction_open") | ||||
| 			end | ||||
|  | ||||
| @@ -320,11 +324,25 @@ if areas.factions_available then | ||||
| 				return false, S("Area @1 does not exist" | ||||
| 						.." or is not owned by you.", id) | ||||
| 			end | ||||
| 			local open = not areas.areas[id].faction_open | ||||
| 			-- Save false as nil to avoid inflating the DB. | ||||
| 			areas.areas[id].faction_open = open or nil | ||||
|  | ||||
| 			if not factions.get_owner(faction_name) then | ||||
| 				return false, S("Faction doesn't exists") | ||||
| 			end | ||||
| 			local fnames = areas.areas[id].faction_open or {} | ||||
| 			local pos = table.indexof(fnames, faction_name) | ||||
| 			if pos < 0 then | ||||
| 				-- Add new faction to the list | ||||
| 				table.insert(fnames, faction_name) | ||||
| 			else | ||||
| 				table.remove(fnames, pos) | ||||
| 			end | ||||
| 			if #fnames == 0 then | ||||
| 				-- Save {} as nil to avoid inflating the DB. | ||||
| 				fnames = nil | ||||
| 			end | ||||
| 			areas.areas[id].faction_open = fnames | ||||
| 			areas:save() | ||||
| 			return true, open and S("Area opened for faction members.") | ||||
| 			return true, fnames and S("Area is open for members of: @1", table.concat(fnames, ", ")) | ||||
| 				or S("Area closed for faction members.") | ||||
| 		end | ||||
| 	}) | ||||
|   | ||||
							
								
								
									
										25
									
								
								hud.lua
									
									
									
									
									
								
							
							
						
						
									
										25
									
								
								hud.lua
									
									
									
									
									
								
							| @@ -20,9 +20,28 @@ minetest.register_globalstep(function(dtime) | ||||
| 		local areaStrings = {} | ||||
|  | ||||
| 		for id, area in pairs(areas:getAreasAtPos(pos)) do | ||||
| 			local faction_info = area.faction_open and areas.factions_available and | ||||
| 					factions.get_player_faction(area.owner) | ||||
| 			area.faction_open = faction_info | ||||
| 			local faction_info | ||||
| 			if area.faction_open and areas.factions_available then | ||||
| 				-- Gather and clean up disbanded factions | ||||
| 				local changed = false | ||||
| 				for i, fac_name in ipairs(area.faction_open) do | ||||
| 					if not factions.get_owner(fac_name) then | ||||
| 						table.remove(area.faction_open, i) | ||||
| 						changed = true | ||||
| 					end | ||||
| 				end | ||||
| 				if #area.faction_open == 0 then | ||||
| 					-- Prevent DB clutter, remove value | ||||
| 					area.faction_open = nil | ||||
| 				else | ||||
| 					faction_info = table.concat(area.faction_open, ", ") | ||||
| 				end | ||||
|  | ||||
| 				if changed then | ||||
| 					areas:save() | ||||
| 				end | ||||
| 			end | ||||
|  | ||||
| 			table.insert(areaStrings, ("%s [%u] (%s%s%s)") | ||||
| 					:format(area.name, id, area.owner, | ||||
| 					area.open and S(":open") or area.openfarming and ":openfarming" or "", | ||||
|   | ||||
							
								
								
									
										12
									
								
								init.lua
									
									
									
									
									
								
							
							
						
						
									
										12
									
								
								init.lua
									
									
									
									
									
								
							| @@ -4,7 +4,7 @@ | ||||
|  | ||||
| areas = {} | ||||
|  | ||||
| areas.factions_available = minetest.global_exists("factions") | ||||
| areas.factions_available = minetest.get_modpath("playerfactions") and true | ||||
|  | ||||
| areas.adminPrivs = {areas=true} | ||||
| areas.startTime = os.clock() | ||||
| @@ -21,11 +21,15 @@ dofile(areas.modpath.."/hud.lua") | ||||
|  | ||||
| areas:load() | ||||
|  | ||||
| local S = minetest.get_translator("areas") | ||||
|  | ||||
| minetest.register_privilege("areas", { | ||||
| 	description = "Can administer areas." | ||||
| 	description = S("Can administer areas."), | ||||
| 	give_to_singleplayer = false | ||||
| }) | ||||
| minetest.register_privilege("areas_high_limit", { | ||||
| 	description = "Can protect more, bigger areas." | ||||
| 	description = S("Can protect more, bigger areas."), | ||||
| 	give_to_singleplayer = false | ||||
| }) | ||||
| -- Mega_builder privilege -- MFF | ||||
| minetest.register_privilege("megabuilder", { | ||||
| @@ -34,7 +38,7 @@ minetest.register_privilege("megabuilder", { | ||||
|  | ||||
| if not minetest.registered_privileges[areas.config.self_protection_privilege] then | ||||
| 	minetest.register_privilege(areas.config.self_protection_privilege, { | ||||
| 		description = "Can protect areas.", | ||||
| 		description = S("Can protect areas."), | ||||
| 	}) | ||||
| end | ||||
|  | ||||
|   | ||||
							
								
								
									
										13
									
								
								internal.lua
									
									
									
									
									
								
							
							
						
						
									
										13
									
								
								internal.lua
									
									
									
									
									
								
							| @@ -18,7 +18,7 @@ end | ||||
|  | ||||
| -- Save the areas table to a file | ||||
| function areas:save() | ||||
| 	local datastr = minetest.serialize(self.areas) | ||||
| 	local datastr = minetest.write_json(self.areas) | ||||
| 	if not datastr then | ||||
| 		minetest.log("error", "[areas] Failed to serialize area data!") | ||||
| 		return | ||||
| @@ -33,10 +33,19 @@ function areas:load() | ||||
| 		self.areas = self.areas or {} | ||||
| 		return err | ||||
| 	end | ||||
| 	self.areas = minetest.deserialize(file:read("*a")) | ||||
| 	local data = file:read("*a") | ||||
| 	if data:sub(1, 1) == "[" then | ||||
| 		self.areas, err = minetest.parse_json(data) | ||||
| 	else | ||||
| 		self.areas, err = minetest.deserialize(data) | ||||
| 	end | ||||
| 	if type(self.areas) ~= "table" then | ||||
| 		self.areas = {} | ||||
| 	end | ||||
| 	if err and #data > 10 then | ||||
| 		minetest.log("error", "[areas] Failed to load area data: " .. | ||||
| 			tostring(err)) | ||||
| 	end | ||||
| 	file:close() | ||||
| 	self:populateStore() | ||||
| end | ||||
|   | ||||
| @@ -1,9 +1,11 @@ | ||||
| # textdomain: areas | ||||
|  | ||||
|  | ||||
|  | ||||
| ### chatcommands.lua ### | ||||
|  | ||||
| <AreaName>=<NomZone> | ||||
| <ID> [faction_name]=<ID> [nom_de_faction] | ||||
| <NewOwner>=<NouveauPropriétaire> | ||||
| <ParentID>=<IDZonePrincipale> | ||||
| <PlayerName>=<NomJoueur> | ||||
| @@ -15,12 +17,13 @@ Area @1 does not exist or is not owned by you.=La zone @1 n’existe pas ou ne v | ||||
| Area closed for faction members.=Zone fermée aux membres de la faction. | ||||
| Area closed.=Zone fermée. | ||||
| Area does not exist.=La zone n’existe pas. | ||||
| Area opened for faction members.=Zone ouverte aux membres de la faction. | ||||
| Area is open for members of: @1=Zone ouverte aux membres de ces factions : @1 | ||||
| Area opened.=Zone ouverte. | ||||
| Area protected. ID: @1=Zone protégée. ID : @1 | ||||
| Area renamed.=Zone renommée. | ||||
| Area successfully moved.=Zone déplacée avec succès. | ||||
| Change the owner of an area using its ID=Change le propriétaire d’une zone en utilisant son ID. | ||||
| Faction doesn't exists=La faction n'existe pas | ||||
| Find areas using a Lua regular expression=Trouve les zones en utilisant une expression régulière Lua. | ||||
| Get information about area configuration and usage.=Obtient des informations sur la configuration des zones et l’utilisation des zones. | ||||
|  | ||||
| @@ -43,6 +46,7 @@ Recursively remove areas using an ID=Supprime les zones récursivement en utilis | ||||
| Remove an area using an ID=Supprime une zone en utilisant son ID. | ||||
| Removed area @1=Zone @1 supprimée. | ||||
| Removed area @1 and it's sub areas.=Zone @1 et ses sous-zones supprimées. | ||||
| Removes all ownerless areas=Supprime toutes les zones sans propriétaire | ||||
| Rename an area that you own=Renomme une zone qui vous appartient. | ||||
| Self protection is disabled.=L’autoprotection est désactivée. | ||||
| Self protection is enabled.=L’autoprotection est activée. | ||||
| @@ -76,6 +80,12 @@ Invalid usage, see /help @1.=Utilisation incorrecte, voir /help @1. | ||||
| :open= : ouverte | ||||
| Areas:=Zones : | ||||
|  | ||||
| ### init.lua ### | ||||
|  | ||||
| Can administer areas.=Permet d’administrer des zones. | ||||
| Can protect areas.=Permet de protéger des zones. | ||||
| Can protect more, bigger areas.=Permet de protéger plus, et de plus grandes zones. | ||||
|  | ||||
| ### interact.lua ### | ||||
|  | ||||
| @1 is protected by @2.=@1 est protégée par @2. | ||||
|   | ||||
| @@ -1,9 +1,11 @@ | ||||
| # textdomain: areas | ||||
|  | ||||
|  | ||||
|  | ||||
| ### chatcommands.lua ### | ||||
|  | ||||
| <AreaName>=<NomeArea> | ||||
| <ID> [faction_name]= <ID> [nome_fazione] | ||||
| <NewOwner>=<NuovoProprietario> | ||||
| <ParentID>=<IDparent> | ||||
| <PlayerName>=<NomeGiocatore> | ||||
| @@ -15,12 +17,13 @@ Area @1 does not exist or is not owned by you.=L'area @1 non esiste o non è di | ||||
| Area closed for faction members.=Area chiusa per i membri della fazione. | ||||
| Area closed.=Area chiusa. | ||||
| Area does not exist.=L'area non esiste. | ||||
| Area opened for faction members.=Area aperta per i membri della fazione. | ||||
| Area is open for members of: @1=L'area è aperta ai membri di: @1 | ||||
| Area opened.=Area aperta. | ||||
| Area protected. ID: @1=Area protetta. ID: @1 | ||||
| Area renamed.=Area rinominata. | ||||
| Area successfully moved.=Area spostata con successo. | ||||
| Change the owner of an area using its ID=Cambia il proprietario di un'area usando il suo ID | ||||
| Faction doesn't exists=La fazione non esiste | ||||
| Find areas using a Lua regular expression=Trova aree usando una espressione regolare Lua | ||||
| Get information about area configuration and usage.=Ottieni informazioni sulla configurazione e l'uso delle aree. | ||||
|  | ||||
| @@ -43,6 +46,7 @@ Recursively remove areas using an ID=Elimina ricorsivamente delle aree usando un | ||||
| Remove an area using an ID=Elimina un'area usando un ID | ||||
| Removed area @1=Eliminata l'area @1 | ||||
| Removed area @1 and it's sub areas.=Eliminata l'area @1 e le sue sotto-aree. | ||||
| Removes all ownerless areas= | ||||
| Rename an area that you own=Rinomina un'area che ti appartiene | ||||
| Self protection is disabled.=L'auto-protezione è disattivata. | ||||
| Self protection is enabled.=L'auto-protezione è attivata. | ||||
| @@ -76,6 +80,12 @@ Invalid usage, see /help @1.=Utilizzo non valido, si veda /help @1. | ||||
| :open=:aperta | ||||
| Areas:=Aree: | ||||
|  | ||||
| ### init.lua ### | ||||
|  | ||||
| Can administer areas.= | ||||
| Can protect areas.= | ||||
| Can protect more, bigger areas.= | ||||
|  | ||||
| ### interact.lua ### | ||||
|  | ||||
| @1 is protected by @2.=@1 è protetta da @2. | ||||
|   | ||||
| @@ -1,9 +1,11 @@ | ||||
| # textdomain: areas | ||||
|  | ||||
|  | ||||
|  | ||||
| ### chatcommands.lua ### | ||||
|  | ||||
| <AreaName>= | ||||
| <ID> [faction_name]= | ||||
| <NewOwner>= | ||||
| <ParentID>= | ||||
| <PlayerName>= | ||||
| @@ -15,12 +17,13 @@ Area @1 does not exist or is not owned by you.= | ||||
| Area closed for faction members.= | ||||
| Area closed.= | ||||
| Area does not exist.= | ||||
| Area opened for faction members.= | ||||
| Area is open for members of: @1= | ||||
| Area opened.= | ||||
| Area protected. ID: @1= | ||||
| Area renamed.= | ||||
| Area successfully moved.= | ||||
| Change the owner of an area using its ID= | ||||
| Faction doesn't exists= | ||||
| Find areas using a Lua regular expression= | ||||
| Get information about area configuration and usage.= | ||||
|  | ||||
| @@ -43,6 +46,7 @@ Recursively remove areas using an ID= | ||||
| Remove an area using an ID= | ||||
| Removed area @1= | ||||
| Removed area @1 and it's sub areas.= | ||||
| Removes all ownerless areas= | ||||
| Rename an area that you own= | ||||
| Self protection is disabled.= | ||||
| Self protection is enabled.= | ||||
| @@ -65,8 +69,6 @@ You have extended area protection limits ("areas_high_limit" privilege).= | ||||
| You have the necessary privilege ("@1").= | ||||
| You need to select an area first.= | ||||
|  | ||||
| Removes all ownerless areas.= | ||||
|  | ||||
| ### chatcommands.lua ### | ||||
| ### pos.lua ### | ||||
|  | ||||
| @@ -78,6 +80,12 @@ Invalid usage, see /help @1.= | ||||
| :open= | ||||
| Areas:= | ||||
|  | ||||
| ### init.lua ### | ||||
|  | ||||
| Can administer areas.= | ||||
| Can protect areas.= | ||||
| Can protect more, bigger areas.= | ||||
|  | ||||
| ### interact.lua ### | ||||
|  | ||||
| @1 is protected by @2.= | ||||
|   | ||||
										
											Binary file not shown.
										
									
								
							| Before Width: | Height: | Size: 142 B After Width: | Height: | Size: 123 B | 
										
											Binary file not shown.
										
									
								
							| Before Width: | Height: | Size: 157 B After Width: | Height: | Size: 134 B | 
		Reference in New Issue
	
	Block a user