money/init.lua
2016-05-13 12:41:59 +01:00

311 lines
11 KiB
Lua
Executable File

--[[
Money Mod by Kotolegokot and Xiong
Edited by TenPlus1 (13th May 2016)
]]
-- Does player have permissions for this shop?
local function has_shop_privilege(meta, player)
return player:get_player_name() == meta:get_string("owner")
or minetest.get_player_privs(player:get_player_name())["protection_bypass"] -- was server
end
-- Barter shop
minetest.register_node("money:barter_shop", {
description = "Barter Shop",
tiles = {
"default_chest_top.png",
"default_chest_top.png",
"default_chest_side.png",
"default_chest_side.png",
"default_chest_side.png",
"default_chest_front.png^money_barter_shop_front.png"
},
groups = {snappy=2,choppy=2,oddly_breakable_by_hand=2},
sounds = default.node_sound_wood_defaults(),
paramtype2 = "facedir",
after_place_node = function(pos, placer)
local meta = minetest.get_meta(pos)
meta:set_string("owner", placer:get_player_name())
meta:set_string("infotext", "Untuned Barter Shop (owned by " .. placer:get_player_name() .. ")")
end,
on_construct = function(pos)
local meta = minetest.get_meta(pos)
meta:set_string("formspec", "size[8,5.6]"
.. default.gui_bg
.. default.gui_bg_img
.. default.gui_slots
.. "field[0.256,0.5;8,1;bartershopname;Name of barter shop:;]"
.. "field[0.256,1.5;8,1;nodename1;Node name (A) shop gives to player:;]"
.. "field[0.256,2.5;8,1;nodename2;Node name (B) player gives to shop:;]"
.. "field[0.256,3.5;8,1;amount1;Quantity of node A per swap:;]"
.. "field[0.256,4.5;8,1;amount2;Quantity of node B per swap:;]"
.. "button_exit[3.1,5;2,1;button;Tune]")
meta:set_string("infotext", "Untuned Barter Shop")
meta:set_string("owner", "")
meta:set_string("form", "yes")
end,
-- retune
on_punch = function( pos, node, player )
local meta = minetest.get_meta(pos)
if player:get_player_name() == meta:get_string("owner") then
meta:set_string("formspec", "size[8,5.6]"
.. default.gui_bg
.. default.gui_bg_img
.. default.gui_slots
.. "field[0.256,0.5;8,1;bartershopname;Name of barter shop:;${bartershopname}]"
.. "field[0.256,1.5;8,1;nodename1;Node name (A) shop gives to player:;${nodename1}]"
.. "field[0.256,2.5;8,1;nodename2;Node name (B) player gives to shop:;${nodename2}]"
.. "field[0.256,3.5;8,1;amount1;Quantity of node A per swap:;${amount1}]"
.. "field[0.256,4.5;8,1;amount2;Quantity of node B per swap:;${amount2}]"
.. "button_exit[3.1,5;2,1;button;Retune]")
meta:set_string("infotext", "Detuned Barter Shop")
meta:set_string("form", "yes")
minetest.chat_send_player(player:get_player_name(), "Barter Shop detuned.")
end
end,
-- end retune
can_dig = function(pos,player)
local meta = minetest.get_meta(pos)
local inv = meta:get_inventory()
return inv:is_empty("main") and (meta:get_string("owner") == player:get_player_name() or minetest.get_player_privs(player:get_player_name())["server"])
end,
allow_metadata_inventory_move = function(pos, from_list, from_index, to_list, to_index, count, player)
local meta = minetest.get_meta(pos)
if not has_shop_privilege(meta, player) then
minetest.log("action", player:get_player_name()..
" tried to access barter shop belonging to "..
meta:get_string("owner").." at "..
minetest.pos_to_string(pos))
return 0
end
return count
end,
allow_metadata_inventory_put = function(pos, listname, index, stack, player)
local meta = minetest.get_meta(pos)
if not has_shop_privilege(meta, player) then
minetest.log("action", player:get_player_name()..
" tried to access barter shop belonging to "..
meta:get_string("owner").." at "..
minetest.pos_to_string(pos))
return 0
end
-- if item is worn do not put in shop
if stack:get_wear() > 0 then return 0 end
return stack:get_count()
end,
allow_metadata_inventory_take = function(pos, listname, index, stack, player)
local meta = minetest.get_meta(pos)
if not has_shop_privilege(meta, player) then
minetest.log("action", player:get_player_name()..
" tried to access barter shop belonging to "..
meta:get_string("owner").." at "..
minetest.pos_to_string(pos))
return 0
end
return stack:get_count()
end,
--[[
on_metadata_inventory_move = function(pos, from_list, from_index, to_list, to_index, count, player)
minetest.log("action", player:get_player_name()..
" moves stuff in barter shop at "..minetest.pos_to_string(pos))
end,
on_metadata_inventory_put = function(pos, listname, index, stack, player)
minetest.log("action", player:get_player_name()..
" puts stuff in barter shop at "..minetest.pos_to_string(pos))
end,
on_metadata_inventory_take = function(pos, listname, index, count, player)
minetest.log("action", player:get_player_name()..
" takes stuff from barter shop at "..minetest.pos_to_string(pos))
end,
]]
on_receive_fields = function(pos, formname, fields, sender)
local meta = minetest.get_meta(pos)
if meta:get_string("form") == "yes" then
if fields.bartershopname ~= ""
and minetest.registered_items[fields.nodename1]
and minetest.registered_items[fields.nodename2]
and tonumber(fields.amount1)
and tonumber(fields.amount1) >= 1
and tonumber(fields.amount2)
and tonumber(fields.amount2) >= 1
and (meta:get_string("owner") == sender:get_player_name()
or minetest.get_player_privs(sender:get_player_name())["server"]) then
meta:set_string("formspec", "size[8,10]"
.. default.gui_bg
.. default.gui_bg_img
.. default.gui_slots
.. "list[context;main;0,0;8,4;]"
.. "label[0,4.25.0;Selling "
.. fields.amount1 .."x "
.. fields.nodename1 .. " for "
.. fields.amount2 .. "x "
.. fields.nodename2 .. "]"
.. "button[3,5;2,1;button;Exchange]"
.. "list[current_player;main;0,6;8,4;]"
.. "listring[]")
meta:set_string("bartershopname", fields.bartershopname)
meta:set_string("nodename1", fields.nodename1)
meta:set_string("nodename2", fields.nodename2)
meta:set_string("amount1", fields.amount1)
meta:set_string("amount2", fields.amount2)
meta:set_string("infotext", "Barter Shop \"" .. fields.bartershopname .. "\" (owned by " .. meta:get_string("owner") .. ")")
meta:set_string("form", "no")
local inv = meta:get_inventory()
inv:set_size("main", 8*4)
end
elseif fields["button"] then
local sender_name = sender:get_player_name()
local inv = meta:get_inventory()
local sender_inv = sender:get_inventory()
if not inv:contains_item("main", meta:get_string("nodename1") .. " " .. meta:get_string("amount1")) then
minetest.chat_send_player(sender_name, "Barter shop does not have enough goods.")
return
elseif not sender_inv:contains_item("main", meta:get_string("nodename2") .. " " .. meta:get_string("amount2")) then
minetest.chat_send_player(sender_name, "You do not have enough goods to trade.")
return
elseif not inv:room_for_item("main", meta:get_string("nodename2") .. " " .. meta:get_string("amount2")) then
minetest.chat_send_player(sender_name, "Not enough space in barter shop.")
return
elseif not sender_inv:room_for_item("main", meta:get_string("nodename1") .. " " .. meta:get_string("amount1")) then
minetest.chat_send_player(sender_name, "Your inventory is too full.")
return
end
inv:remove_item("main", meta:get_string("nodename1") .. " " .. meta:get_string("amount1"))
sender_inv:remove_item("main", meta:get_string("nodename2") .. " " .. meta:get_string("amount2"))
inv:add_item("main", meta:get_string("nodename2") .. " " .. meta:get_string("amount2"))
sender_inv:add_item("main", meta:get_string("nodename1") .. " " .. meta:get_string("amount1"))
minetest.chat_send_player(sender_name, "You exchanged " .. meta:get_string("amount2") .. " " .. meta:get_string("nodename2") .. " for " .. meta:get_string("amount1") .. " " .. meta:get_string("nodename1") .. ".")
end
end,
})
-- Barter Shop recipe
minetest.register_craft({
type = "shapeless",
output = "money:barter_shop",
recipe = {"default:sign_wall", "default:chest_locked"},
})
-- Admin barter shop.
minetest.register_node("money:admin_barter_shop", {
description = "Admin Barter Shop",
tiles = {
"default_chest_top.png",
"default_chest_top.png",
"default_chest_side.png",
"default_chest_side.png",
"default_chest_side.png",
"default_chest_front.png^money_admin_barter_shop_front.png"},
groups = {snappy=2,choppy=2,oddly_breakable_by_hand=2},
sounds = default.node_sound_wood_defaults(),
paramtype2 = "facedir",
on_construct = function(pos)
local meta = minetest.get_meta(pos)
meta:set_string("formspec", "size[8,6]"
.. default.gui_bg
.. default.gui_bg_img
.. default.gui_slots
.. "field[0.256,0.5;8,1;nodename1;What are you giving to player:;]"
.. "field[0.256,1.75;8,1;amount1;Amount to give:;]"
.. "field[0.256,3;8,1;nodename2;In exchange for what:;]"
.. "field[0.256,4.25;8,1;amount2;Amount to take:;]"
.. "button_exit[3.1,5;2,1;button;Proceed]")
meta:set_string("infotext", "Untuned Admin Barter Shop")
meta:set_string("form", "yes")
end,
can_dig = function(pos,player)
return minetest.get_player_privs(player:get_player_name())["protection_bypass"] -- was server
end,
on_receive_fields = function(pos, formname, fields, sender)
local meta = minetest.get_meta(pos)
if meta:get_string("form") == "yes" then
if minetest.registered_items[fields.nodename1]
and minetest.registered_items[fields.nodename2]
and tonumber(fields.amount1) and tonumber(fields.amount1) >= 1
and tonumber(fields.amount2) and tonumber(fields.amount2) >= 1
and (meta:get_string("owner") == sender:get_player_name()
or minetest.get_player_privs(sender:get_player_name())["server"]) then
meta:set_string("formspec", "size[8,6]"
.. default.gui_bg
.. default.gui_bg_img
.. default.gui_slots
.. "label[0,0.0;Selling "
.. fields.amount1 .."x "
.. fields.nodename1 .. " for "
.. fields.amount2 .. "x "
.. fields.nodename2 .. "]"
.. "button[3,0.75;2,1;button;Exchange]"
.. "list[current_player;main;0,2;8,4;]")
meta:set_string("nodename1", fields.nodename1)
meta:set_string("nodename2", fields.nodename2)
meta:set_string("amount1", fields.amount1)
meta:set_string("amount2", fields.amount2)
meta:set_string("form", "no")
meta:set_string("infotext", "Selling "
.. fields.amount1 .. "x "
.. fields.nodename1 .. " for "
.. fields.amount2 .. "x "
.. fields.nodename2)
end
elseif fields["button"] then
local sender_name = sender:get_player_name()
local sender_inv = sender:get_inventory()
if not sender_inv:contains_item("main", meta:get_string("nodename2") .. " " .. meta:get_string("amount2")) then
minetest.chat_send_player(sender_name, "You do not have enough goods to trade.")
return
elseif not sender_inv:room_for_item("main", meta:get_string("nodename1") .. " " .. meta:get_string("amount1")) then
minetest.chat_send_player(sender_name, "Your inventory is too full.")
return
end
sender_inv:remove_item("main", meta:get_string("nodename2") .. " " .. meta:get_string("amount2"))
sender_inv:add_item("main", meta:get_string("nodename1") .. " " .. meta:get_string("amount1"))
minetest.chat_send_player(sender_name, "You exchanged " .. meta:get_string("amount2") .. " " .. meta:get_string("nodename2") .. " on " .. meta:get_string("amount1") .. " " .. meta:get_string("nodename1") .. ".")
end
end,
})