tis-sumatrapdf icon

Sumatra PDF

Paquet d’installation silencieuse pour Sumatra PDF

3.3.3-3

  • package: tis-sumatrapdf
  • name: Sumatra PDF
  • version: 3.3.3-3
  • categories: Media,Utilities
  • maintainer: WAPT Team,Tranquil IT,Jimmy PELÉ
  • editor: Krzysztof Kowalczyk, Simon Bünzli and others
  • licence: GPLv3
  • locale: all
  • target_os: windows
  • impacted_process: SumatraPDF
  • architecture: x86
  • signature_date:
  • size: 5.53 Mo
  • homepage : https://www.sumatrapdfreader.org/

package           : tis-sumatrapdf
version           : 3.3.3-3
architecture      : x86
section           : base
priority          : optional
name              : Sumatra PDF
categories        : Media,Utilities
maintainer        : WAPT Team,Tranquil IT,Jimmy PELÉ
description       : Sumatra PDF is a free PDF, eBook (ePub, Mobi), XPS, DjVu, CHM, Comic Book (CBZ and CBR) reader for Windows.
depends           : 
conflicts         : 
maturity          : PROD
locale            : all
target_os         : windows
min_wapt_version  : 1.7
sources           : https://www.sumatrapdfreader.org/download-free-pdf-viewer.html
installed_size    : 
impacted_process  : SumatraPDF
description_fr    : 
description_pl    : 
description_de    : 
description_es    : 
description_pt    : 
description_it    : 
description_nl    : 
description_ru    : 
audit_schedule    : 
editor            : Krzysztof Kowalczyk, Simon Bünzli and others
keywords          : 
licence           : GPLv3
homepage          : https://www.sumatrapdfreader.org/
package_uuid      : 9c0f8a67-a974-43e6-82ba-87a02145bd4d
valid_from        : 
valid_until       : 
forced_install_on : 
changelog         : https://www.sumatrapdfreader.org/docs/Version-history.html
min_os_version    : 6.0
max_os_version    : 
icon_sha256sum    : c57c7bd4990f3117be1a77cb7bb6244a88b5331c216a61bc3d4f6bf7b804bf4d
signer            : Tranquil IT
signer_fingerprint: 8c5127a75392be9cc9afd0dbae1222a673072c308c14d88ab246e23832e8c6bb
signature         : wUCD4/Gjqe9jqlsVWHfm+8g/mZf3Dl6QVPuX6gIVATdTmTc64ce07+RkHMYZrHqJzXoiCL3nUFm2LvTyEh5vBo1rBBrLo6VfLpKk/ASKouGmwWHYLSzwEc52Yt0cBGaHUTLeHh0wqBZIr73HlAr8LXUtlX+uTrl3hdDsBi15q7+t+Z3jwIRt112dG5vepxd1VOEA2ZKH891U6e4vVmq0ctHhliQ6CSRz4UzOqCd1JxMcZEDr8eTfpcqHZmXb+BAnb2iNIHqEcChnEp8EasSdYT6LItZiZCPeq9srd9RvfQkqBiBcCMODW68hMiTPq/j7/F+/uAqUESqKEn3imTtQJw==
signature_date    : 2021-09-28T17:41:07.841674
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 *
try:
    import bs4 as BeautifulSoup
except:
    import BeautifulSoup
import requests
import platform

uninstallkey = []

# Installation procedure: https://www.sumatrapdfreader.org/docs/Installer-cmd-line-arguments.html

# Defining variables
bin_name_string = 'SumatraPDF-%s-install.exe'
silent_args = '-s -d "%s"' % makepath(programfiles,'SumatraPDF')
app_uninstallkey = 'SumatraPDF'


def install():
    # Initializing variables
    package_version = control.version.split('-')[0]
    bin_name = bin_name_string % package_version
    app_name = control.name

    # Uninstalling older versions
    for uninstall in installed_softwares(uninstallkey=app_uninstallkey):
        if Version(uninstall['version']) < Version(package_version):
            print('Older %s version found (%s)' % (app_name,uninstall['version']))
            print('Removing: %s' % uninstall['name'])
            run(uninstall_cmd(uninstall['key']))

    # Installing the package
    install_exe_if_needed(bin_name
        ,silentflags=silent_args
        ,key=app_uninstallkey
        ,min_version=package_version)


def update_package():
    print('Download/Update package content from upstream binary sources')

    result = False
    proxies = get_proxies()
    if not proxies:
        proxies = get_proxies_from_wapt_console()

    # Initializing variables
    app_name = control.name
    url = control.sources
    bin_end = bin_name_string.split('%s')[-1]

    # Getting latest version from official website
    page = requests.get(url,proxies=proxies,headers={"User-Agent": "Mozilla/5.0 (Windows NT 10.0; Win64; x64) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/70.0.3538.77 Safari/537.36"}).text
    bs = BeautifulSoup.BeautifulSoup(page)
    bs_read = bs.findAll('a',{'onclick':'return SetupRedirect()'})
    for link in bs_read:
        if link['href'].endswith(bin_end):
            #https://www.sumatrapdfreader.org/dl2/SumatraPDF-3.2-64-install.exe
            url_dl = link['href']

    latest_bin = url_dl.split('/')[-1]
    version = latest_bin.split('-')[1]

    print("Latest %s version is: %s" % (app_name,version))
    print("Download url is: %s" % url_dl)

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

        # Checking version from file
        version_from_file = get_version_from_binary(latest_bin)
        if Version(version) != Version(version_from_file) 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_name_sub % version_from_file)
            version = version_from_file

    # 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
    control.version = '%s-%s' % (Version(version), control.version.split('-', 1)[-1])
    #control.set_software_version(Version(version))
    control.save_control_to_wapt()

    # Deleting outdated binaries
    remove_outdated_binaries(version)

    # Validating or not 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
    p = getproxies()
    if p :
        p['https'] = p['http']
    return p


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 bs_find(url, element, attribute=None, value=None, user_agent=None, proxies=None, features='html.parser', **kwargs):
    r""""Parse html web page with BeautifulSoup and get the first result

    Args:
        url (str): url of the web page to parse
        element (str): searched element
        attribute (str): selected attribute of the element
        value (str): value of the selected attribute
        user_agent (str): specify a user-agent if needed
        proxies (dict): specify your proxy if needed
        **kwargs (str): joker for requests parameters
        features (str): bs feature to use


    >>> bs_find('https://www.w3.org/', 'a', 'title', 'Open Web Platform testing')['href']
    'https://web-platform-tests.org/'

    >>> bs_find('https://www.w3.org/', 'span', 'class', 'alt-logo').string
    'W3C'

    .. versionadded:: 2.0

    """
    import requests
    if user_agent:
        page = requests.get(url, proxies=proxies, headers={'User-Agent':'%s' % user_agent}, **kwargs).text
    else:
        page = requests.get(url, proxies=proxies, **kwargs).text
    soup = BeautifulSoup.BeautifulSoup(page, features=features)
    if value:
        return soup.find(element, {attribute: value})
    else:
        return soup.find(element)


def bs_find_all(url, element, attribute=None, value=None, user_agent=None, proxies=None, features='html.parser', **kwargs):
    r""""Parse html web page with BeautifulSoup and get a list of the result

    Args:
        url (str): url of the web page to parse
        element (str): searched element
        attribute (str): selected attribute of the element
        value (str): value of the selected attribute
        user_agent (str): specify a user-agent if needed
        proxies (dict): specify your proxy if needed
        **kwargs (str): joker for requests parameters
        features (str): bs feature to use


    >>> bs_find_all('https://www.w3.org/', 'a', 'title', 'Open Web Platform testing')[0]['href']
    'https://web-platform-tests.org/'

    >>> bs_find_all('https://www.w3.org/', 'span', 'class', 'alt-logo')[0].string
    'W3C'

    .. versionadded:: 2.0

    """
    import requests
    if user_agent:
        page = requests.get(url, proxies=proxies, headers={'User-Agent':'%s' % user_agent}, **kwargs).text
    else:
        page = requests.get(url, proxies=proxies, **kwargs).text
    soup = BeautifulSoup.BeautifulSoup(page, features=features)
    if value:
        return soup.find_all(element, {attribute:value})
    else:
        return soup.find_all(element)


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, filename_contains=None, list_extensions=['exe','msi','deb','rpm','dmg','pkg']):
    r"""Remove files based on the version contained in his filename

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

    Returns:
        None

    .. versionadded:: 2.0

    """
    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:
                remove_file(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)



dc92aae274d849dd657b72d91539b9ae828efaab6831b6e1aa03840447e94b3b : setup.py
e4801235defdf5ae7c5e384d45ae867e7993bd5efc53ce26ce7df24a8065180b : SumatraPDF-3.3.3-install.exe
a5a97261381e1d0ad46ee15916abec9c2631d0201f5cc50ceb0197a165a0bbbf : WAPT/certificate.crt
c57c7bd4990f3117be1a77cb7bb6244a88b5331c216a61bc3d4f6bf7b804bf4d : WAPT/icon.png
f6632aa7bc05488002c2c5f2957bf48f52cf2ded4c93d4e10b204e5383cc9733 : WAPT/control