Compare commits
3 Commits
b79404f7fa
...
15143fd58f
Author | SHA1 | Date | |
---|---|---|---|
15143fd58f | |||
bf20c9f4bd | |||
2aef6adf19 |
@ -10,12 +10,12 @@
|
|||||||
-----------------------------------------------------
|
-----------------------------------------------------
|
||||||
local is_46 = minetest.has_feature("add_entity_with_staticdata")
|
local is_46 = minetest.has_feature("add_entity_with_staticdata")
|
||||||
|
|
||||||
|
function get_minetest_config( key )
|
||||||
if is_46 then
|
if is_46 then
|
||||||
get_minetest_config = function( key )
|
return minetest.settings:get( key )
|
||||||
minetest.settings:get( key )
|
|
||||||
end
|
|
||||||
else
|
else
|
||||||
get_minetest_config = core.setting_get -- backwards compatibility
|
return core.setting_get( key ) -- backwards compatibility
|
||||||
|
end
|
||||||
end
|
end
|
||||||
|
|
||||||
function convert_ipv4( str )
|
function convert_ipv4( str )
|
||||||
|
46
init.lua
46
init.lua
@ -24,7 +24,7 @@ local auth_filter = AuthFilter( world_path, "greenlist.mt" )
|
|||||||
local auth_db = AuthDatabase( world_path, "auth.db" )
|
local auth_db = AuthDatabase( world_path, "auth.db" )
|
||||||
local auth_watchdog = AuthWatchdog( )
|
local auth_watchdog = AuthWatchdog( )
|
||||||
local is_50 = minetest.has_feature("object_use_texture_alpha")
|
local is_50 = minetest.has_feature("object_use_texture_alpha")
|
||||||
local is_54 = minetest.has_feature("object_use_texture_alpha")
|
local is_54 = minetest.has_feature("direct_velocity_on_players")
|
||||||
|
|
||||||
if is_50 then
|
if is_50 then
|
||||||
if minetest.register_on_auth_fail then
|
if minetest.register_on_auth_fail then
|
||||||
@ -128,15 +128,15 @@ end )
|
|||||||
minetest.register_authentication_handler( {
|
minetest.register_authentication_handler( {
|
||||||
-- translate old auth hooks to new database backend
|
-- translate old auth hooks to new database backend
|
||||||
get_auth = function( username )
|
get_auth = function( username )
|
||||||
|
minetest.log( "verbose" , "[auth_rx] get_auth handler access to some resource for " .. username )
|
||||||
local rec = auth_db.select_record( username )
|
local rec = auth_db.select_record( username )
|
||||||
if rec then
|
if rec then
|
||||||
local assigned_privs = rec.assigned_privs
|
local assigned_privs = rec.assigned_privs
|
||||||
|
|
||||||
if get_minetest_config( "name" ) == username then
|
if get_minetest_config( "name" ) == username then
|
||||||
-- grant server operator all privileges
|
-- grant server operator all privileges
|
||||||
-- (TODO: implement as function that honors give_to_admin flag)
|
|
||||||
assigned_privs = { }
|
assigned_privs = { }
|
||||||
for priv in pairs( core.registered_privileges ) do
|
for priv in pairs( minetest.registered_privileges ) do
|
||||||
table.insert( assigned_privs, priv )
|
table.insert( assigned_privs, priv )
|
||||||
end
|
end
|
||||||
end
|
end
|
||||||
@ -145,28 +145,52 @@ minetest.register_authentication_handler( {
|
|||||||
end
|
end
|
||||||
end,
|
end,
|
||||||
create_auth = function( username, password )
|
create_auth = function( username, password )
|
||||||
if auth_db.create_record( username, password ) then
|
minetest.log( "verbose" , "[auth_rx] create_auth handler new user over server for " .. username )
|
||||||
auth_db.set_assigned_privs( username, get_default_privs( ) )
|
local rec = auth_db.create_record( username, password )
|
||||||
minetest.log( "info", "Created player '" .. username .. "' in authentication database" )
|
if rec then
|
||||||
|
local assigned_privs = get_default_privs( )
|
||||||
|
|
||||||
|
if get_minetest_config( "name" ) == username then
|
||||||
|
-- grant server operator all privileges
|
||||||
|
assigned_privs = { }
|
||||||
|
for priv in pairs( minetest.registered_privileges ) do
|
||||||
|
table.insert( assigned_privs, priv )
|
||||||
|
end
|
||||||
|
end
|
||||||
|
|
||||||
|
auth_db.set_assigned_privs( username, assigned_privs )
|
||||||
end
|
end
|
||||||
end,
|
end,
|
||||||
delete_auth = function( username )
|
delete_auth = function( username )
|
||||||
if auth_db.delete_record( username ) then
|
minetest.log( "verbose" , "[auth_rx] delete_auth handler for " .. username )
|
||||||
|
-- server operator's privileges are immutable
|
||||||
|
if get_minetest_config( "name" ) ~= username then
|
||||||
|
local rec = auth_db.delete_record( username )
|
||||||
|
if rec then
|
||||||
minetest.log( "info", "Deleted player '" .. username .. "' in authenatication database" )
|
minetest.log( "info", "Deleted player '" .. username .. "' in authenatication database" )
|
||||||
end
|
end
|
||||||
|
end
|
||||||
end,
|
end,
|
||||||
set_password = function ( username, password )
|
set_password = function ( username, password )
|
||||||
if auth_db.set_password( username, password ) then
|
minetest.log( "verbose" , "[auth_rx] set_password handler for " .. username )
|
||||||
|
local rec = auth_db.set_password( username, password )
|
||||||
|
if rec then
|
||||||
minetest.log( "info", "Reset password of player '" .. username .. "' in authentication database" )
|
minetest.log( "info", "Reset password of player '" .. username .. "' in authentication database" )
|
||||||
end
|
end
|
||||||
end,
|
end,
|
||||||
set_privileges = function ( username, privileges )
|
set_privileges = function ( username, privileges )
|
||||||
|
minetest.log( "verbose" , "[auth_rx] set_privileges handler grants for " .. username )
|
||||||
|
local assigned_privs = pack_privileges( privileges )
|
||||||
-- server operator's privileges are immutable
|
-- server operator's privileges are immutable
|
||||||
if get_minetest_config( "name" ) == username then return end
|
if get_minetest_config( "name" ) == username then
|
||||||
|
assigned_privs = { }
|
||||||
|
for priv in pairs( minetest.registered_privileges ) do
|
||||||
|
table.insert( assigned_privs, priv )
|
||||||
|
end
|
||||||
|
end
|
||||||
|
|
||||||
if auth_db.set_assigned_privs( username, pack_privileges( privileges ) ) then
|
if auth_db.set_assigned_privs( username, assigned_privs ) then
|
||||||
minetest.notify_authentication_modified( username )
|
minetest.notify_authentication_modified( username )
|
||||||
minetest.log( "info", "Reset privileges of player '" .. username .. "' in authentication database" )
|
|
||||||
end
|
end
|
||||||
end,
|
end,
|
||||||
record_login = function ( ) end,
|
record_login = function ( ) end,
|
||||||
|
Loading…
x
Reference in New Issue
Block a user