aboutsummaryrefslogtreecommitdiff
path: root/textures/base/pack/error_screenshot.png
blob: e35a0a38aa193ea3a160f8d9057a64909b3ea729 (plain)
ofshex dumpascii
0000 89 50 4e 47 0d 0a 1a 0a 00 00 00 0d 49 48 44 52 00 00 01 2c 00 00 00 c8 04 03 00 00 00 a0 f1 c1 .PNG........IHDR...,............
0020 66 00 00 00 09 70 48 59 73 00 00 0b 13 00 00 0b 13 01 00 9a 9c 18 00 00 00 07 74 49 4d 45 07 e2 f....pHYs.................tIME..
0040 05 07 16 32 36 f8 0e b9 ca 00 00 00 0f 50 4c 54 45 00 00 00 ff 00 00 ff ff ff ff ff ff ff 00 00 ...26........PLTE...............
0060 ca 18 88 29 00 00 00 04 74 52 4e 53 00 00 00 72 0d 98 76 8a 00 00 00 01 62 4b 47 44 02 66 0b 7c ...)....tRNS...r..v.....bKGD.f.|
0080 64 00 00 03 32 49 44 41 54 78 da ed dd 51 8e 9b 30 14 85 e1 c8 cd 02 ea 59 01 ba ca 02 aa e9 06 d...2IDATx...Q..0.......Y.......
00a0 68 e4 fd af 69 1e c6 18 1b 0c b9 8e 8d 8f db 1e 5e 89 c4 97 5f c1 01 e3 28 b7 db 50 9b 91 e9 36 h...i...........^..._...(..P...6
00c0 e0 46 16 59 64 91 45 d6 05 ac 1f bf 87 d9 3e 45 44 84 ac 7f 88 f5 6b 8c f3 2a 85 90 45 16 59 64 .F.Yd.E.......>ED.....k..*..E.Yd
00e0 91 45 16 59 64 91 45 16 59 64 91 45 16 59 64 91 45 16 59 64 65 36 e7 dc ac 67 39 e7 5c 2f 96 53 .E.Yd.E.Yd.E.Yd.E.Yde6...g9.\/.S
0100 b3 ee 5d 59 b3 96 e5 ba b2 9c 92 f5 e8 cc 9a 75 2c d7 99 a5 3a 94 79 74 67 69 72 19 fd 4b eb 59 ..]Y...........u,...:.ytgir..K.Y
0120 77 75 82 7b 69 ac aa e1 54 dd a0 38 56 15 4b 1b a1 3c 56 dd 97 8f b2 42 79 ac 3a 96 2e c3 1b b1 wu.{i...T..8V.K..<V....By.:.....
0140 2a bf aa 55 1d de 88 55 c9 d2 84 78 27 56 ed 85 8d a2 c4 3b b1 6a 59 af 53 94 c7 32 32 55 5f 06 *..U...U...x'V.....;.jY.S..22U_.
0160 be 6c 51 1e ab 05 eb 55 0c bf 7f ea cc 7a 55 e3 7b f7 b3 3b eb 3c 97 df 2b dd 59 e7 b9 7c 2c 00 .lQ....U.....zU.{..;.<..+.Y..|,.
0180 eb 2c 97 df f7 01 60 9d e5 fa de f5 07 c2 3a ce e5 f7 58 83 60 1d e7 f2 b1 7e 62 58 47 b9 96 58 .,....`.......:...X.`....~bXG..X
01a0 37 0c eb 28 d7 12 0b c5 ca e7 0a b1 50 ac 7c ae 10 0b c6 ca e5 5a 63 c1 58 b9 5c 6b 2c 1c 6b 9f 7..(........P.|......Zc.X.\k,.k.
01c0 2b 8a 85 63 ed 73 45 b1 80 ac 6d ae 38 16 90 b5 cd 15 c7 42 b2 d2 5c 49 2c 24 2b cd 95 c4 82 b2 +..c.sE...m.8......B..\I,$+.....
01e0 e2 5c 69 2c 28 2b ce 95 c6 c2 b2 d6 5c 9b 58 10 96 88 f8 a3 2e 17 ee 92 8e 59 eb 0b 3a b2 64 3d .\i,(+......\.X..........Y..:.d=
0200 ec 72 9b f3 48 06 78 08 cb 1f 56 e2 5c 71 2c c1 b0 44 f6 b9 f6 b1 96 15 e6 bd 58 e1 b0 71 ae 7d .r..H.x...V.\q,..D........X..q.}
0220 ac a2 5c ed 59 f7 4d 2c 14 4b 36 c7 dd c4 5a d5 02 65 3d 42 ac 69 24 96 2c b1 3e c6 62 2d 63 96 ..\.Y.M,.K6...Z..e=B.i$.,.>.b-c.
0240 0c 59 eb 39 16 2b 7c b6 c6 62 85 33 f1 39 12 2b 1a b7 46 62 45 a3 fc 8c 64 a5 a3 7c f2 9d 88 1c .Y.9.+|..b.3.9.+..FbE...d..|....
0260 e5 53 96 1f b3 a2 5c 20 56 72 05 b1 5c 94 46 4f a6 41 57 10 c9 f5 56 98 29 dd e7 02 5e 9d 2e b1 .S....\.Vr..\.FO.AW...V.)...^...
0280 44 f6 b9 80 d7 f2 21 96 c8 ee 64 84 df 27 da cc 8c 04 fe ae da df 1b a6 33 12 f8 39 08 9b 9b 91 D.....!...d..'..........3..9....
02a0 80 cf d8 84 1b e9 24 17 7c 7e cb 66 27 70 d0 b3 81 21 56 9a 0b 3d 77 6a f3 13 38 e0 99 e6 28 56 ......$.|~.f'p...!V..=wj..8...(V
02c0 92 0b 3c 2f 6f 0f e6 bb b0 4f 31 92 58 71 2e ec 33 1f 7b 34 df 05 7d 42 b6 89 15 e5 82 3e 4f b4 ..</o....O1.Xq..3.{4..}B.....>O.
02e0 87 d3 83 c8 a7 af bb 58 6b 2e 03 7c 56 6d 8f 67 53 0d ee c9 7e 26 56 c8 65 70 eb 20 ec c9 3e 03 .......Xk..|Vm.gS...~&V.ep....>.
0300 5b 35 92 8d 05 5c 35 72 16 0b b8 c6 e6 34 16 6c 45 d2 79 2c d8 fa ad 31 57 bb 0d ba 36 f0 8a 95 [5...\5r.....4.lE.y,...1W...6...
0320 94 39 d6 a7 94 6c fe f6 59 f3 9a 9e ac f0 4c ec f5 8b e6 7e 2c 4d ac f2 5c d5 2c 55 ac e2 5c b5 .9...l..Y.....L....~,M..\.,U..\.
0340 1f f9 8b d6 cb d7 b2 2e fa 75 41 25 eb aa df 62 54 b2 0a 1a 14 e5 6a c2 6a 1c b6 11 6b 6e fe 16 .........uA%...bT.....j.j...kn..
0360 9a b0 8a 3e 87 dd 58 f3 05 ef a1 01 ab ec b4 ed c5 9a af 78 13 f5 ac c2 af 04 c0 dc 69 bb 8d 2c ...>..X............x........i..,
0380 b2 c8 22 8b 2c b2 c8 22 8b 2c b2 c8 22 8b 2c b2 c8 22 8b 2c b2 c8 fa 9f 59 fc cf 15 b2 ae 61 19 ..".,..".,..".,..".,....Y.....a.
03a0 99 e2 9f 75 b4 dc a6 ca 93 60 50 d6 80 1b 59 64 91 45 d6 df c3 fa 02 b9 95 62 12 62 26 25 e0 00 ...u.....`P...Yd.E.......b.b&%..
03c0 00 00 00 49 45 4e 44 ae 42 60 82 ...IEND.B`.
ng.split(str, delim)) do privs[priv:trim()] = true end return privs end function core.privs_to_string(privs, delim) assert(type(privs) == "table") delim = delim or ',' list = {} for priv, bool in pairs(privs) do if bool then table.insert(list, priv) end end return table.concat(list, delim) end assert(core.string_to_privs("a,b").b == true) assert(core.privs_to_string({a=true,b=true}) == "a,b") core.auth_file_path = core.get_worldpath().."/auth.txt" core.auth_table = {} local function read_auth_file() local newtable = {} local file, errmsg = io.open(core.auth_file_path, 'rb') if not file then core.log("info", core.auth_file_path.." could not be opened for reading ("..errmsg.."); assuming new world") return end for line in file:lines() do if line ~= "" then local name, password, privilegestring = string.match(line, "([^:]*):([^:]*):([^:]*)") if not name or not password or not privilegestring then error("Invalid line in auth.txt: "..dump(line)) end local privileges = core.string_to_privs(privilegestring) newtable[name] = {password=password, privileges=privileges} end end io.close(file) core.auth_table = newtable core.notify_authentication_modified() end local function save_auth_file() local newtable = {} -- Check table for validness before attempting to save for name, stuff in pairs(core.auth_table) do assert(type(name) == "string") assert(name ~= "") assert(type(stuff) == "table") assert(type(stuff.password) == "string") assert(type(stuff.privileges) == "table") end local file, errmsg = io.open(core.auth_file_path, 'w+b') if not file then error(core.auth_file_path.." could not be opened for writing: "..errmsg) end for name, stuff in pairs(core.auth_table) do local privstring = core.privs_to_string(stuff.privileges) file:write(name..":"..stuff.password..":"..privstring..'\n') end io.close(file) end read_auth_file() core.builtin_auth_handler = { get_auth = function(name) assert(type(name) == "string") -- Figure out what password to use for a new player (singleplayer -- always has an empty password, otherwise use default, which is -- usually empty too) local new_password_hash = "" -- If not in authentication table, return nil if not core.auth_table[name] then return nil end -- Figure out what privileges the player should have. -- Take a copy of the privilege table local privileges = {} for priv, _ in pairs(core.auth_table[name].privileges) do privileges[priv] = true end -- If singleplayer, give all privileges except those marked as give_to_singleplayer = false if core.is_singleplayer() then for priv, def in pairs(core.registered_privileges) do if def.give_to_singleplayer then privileges[priv] = true end end -- For the admin, give everything elseif name == core.setting_get("name") then for priv, def in pairs(core.registered_privileges) do privileges[priv] = true end end -- All done return { password = core.auth_table[name].password, privileges = privileges, } end, create_auth = function(name, password) assert(type(name) == "string") assert(type(password) == "string") core.log('info', "Built-in authentication handler adding player '"..name.."'") core.auth_table[name] = { password = password, privileges = core.string_to_privs(core.setting_get("default_privs")), } save_auth_file() end, set_password = function(name, password) assert(type(name) == "string") assert(type(password) == "string") if not core.auth_table[name] then core.builtin_auth_handler.create_auth(name, password) else core.log('info', "Built-in authentication handler setting password of player '"..name.."'") core.auth_table[name].password = password save_auth_file() end return true end, set_privileges = function(name, privileges) assert(type(name) == "string") assert(type(privileges) == "table") if not core.auth_table[name] then core.builtin_auth_handler.create_auth(name, core.get_password_hash(name, core.setting_get("default_password"))) end core.auth_table[name].privileges = privileges core.notify_authentication_modified(name) save_auth_file() end, reload = function() read_auth_file() return true end, } function core.register_authentication_handler(handler) if core.registered_auth_handler then error("Add-on authentication handler already registered by "..core.registered_auth_handler_modname) end core.registered_auth_handler = handler core.registered_auth_handler_modname = core.get_current_modname() end function core.get_auth_handler() if core.registered_auth_handler then return core.registered_auth_handler end return core.builtin_auth_handler end function core.set_player_password(name, password) if core.get_auth_handler().set_password then core.get_auth_handler().set_password(name, password) end end function core.set_player_privs(name, privs) if core.get_auth_handler().set_privileges then core.get_auth_handler().set_privileges(name, privs) end end function core.auth_reload() if core.get_auth_handler().reload then return core.get_auth_handler().reload() end return false end