tis-minetest-portable

5.11.0-1
Minetest an open source voxel game engine
976 downloads
Download
See build result See VirusTotal scan
tis-minetest-portable icon
  • package : tis-minetest-portable
  • name : minetest
  • version : 5.11.0-1
  • categories :
  • maintainer : Amel FRADJ
  • installed_size :
  • editor :
  • licence : Unknown, LGPL-2.1 licenses found
  • signature_date : 2025-02-19T20:04:05.000000
  • size : 16.29 Mo
  • locale :
  • target_os : windows
  • impacted_process :
  • architecture : x64
  • Homepage : www.minetest.net/
package           : tis-minetest-portable
version           : 5.11.0-1
architecture      : x64
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      : c0a52f6e-07da-44d5-a6b8-c52b1455e076
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    : 2025-02-19T20:04:05.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         : HwEbbrraPKJ1uI0YftiLlXV4wJxdIs/QyL4oeUe4YJRLwRuLkHb+Tl5WFwZTaZwUyD2bILE1jDMkzbTDBaLM/iAtyXb+7Ab5JnVMsv3H91YYwQh03qD52I1qQOS2zrEyS6VnWx5p/7p5mpEbAcGayzv3shqWp15b3rImPkvO9O5JTlyLe+5zpnkGW2f1RE4+oe7V8hY1Z8IxPHYS7PCFhoYvBs7EUagOeU/MF72JlQHli6sOxX7Ai3oWrorvW6YXOIr+LzOYoF5lqq8v354iOTT8vETffhqBBA5GGsVyyGN4cytASBcEhqYSxDaa0iPDmyZ1ObgPPGzOdb5jtH7giA==
# -*- coding: utf-8 -*-
from setuphelpers import *
import glob
import os

app_name = "luanti"
app_dir = makepath(programfiles, app_name)
app_path = makepath(app_dir,"bin", "luanti.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", "luanti.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["tag_name"]
                    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
89e7cfcfbc16f3a77a334994c71327e8f10ef66ba05bb426db2bf4642c5b0d9f : WAPT/control
ee2cd1b17c9e0906567e79e2a418c07c8e72fc5c3b950eacc971deafd205d557 : WAPT/icon.png
61838e82eed301fddb9f38240e5cd946198fc00a0dc7becfc0dc646b760fe75c : luanti-5.11.0-win64.zip
8cf317001aad7e3b51e3ab2e7a1ed7ae2004dab812445ee7715f8e13dfecae8c : luti.json
9bf2db228906eeeb7c8d5607892742205095e4bfe27e2e7f69a6a4e3db2c0ce8 : setup.py
7ef7acd47036d79571d82dc34daea4112b34b035702690f371b266e5da551127 : update_package.py