tis-minetest-portable
5.9.1-1
Minetest an open source voxel game engine
976 downloads
Download
See build result See VirusTotal scan

- package : tis-minetest-portable
- name : minetest
- version : 5.9.1-1
- categories :
- maintainer : Amel FRADJ
- installed_size :
- editor :
- licence : Unknown, LGPL-2.1 licenses found
- signature_date : 2024-09-20T21:00:58.000000
- size : 15.79 Mo
- locale :
- target_os : windows
- impacted_process :
- architecture : x86
- Homepage : www.minetest.net/
package : tis-minetest-portable
version : 5.9.1-1
architecture : x86
section : base
priority : optional
name : minetest
categories :
maintainer : Amel FRADJ
description : Minetest an open source voxel game engine
depends :
conflicts :
maturity : PROD
locale :
target_os : windows
min_wapt_version :
sources :
installed_size :
impacted_process :
description_fr : Minetest, un moteur de jeu voxel open source
description_pl : Minetest - silnik gier voxel o otwartym kodzie źródłowym
description_de : Minetest eine quelloffene Voxel-Spiel-Engine
description_es : Minetest, un motor de juegos voxel de código abierto
description_pt : Minetest, um motor de jogo voxel de código aberto
description_it : Minetest, un motore di gioco voxel open source
description_nl : Minetest een open source voxel game-engine
description_ru : Minetest - игровой движок с открытым исходным кодом для воксельных игр
audit_schedule :
editor :
keywords :
licence : Unknown, LGPL-2.1 licenses found
homepage : www.minetest.net/
package_uuid : 3fa504df-c8fc-4573-b4ac-bf160bd24861
valid_from :
valid_until :
forced_install_on :
changelog :
min_os_version :
max_os_version :
icon_sha256sum : ee2cd1b17c9e0906567e79e2a418c07c8e72fc5c3b950eacc971deafd205d557
signer : Tranquil IT
signer_fingerprint: 8c5127a75392be9cc9afd0dbae1222a673072c308c14d88ab246e23832e8c6bb
signature_date : 2024-09-20T21:00:58.000000
signed_attributes : package,version,architecture,section,priority,name,categories,maintainer,description,depends,conflicts,maturity,locale,target_os,min_wapt_version,sources,installed_size,impacted_process,description_fr,description_pl,description_de,description_es,description_pt,description_it,description_nl,description_ru,audit_schedule,editor,keywords,licence,homepage,package_uuid,valid_from,valid_until,forced_install_on,changelog,min_os_version,max_os_version,icon_sha256sum,signer,signer_fingerprint,signature_date,signed_attributes
signature : n6xwThcqUUpOeV+WwusU7te1q5IvGA05WmpLcMKkXf6OcDm1/hHNYtiXs9bYA+NZZlI1Ak3NHFC+/RN8GAtdJQuzpgzm5nYq69wdeP4m+XBCIR/lz+TJjzMCT95fDmHFXtM09V8aLW6MIDdpk2Fan+JaDIDYMCPyamZOD2ZvN3yriVSU8RlMmwNGz+Kn0GZC0lTRKqeKZMkVyN4lEZjIn0Gud5JTXoM5R39bEd4Z7V5NKQB0/WGMsiwoHSgqLNtPUV+bL+zfd2pbWQYMLgoZmorcqAcL3/YdECV7m9Bm0QGhNFwyAiLgYIIMh69NKC5pZbNKGDoeI4rs4yvE58FGNA==
# -*- coding: utf-8 -*-
from setuphelpers import *
import glob
import os
app_name = "minetest"
app_dir = makepath(programfiles, app_name)
app_path = makepath(app_dir,"bin", "minetest.exe")
audit_version = False
def get_installed_version(app_path):
return get_file_properties(app_path).get("FileVersion", "")
def install():
# Trouver le fichier zip
zip_name = glob.glob(f"{app_name}*.zip")[0]
unzip_dest = makepath(".", "temp_dezip")
# Supprimer le répertoire temporaire s'il existe déjà
if isdir(unzip_dest):
remove_tree(unzip_dest)
# Extraire le fichier zip
print(f"Extracting: {zip_name} to: {unzip_dest}")
unzip(zip_name, unzip_dest)
# Vérifier le contenu extrait
extracted_content = os.listdir(unzip_dest)
print(f"Extracted content in {unzip_dest}: {extracted_content}")
# Vérifier si le contenu extrait est un autre fichier ZIP
while len(extracted_content) == 1 and extracted_content[0].endswith(".zip"):
inner_zip_path = makepath(unzip_dest, extracted_content[0])
unzip(inner_zip_path, unzip_dest)
extracted_content = os.listdir(unzip_dest)
print(f"Extracted another ZIP file. New content: {extracted_content}")
# Supposons que le répertoire extrait soit le premier dossier dans `extracted_content`
extracted_dir = makepath(unzip_dest, extracted_content[0])
# Vérifier si le répertoire extrait contient `bin/minetest.exe`
if not isdir(extracted_dir) or not os.path.exists(makepath(extracted_dir, "bin", "minetest.exe")):
raise Exception(f"Expected directory structure not found in extracted content: {extracted_dir}")
# Supprimer l'ancien répertoire de l'application s'il existe
if isdir(app_dir):
remove_tree(app_dir)
# Déplacer le contenu du répertoire extrait vers le répertoire d'installation final
copytree2(extracted_dir, app_dir, onreplace=default_overwrite)
# Supprimer le répertoire temporaire
remove_tree(unzip_dest)
# Créer les raccourcis personnalisés
create_desktop_shortcut(app_name, target=app_path)
create_programs_menu_shortcut(app_name, target=app_path)
def audit():
# Auditing software
audit_status = "OK"
installed_version = get_installed_version(app_path)
if Version(installed_version) < Version(control.get_software_version()) and audit_version:
print("%s is installed in version (%s) instead of (%s)" % (app_name, installed_version, control.get_software_version()))
audit_status = "WARNING"
elif isdir(app_dir) and not dir_is_empty(app_dir):
print("%s (%s) is installed" % (app_name, installed_version))
audit_status = "OK"
else:
print("%s is not installed" % app_name)
audit_status = "ERROR"
return audit_status
def uninstall():
# Uninstalling software
killalltasks(ensure_list(control.impacted_process))
if isdir(app_dir):
remove_tree(app_dir)
# Removing shortcuts
remove_desktop_shortcut(app_name)
remove_programs_menu_shortcut(app_name)
# -*- coding: utf-8 -*-
from setuphelpers import *
from setupdevhelpers import *
import json
# Declaring global variables - Warnings: 1) WAPT context is only available in package functions; 2) Global variables are not persistent between calls
def update_package():
result = False
proxies = get_proxies()
if not proxies:
proxies = get_proxies_from_wapt_console()
dict_arch ={
"x64":"-win64.zip",
"x86": "-win32.zip"
}
git_repo = "minetest/minetest"
url_api = "https://api.github.com/repos/%s/releases" % git_repo
# Getting latest version information from official sources
print("API used is: %s" % url_api)
json_load = json.loads(wgets(url_api, proxies=proxies))
url_dl = None
# Itérer sur chaque release pour trouver la dernière version correspondante
for release in json_load:
if "assets" in release:
for download in release["assets"]:
if download["browser_download_url"].endswith('.zip') and dict_arch[control.architecture] in download["browser_download_url"]:
url_dl = download["browser_download_url"]
version = release["name"][9:]
filename= download["name"]
break
if url_dl:
break # Sortir de la boucle externe si la bonne version est trouvée
if not isfile(filename):
package_updated = True
wget(url_dl,filename,proxies=proxies)
#nettoyer les fichiers temporaires
for f in glob.glob('*.zip'):
if f != filename:
remove_file(f)
control.set_software_version(version)
control.save_control_to_wapt()
38d056ab130f7bf7c481c12636a4e9959de36561d3dfcbe54c6e3571bc0c1dc3 : WAPT/certificate.crt
5077419acb0e814b3701a964d05ab802228c3f5d0c4769ae36213f2674e4e24a : WAPT/control
ee2cd1b17c9e0906567e79e2a418c07c8e72fc5c3b950eacc971deafd205d557 : WAPT/icon.png
88547ca9d93c8ab052340bf304c2fa8b8e9b34e8fbb9bf265337d98cd7f10dd3 : luti.json
e2ec2505457bb2c32ed5dab6dab7640586cced3b512584e66a34b8b5cd3f525b : minetest-5.9.1-win32.zip
b6b91e6cd778a99e8e72fd83143309ece90574ebe314173b2255d07bd56b19b3 : setup.py
84c8252a9f2a3360ac6dbded6c176561a0c864b8d190b5775255bd15862880b4 : update_package.py