Update init.lua

This commit is contained in:
Nicolas 2023-12-30 20:40:39 +01:00 committed by GitHub
parent 8de2a9a65e
commit f2f54bab7d
No known key found for this signature in database
GPG Key ID: 4AEE18F83AFDEB23

104
init.lua
View File

@ -1,65 +1,74 @@
-- modname/init.lua
-- Chemin vers le fichier JSON
local json_file_path = minetest.get_worldpath() .. "/events.json"
-- Initialiser la variable events en dehors de load_database
local events = {}
-- Fonction pour charger la base de données
local function load_database()
-- Chemin vers le fichier JSON
local json_file_path = minetest.get_worldpath() .. "/events.json"
-- Charger les événements depuis le fichier JSON existant ou initialiser une table vide
local events = {}
local json_file = io.open(json_file_path, "r")
if json_file then
events = minetest.deserialize(json_file:read("*all"))
json_file:close()
minetest.log("action", "[Modname] Base de données chargée avec succès.")
else
-- Créer le fichier JSON s'il n'existe pas
local new_json_file = io.open(json_file_path, "w")
new_json_file:write(minetest.serialize(events))
new_json_file:close()
minetest.log("action", "[Modname] Nouvelle base de données créée.")
end
end
-- Fonction pour sauvegarder les événements dans le fichier JSON
local function save_events()
local json_file = io.open(json_file_path, "w")
if json_file then
json_file:write(minetest.serialize(events))
json_file:close()
end
end
-- Fonction pour enregistrer un nouvel événement
local function log_event(pos, event_type, entity)
local key = minetest.pos_to_string(pos)
if not events[key] then
events[key] = {}
end
-- Fonction pour enregistrer les événements dans le fichier JSON
local function save_events()
local json_file = io.open(json_file_path, "w")
if json_file then
json_file:write(minetest.serialize(events))
json_file:close()
end
local event = {
event_type = event_type,
entity = entity,
timestamp = os.date("%Y-%m-%dT%H:%M:%S")
}
table.insert(events[key], event)
save_events()
end
-- Exemple d'utilisation : enregistrez un événement lorsque le joueur casse ou place un bloc
minetest.register_on_dignode(function(pos, oldnode, digger)
if digger then
log_event(pos, "break", digger:get_player_name())
end
end)
-- Fonction pour enregistrer un nouvel événement
local function log_event(pos, event_type, entity)
local key = minetest.pos_to_string(pos)
if not events[key] then
events[key] = {}
end
local event = {
event_type = event_type,
entity = entity,
timestamp = os.date("%Y-%m-%dT%H:%M:%S")
}
table.insert(events[key], event)
save_events()
minetest.register_on_placenode(function(pos, newnode, placer, oldnode, itemstack, pointed_thing)
if placer then
log_event(pos, "place", placer:get_player_name())
end
end)
-- Exemple d'utilisation : enregistrez un événement lorsque le joueur casse ou place un bloc
minetest.register_on_dignode(function(pos, oldnode, digger)
if digger then
log_event(pos, "break", digger:get_player_name())
end
end)
minetest.register_on_placenode(function(pos, newnode, placer, oldnode, itemstack, pointed_thing)
if placer then
log_event(pos, "place", placer:get_player_name())
end
end)
-- Envoyer le message dans le chat du serveur
minetest.chat_send_all("[Modname] Base de données chargée avec succès.")
-- Fonction pour vérifier si la base de données est chargée
local function check_database()
if next(events) then
minetest.chat_send_all("[Modname] La base de données est chargée.")
else
minetest.chat_send_all("[Modname] La base de données n'est pas chargée.")
end
end
-- Commande pour recharger la base de données
@ -71,5 +80,14 @@ minetest.register_chatcommand("rdatab", {
end,
})
-- Commande pour vérifier si la base de données est chargée
minetest.register_chatcommand("check_database", {
description = "Vérifie si la base de données est chargée.",
func = function(name, param)
check_database()
return true, "[Modname] Vérification de la base de données effectuée."
end,
})
-- Appeler la fonction load_database lors du chargement des mods
minetest.register_on_mods_loaded(load_database)