tis-dia icon

Dia

Silent install package for Dia

0.97.2-4

  • package: tis-dia
  • name: Dia
  • version: 0.97.2-4
  • categories: Utilities
  • maintainer: WAPT Team,Tranquil IT,Pierre Cosson
  • editor: Steffen Macke
  • licence: GPLv2
  • locale: all
  • target_os: windows
  • impacted_process: dia,diaw,dia-win-remote
  • architecture: all
  • signature_date:
  • size: 21.99 Mo
  • installed_size: 71.25 Mo
  • homepage : http://dia-installer.de/index.html.en

package           : tis-dia
version           : 0.97.2-4
architecture      : all
section           : base
priority          : optional
name              : Dia
categories        : Utilities
maintainer        : WAPT Team,Tranquil IT,Pierre Cosson
description       : Dia is a program to draw structured diagrams.
depends           : 
conflicts         : 
maturity          : PROD
locale            : all
target_os         : windows
min_wapt_version  : 2.0
sources           : http://dia-installer.de/index.html.en
installed_size    : 71249920
impacted_process  : dia,diaw,dia-win-remote
description_fr    : Dia est un programme permettant de dessiner des diagrammes structurés.
description_pl    : Dia to program do rysowania diagramów strukturalnych.
description_de    : Dia ist ein Programm zum Zeichnen von strukturierten Diagrammen.
description_es    : Dia es un programa para dibujar diagramas estructurados.
description_pt    : Dia é um programa para desenhar diagramas estruturados.
description_it    : Dia è un programma per disegnare diagrammi strutturati.
description_nl    : Dia is een programma om gestructureerde diagrammen te tekenen.
description_ru    : Dia - это программа для рисования структурированных диаграмм.
audit_schedule    : 
editor            : Steffen Macke
keywords          : visio
licence           : GPLv2
homepage          : http://dia-installer.de/index.html.en
package_uuid      : e596b0c0-0f19-4c3b-b223-35a6a46f192b
valid_from        : 
valid_until       : 
forced_install_on : 
changelog         : 
min_os_version    : 6.1
max_os_version    : 
icon_sha256sum    : fbd5dae2b729fc1025d5b0c321bf942433ba8b98e35b1da28642979193a1e67a
signer            : Tranquil IT
signer_fingerprint: 8c5127a75392be9cc9afd0dbae1222a673072c308c14d88ab246e23832e8c6bb
signature         : NQzawThG9PCJglfC6lS3gzma6sQtuY2ukaGs2m+ZwTrSjaTDirGAV8ht5hPCWoINR7xzEU52IUcIRb04KWG2zELOhi/faWJuDRuodzav++zqtyMyZys6lVxfE7y7Cj45ZAo9QVQHPvyGKBYI94PYzQmDgr4EKZrjiQCiIzPoLhhbCDSzW9plMFptYslC/OE5+tOs1qfLr/EFi5OmDyPZ7GPZcVL1lti3ZwjOsso3Bh/4Wwn/b3e7X4pN+ydSgDQqDO2kyWD7nXIbNi8cG3b7LV9QOYu974JtkwrwFOp4I+J5958hkWiOZa039qITkByW/wwcBrRWUgvOSuFUQ4b7Pg==
signature_date    : 2022-05-25T13:00:51.277984
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

# -*- coding: utf-8 -*-
from setuphelpers import *
import platform
import json

r"""
Usable WAPT package functions: install(), uninstall(), session_setup(), audit(), update_package()

"""
# Declaring global variables - Warnings: 1) WAPT context is only available in package functions; 2) Global variables are not persistent between calls
bin_contains = "dia"
app_name = "Dia"
app_dir = makepath(programfiles32, app_name)
app_path = makepath(app_dir, "bin", "diaw.exe")


def install():
    # Declaring local variables
    package_version = control.get_software_version()
    bin_name = glob.glob("*%s*.zip" % bin_contains)[0]

    # Getting installed software version
    if isfile(app_path):
        installed_version = get_version_from_binary(app_path)
    else:
        installed_version = None

    # Installing software
    print("Installing: %s" % app_name)
    if installed_version is None or Version(installed_version) < Version(package_version) or force:
        killalltasks(control.get_impacted_process_list())
        if isdir(app_dir):
            remove_tree(app_dir)
        mkdirs(app_dir)
        print("Extracting: %s to: %s" % (bin_name, app_dir))
        unzip(bin_name, app_dir)

        # Creating shortcuts
        # "C:\Program Files\Octave\mingw64\share\octave\6.4.0\imagelib\octave-logo.ico"

        create_desktop_shortcut(app_name, app_path)
        create_programs_menu_shortcut(app_name, app_path)

        # Adding software to "list-registry"
        print("Registering: %s to Windows Registry" % app_name)
        register_windows_uninstall(control, win64app=iswin64())
        register_uninstall(app_name, win64app=iswin64())
    else:
        print("%s is already installed. Skipping" % app_name)


def uninstall():
    # Uninstalling software
    killalltasks(control.get_impacted_process_list())
    if isdir(app_dir):
        remove_tree(app_dir)
    unregister_uninstall(app_name, win64app=iswin64())

    # Removing shortcuts
    remove_desktop_shortcut(app_name)
    remove_programs_menu_shortcut(app_name)


def audit():
    # Declaring local variables
    package_version = control.version.split("-", 1)[0]

    # Getting installed software version
    if installed_softwares(uninstallkey=app_name):
        installed_version = installed_softwares(uninstallkey=app_name)[0]["version"]
    else:
        installed_version = None

    # Auditing software
    print("Auditing: %s" % control.package)
    if installed_version is None:
        print("%s is not installed" % app_name)
        return "ERROR"
    elif Version(installed_version) != Version(package_version):
        print("%s is installed in version (%s) instead of (%s)" % (app_name, installed_version, package_version))
        return "WARNING"
    else:
        print("%s is installed in correct version (%s)" % (app_name, installed_version))
        return "OK"


def update_package():
    # Declaring local variables
    result = False
    proxies = get_proxies()
    if not proxies:
        proxies = get_proxies_from_wapt_console()
    app_name = control.name
    api_url = "https://sourceforge.net/projects/dia-installer/best_release.json"

    # Getting latest version information from official sources
    print("API used is: %s" % api_url)
    json_load = json.loads(wgets(api_url, proxies=proxies))
    for download in json_load["platform_releases"]:
        if "dia-setup" in json_load["platform_releases"][download]["filename"]:
            version = json_load["platform_releases"][download]["filename"].split("/")[-2]
            download_url = "http://sourceforge.net/projects/dia-installer/files/dia/%s/dia_%s_win32.zip/download" % (version, version)

            latest_bin = download_url.split("/")[-2]
            break

    print("Latest %s version is: %s" % (app_name, version))
    print("Download URL is: %s" % download_url)

    # Downloading latest binaries
    if not isfile(latest_bin):
        print("Downloading: %s" % latest_bin)
        wget(download_url, latest_bin, proxies=proxies)

        # Checking version from file
        version_from_file = get_version_from_binary(latest_bin)
        # if not version_from_file.startswith(version) and version_from_file != '':
        if Version(version_from_file) != Version(version) and version_from_file != "":
            print("Changing version to the version number of the binary (from: %s to: %s)" % (version, version_from_file))
            os.rename(latest_bin, bin_contains + version_from_file + ".exe")
            version = version_from_file
        else:
            print("Binary file version corresponds to online version")

    # Changing version of the package
    if Version(version) > Version(control.get_software_version()):
        print("Software version updated (from: %s to: %s)" % (control.get_software_version(), Version(version)))
        result = True
    else:
        print("Software version up-to-date (%s)" % Version(version))
    control.version = "%s-%s" % (Version(version), control.version.split("-", 1)[-1])
    # control.set_software_version(version)
    control.save_control_to_wapt()

    # Deleting outdated binaries
    remove_outdated_binaries(version)

    # Validating update-package-sources
    return result


def get_proxies():
    r"""Return system proxy with the urllib python library

    >>> get_proxies()
    {'http': 'http://srvproxy.ad.domain.lan:8080',
    'https': 'http://srvproxy.ad.domain.lan:8080'}

    """
    if platform.python_version_tuple()[0] == "3":
        from urllib.request import getproxies
    else:
        from urllib import getproxies
    return getproxies()


def get_proxies_from_wapt_console():
    r"""Return proxy information from the current user WAPT console

    >>> get_proxies_from_wapt_console()
    {'http': 'http://srvproxy.ad.domain.lan:8080',
    'https': 'http://srvproxy.ad.domain.lan:8080'}

    """
    proxies = {}
    if platform.system() == "Windows":
        waptconsole_ini_path = makepath(user_local_appdata(), "waptconsole", "waptconsole.ini")
    else:
        waptconsole_ini_path = makepath(user_home_directory(), ".config", "waptconsole", "waptconsole.ini")
    if isfile(waptconsole_ini_path):
        proxy_wapt = inifile_readstring(waptconsole_ini_path, "global", "http_proxy")
        if proxy_wapt:
            proxies = {"http": proxy_wapt, "https": proxy_wapt}
    return proxies


def get_version_from_binary(filename, property_name="ProductVersion"):
    r"""Get installer version from file informations, for now, only exe and msi files are compatibles

    Args:
        filename (str): path to the file
        property_name (str): selected property

    Returns:
        str: version number

    """
    if filename.endswith(".msi"):
        return get_msi_properties(filename)[property_name]
    else:
        return get_file_properties(filename)[property_name]


def remove_outdated_binaries(version, list_extensions=["exe", "msi", "deb", "rpm", "dmg", "pkg"], filename_contains=None):
    r"""Remove files based on the version contained in his filename, failing over on file version on compatible OSes

    Args:
        version (str): version number of keeped files
        list_extensions (str or list of str): file extensions of compared files
        filename_contains (str or list of str): Part of the filename that must be contained (useful for distinguishing architecture and os)

    Returns:
        list: list of deleted files

    .. versionadded:: 2.0

    .. versionchanged:: 2.2
        Now returns removed files, now checking .exe and .msi file versions

    """
    files = []
    if type(list_extensions) != list:
        list_extensions = [list_extensions]
    if filename_contains:
        if type(filename_contains) != list:
            filename_contains = [filename_contains]
    list_extensions = ["." + ext for ext in list_extensions if ext[0] != "."]
    for file_ext in list_extensions:
        for bin_in_dir in glob.glob("*%s" % file_ext):
            if not version in bin_in_dir:
                if platform.system() == "Windows":
                    if file_ext == ".exe" or file_ext == ".msi":
                        if Version(version) == Version(get_version_from_binary(bin_in_dir, "FileVersion")) or Version(version) == Version(
                            get_version_from_binary(bin_in_dir, "ProductVersion")
                        ):
                            print("%s file or product version is correct (%s)" % (bin_in_dir, version))
                            continue
                remove_file(bin_in_dir)
                files.append(bin_in_dir)
            if filename_contains:
                for filename_contain in filename_contains:
                    if not filename_contain in bin_in_dir:
                        remove_file(bin_in_dir)
                        files.append(bin_in_dir)
    return [fn for fn in files]

9a65e924fc86d6f74b02d4c4a24c3021cad44d70e41961c9fedfb28b8cca18b9 : dia_0.97.2_win32.zip
1d8f35b36385e64b84978c3119431e123dced367c05f297cd515d58e5f8cd1d1 : setup.py
fbd5dae2b729fc1025d5b0c321bf942433ba8b98e35b1da28642979193a1e67a : WAPT/icon.png
a5a97261381e1d0ad46ee15916abec9c2631d0201f5cc50ceb0197a165a0bbbf : WAPT/certificate.crt
9c8509eea5b7a97c09bc13cef743be89c1035464949094f92ab11e8ffa964095 : luti.json
960ca5f9e2d80fcb0cd9a7eff183fa182e5b664bcd9228d1babb8453dd112302 : WAPT/control