Adding new required packages.
This commit is contained in:
commit
2d1f741831
6 changed files with 152 additions and 57 deletions
10
README.md
Normal file
10
README.md
Normal file
|
@ -0,0 +1,10 @@
|
||||||
|
# accountfree-docker
|
||||||
|
---
|
||||||
|
|
||||||
|
This repository contains the Dockerfiles required to build AccountFree:
|
||||||
|
- ubuntu-pyside2-xvfb: Ubuntu focal base containing PySide2 (Qt for Python) & Xvfb (virtual X server that does not require a display).
|
||||||
|
- ubuntu-pyside2-xvfb-wine: Contains the latest wine installation, with Windows python3, PySide2 & pyinstaller + Xvfb.
|
||||||
|
- accountfree-build-img: Based on ubuntu-pyside2-xvfb, contains AccountFree dependencies to build it's Linux packages.
|
||||||
|
- accountfree-build-img: Based on ubuntu-pyside2-xvfb-wine, contains AccountFree dependencies to build it's Windows installer.
|
||||||
|
|
||||||
|
NOTE: In Docker, use xvfb-runto run a program within a Xvfb server.
|
|
@ -1,17 +1,15 @@
|
||||||
FROM ad5001/ubuntu-pyside2-xvfb-wine:win7-5.14.1
|
FROM ad5001/ubuntu-pyside2-xvfb-wine:win7-5.15.2
|
||||||
|
|
||||||
RUN apt-get update
|
RUN apt-get update
|
||||||
RUN apt install unzip nsis curl -y
|
RUN apt install unzip nsis curl -y
|
||||||
# Installing tor to not get the popup
|
RUN apt clean
|
||||||
RUN wget https://dist.torproject.org/torbrowser/9.0.5/tor-win64-0.4.2.6.zip
|
# Installing tor
|
||||||
RUN unzip tor-win64-0.4.2.6.zip -x Data/*
|
RUN wget https://dist.torproject.org/torbrowser/10.0.18/tor-win64-0.4.5.9.zip \
|
||||||
RUN mv Tor /wine/drive_c/
|
&& ls -la \
|
||||||
|
&& unzip tor-win64-0.4.5.9.zip -x Data/* \
|
||||||
|
&& rm tor-win64-0.4.5.9.zip \
|
||||||
|
&& mv Tor /wine/drive_c/
|
||||||
|
|
||||||
RUN wine reg ADD "HKEY_LOCAL_MACHINE\System\CurrentControlSet\Control\Session Manager\Environment" /v PATH /f /t REG_EXPAND_SZ /d "C:\windows\system32;C:\windows;C:\windows\system32\wbem;C:\Tor"
|
RUN wine reg ADD "HKEY_LOCAL_MACHINE\System\CurrentControlSet\Control\Session Manager\Environment" /v PATH /f /t REG_EXPAND_SZ /d "C:\windows\system32;C:\windows;C:\windows\system32\wbem;C:\Tor"
|
||||||
RUN rm tor-win64-0.4.2.6.zip
|
|
||||||
|
|
||||||
# Installing pyinstaller
|
|
||||||
RUN pip install pyinstaller
|
|
||||||
RUN echo 'wine '\''C:\Python37\Scripts\pyinstaller.exe'\'' "$@"' > /usr/bin/pyinstaller
|
|
||||||
RUN chmod +x /usr/bin/pyinstaller
|
|
||||||
|
|
||||||
# Installing dependencies
|
# Installing dependencies
|
||||||
RUN pip install pyside2 packaging socksipy-branch websocket-client stem requests
|
RUN pip install packaging websocket-client pywin32 stem requests
|
||||||
|
|
|
@ -1,5 +1,8 @@
|
||||||
FROM ad5001/ubuntu-pyside2-xvfb:eoan-5.13.2
|
FROM ad5001/ubuntu-pyside2-xvfb:hirsute-5.15.2
|
||||||
|
|
||||||
RUN apt-get update
|
ARG DEBIAN_FRONTEND=noninteractive
|
||||||
RUN apt-get -y install tor qml-module-qtqml-models2 qml-module-qtquick-controls python3-stdeb python-all python3-requests python3-stem flatpak-builder
|
|
||||||
RUN pip3 install pyside2 packaging socksipy-branch websocket-client
|
ENV TZ=Europe/Paris
|
||||||
|
RUN apt-get update && apt-get upgrade -y
|
||||||
|
RUN apt-get -y install tor qml-module-qtqml-models2 qml-module-qtquick-controls python3-stdeb python-all python3-requests python3-stem rpm dh-python flatpak-builder
|
||||||
|
RUN pip3 install packaging websocket-client
|
||||||
|
|
|
@ -1,27 +1,26 @@
|
||||||
FROM ubuntu:19.10
|
FROM ubuntu:hirsute
|
||||||
|
|
||||||
|
ARG PYSIDE2_VERSION=5.15.2
|
||||||
|
|
||||||
|
# Adapted rom https://github.com/cdrx/docker-pyinstaller/blob/master/Dockerfile-py3-win64
|
||||||
|
# Unupdated for a while.
|
||||||
|
|
||||||
|
ENV DEBIAN_FRONTEND noninteractive
|
||||||
|
|
||||||
# Some of the work here comes from cdrx/docker-pyinstaller adapted for drone and with modifications for Qt
|
|
||||||
ARG WINE_VERSION=winehq-staging
|
ARG WINE_VERSION=winehq-staging
|
||||||
ARG PYTHON_VERSION=3.7.6
|
ARG PYTHON_VERSION=3.9.6
|
||||||
ARG PYINSTALLER_VERSION=3.6
|
ARG PYINSTALLER_VERSION=4.3
|
||||||
|
|
||||||
# Installing dependencies
|
# we need wine for this all to work, so we'll use the PPA
|
||||||
RUN set -x \
|
RUN set -x \
|
||||||
&& dpkg --add-architecture i386 \
|
&& dpkg --add-architecture i386 \
|
||||||
&& apt-get update -qy \
|
&& apt-get update -qy \
|
||||||
&& apt-get upgrade -qy \
|
&& apt-get install --no-install-recommends -qfy rename apt-transport-https software-properties-common wget gpg-agent \
|
||||||
&& apt-get install --no-install-recommends -qfy rename gpg-agent apt-transport-https software-properties-common wget curl p7zip
|
|
||||||
#&& apt-get install --no-install-recommends -qfy gcc-multilib libasound2-dev:i386 libgsm1-dev:i386 libjpeg8-dev:i386 liblcms2-dev:i386 libldap2-dev:i386 libmpg123-dev:i386 libopenal-dev:i386 libv4l-dev:i386 libx11-dev:i386 libxinerama-dev:i386 libxml2-dev:i386 zlib1g-dev:i386 \
|
|
||||||
#&& apt-get install --no-install-recommends -qfy libcapi20-dev:i386 libcups2:i386 libdbus-1-3:i386 libfontconfig:i386 libfreetype6:i386 libglu1-mesa:i386 libgphoto2-6:i386 libncurses5:i386 libosmesa6:i386 libsane:i386 libxcomposite1:i386 libxcursor1:i386 libxi6:i386 libxrandr2:i386 libxslt1.1:i386 ocl-icd-libopencl1:i386 libgd3:i386
|
|
||||||
# We need wine for this all to work, so we'll use the PPA
|
|
||||||
RUN set -x \
|
|
||||||
&& wget -nv https://dl.winehq.org/wine-builds/winehq.key \
|
&& wget -nv https://dl.winehq.org/wine-builds/winehq.key \
|
||||||
&& apt-key add winehq.key \
|
&& apt-key add winehq.key \
|
||||||
&& add-apt-repository 'https://dl.winehq.org/wine-builds/ubuntu/' \
|
&& add-apt-repository 'https://dl.winehq.org/wine-builds/ubuntu/' \
|
||||||
&& apt-get update -qy \
|
&& apt-get update -qy \
|
||||||
&& apt-get install --no-install-recommends -qfy wine-staging-amd64 wine-staging \
|
|
||||||
&& apt-get install --no-install-recommends -qfy $WINE_VERSION winbind cabextract \
|
&& apt-get install --no-install-recommends -qfy $WINE_VERSION winbind cabextract \
|
||||||
&& apt-get clean \
|
|
||||||
&& wget -nv https://raw.githubusercontent.com/Winetricks/winetricks/master/src/winetricks \
|
&& wget -nv https://raw.githubusercontent.com/Winetricks/winetricks/master/src/winetricks \
|
||||||
&& chmod +x winetricks \
|
&& chmod +x winetricks \
|
||||||
&& mv winetricks /usr/local/bin
|
&& mv winetricks /usr/local/bin
|
||||||
|
@ -42,18 +41,19 @@ RUN set -x \
|
||||||
&& winetricks win7 \
|
&& winetricks win7 \
|
||||||
&& for msifile in `echo core dev exe lib path pip tcltk tools`; do \
|
&& for msifile in `echo core dev exe lib path pip tcltk tools`; do \
|
||||||
wget -nv "https://www.python.org/ftp/python/$PYTHON_VERSION/amd64/${msifile}.msi"; \
|
wget -nv "https://www.python.org/ftp/python/$PYTHON_VERSION/amd64/${msifile}.msi"; \
|
||||||
wine msiexec /i "${msifile}.msi" /qb TARGETDIR=C:/Python37; \
|
wine msiexec /i "${msifile}.msi" /qb TARGETDIR=C:/Python39; \
|
||||||
rm ${msifile}.msi; \
|
rm ${msifile}.msi; \
|
||||||
done \
|
done \
|
||||||
&& cd /wine/drive_c/Python37 \
|
&& cd /wine/drive_c/Python39 \
|
||||||
&& echo 'wine '\''C:\Python37\python.exe'\'' "$@"' > /usr/bin/python \
|
&& echo 'wine '\''C:\Python39\python.exe'\'' "$@"' > /usr/bin/python \
|
||||||
&& echo 'wine '\''C:\Python37\Scripts\easy_install.exe'\'' "$@"' > /usr/bin/easy_install \
|
&& echo 'wine '\''C:\Python39\Scripts\easy_install.exe'\'' "$@"' > /usr/bin/easy_install \
|
||||||
&& echo 'wine '\''C:\Python37\Scripts\pip.exe'\'' "$@"' > /usr/bin/pip \
|
&& echo 'wine '\''C:\Python39\Scripts\pip.exe'\'' "$@"' > /usr/bin/pip \
|
||||||
&& echo 'wine '\''C:\Python37\Scripts\pyupdater.exe'\'' "$@"' > /usr/bin/pyupdater \
|
&& echo 'wine '\''C:\Python39\Scripts\pyinstaller.exe'\'' "$@"' > /usr/bin/pyinstaller \
|
||||||
|
&& echo 'wine '\''C:\Python39\Scripts\pyupdater.exe'\'' "$@"' > /usr/bin/pyupdater \
|
||||||
&& echo 'assoc .py=PythonScript' | wine cmd \
|
&& echo 'assoc .py=PythonScript' | wine cmd \
|
||||||
&& echo 'ftype PythonScript=c:\Python37\python.exe "%1" %*' | wine cmd \
|
&& echo 'ftype PythonScript=c:\Python39\python.exe "%1" %*' | wine cmd \
|
||||||
&& while pgrep wineserver >/dev/null; do echo "Waiting for wineserver"; sleep 1; done \
|
&& while pgrep wineserver >/dev/null; do echo "Waiting for wineserver"; sleep 1; done \
|
||||||
&& chmod +x /usr/bin/python /usr/bin/easy_install /usr/bin/pip /usr/bin/pyupdater \
|
&& chmod +x /usr/bin/python /usr/bin/easy_install /usr/bin/pip /usr/bin/pyinstaller /usr/bin/pyupdater \
|
||||||
&& (pip install -U pip || true) \
|
&& (pip install -U pip || true) \
|
||||||
&& rm -rf /tmp/.wine-*
|
&& rm -rf /tmp/.wine-*
|
||||||
|
|
||||||
|
@ -65,7 +65,7 @@ ENV W_TMP="$W_DRIVE_C/windows/temp/_$0"
|
||||||
# install Microsoft Visual C++ Redistributable for Visual Studio 2017 dll files
|
# install Microsoft Visual C++ Redistributable for Visual Studio 2017 dll files
|
||||||
RUN set -x \
|
RUN set -x \
|
||||||
&& rm -f "$W_TMP"/* \
|
&& rm -f "$W_TMP"/* \
|
||||||
&& wget -P "$W_TMP" https://download.visualstudio.microsoft.com/download/pr/11100230/15ccb3f02745c7b206ad10373cbca89b/VC_redist.x64.exe \
|
&& wget -P "$W_TMP" -v https://download.visualstudio.microsoft.com/download/pr/11100230/15ccb3f02745c7b206ad10373cbca89b/VC_redist.x64.exe \
|
||||||
&& cabextract -q --directory="$W_TMP" "$W_TMP"/VC_redist.x64.exe \
|
&& cabextract -q --directory="$W_TMP" "$W_TMP"/VC_redist.x64.exe \
|
||||||
&& cabextract -q --directory="$W_TMP" "$W_TMP/a10" \
|
&& cabextract -q --directory="$W_TMP" "$W_TMP/a10" \
|
||||||
&& cabextract -q --directory="$W_TMP" "$W_TMP/a11" \
|
&& cabextract -q --directory="$W_TMP" "$W_TMP/a11" \
|
||||||
|
@ -73,18 +73,9 @@ RUN set -x \
|
||||||
&& rename 's/_/\-/g' *.dll \
|
&& rename 's/_/\-/g' *.dll \
|
||||||
&& cp "$W_TMP"/*.dll "$W_SYSTEM64_DLLS"/
|
&& cp "$W_TMP"/*.dll "$W_SYSTEM64_DLLS"/
|
||||||
|
|
||||||
# Installing Xvfb to display
|
# Additional data for PySide2
|
||||||
RUN apt-get install xvfb git p7zip-full -y
|
|
||||||
|
|
||||||
ARG QT_VERSION=5.14.1
|
RUN apt install -y wget curl p7zip-full git xvfb
|
||||||
ARG QT_COMPONENTS="qtbase qtquickcontrols qtquickcontrols2 qtmultimedia qtimageformats qtgraphicaleffects qtdeclarative qtconnectivity qtcharts"
|
RUN apt clean
|
||||||
|
# Installing pyside2 & pyinstaller
|
||||||
# Installing Qt & PySide2
|
RUN pip install wheel PySide2==$PYSIDE2_VERSION pyinstaller==$PYINSTALLER_VERSION
|
||||||
# Gathering silent install script
|
|
||||||
# RUN wget https://download.ad5001.eu/other/qt-noninteractive-install.qs
|
|
||||||
# RUN mv qt-noninteractive-install.qs /wine/drive_c/
|
|
||||||
RUN wget https://download.ad5001.eu/other/install-qt.sh \
|
|
||||||
&& chmod +x install-qt.sh \
|
|
||||||
&& ./install-qt.sh --host windows_x86 --version $QT_VERSION --directory /wine/drive_c/Qt --toolchain win64_msvc2017_64 $QT_COMPONENTS
|
|
||||||
RUN rm install-qt.sh
|
|
||||||
RUN pip install PySide2
|
|
||||||
|
|
89
ubuntu-pyside2-xvfb-wine/Dockerfile-old
Normal file
89
ubuntu-pyside2-xvfb-wine/Dockerfile-old
Normal file
|
@ -0,0 +1,89 @@
|
||||||
|
FROM ubuntu:20.04
|
||||||
|
|
||||||
|
# Some of the work here comes from cdrx/docker-pyinstaller adapted for drone and with modifications for Qt
|
||||||
|
ARG WINE_VERSION=winehq-staging
|
||||||
|
ARG PYTHON_VERSION=3.7.5
|
||||||
|
ENV DEBIAN_FRONTEND "noninteractive"
|
||||||
|
|
||||||
|
# Installing dependencies
|
||||||
|
RUN set -x \
|
||||||
|
&& dpkg --add-architecture i386 \
|
||||||
|
&& apt-get update -qy \
|
||||||
|
&& apt-get upgrade -qy \
|
||||||
|
&& apt-get install --no-install-recommends -qfy rename gpg-agent apt-transport-https software-properties-common wget curl p7zip-full git xvfb
|
||||||
|
# We need wine for this all to work, so we'll use the PPA
|
||||||
|
RUN set -x \
|
||||||
|
&& wget -nv https://dl.winehq.org/wine-builds/winehq.key \
|
||||||
|
&& apt-key add winehq.key \
|
||||||
|
&& add-apt-repository 'https://dl.winehq.org/wine-builds/ubuntu/' \
|
||||||
|
&& apt-get update -qy \
|
||||||
|
&& apt-get install --no-install-recommends -qfy $WINE_VERSION winbind cabextract \
|
||||||
|
&& apt-get clean \
|
||||||
|
&& wget -nv https://raw.githubusercontent.com/Winetricks/winetricks/master/src/winetricks \
|
||||||
|
&& chmod +x winetricks \
|
||||||
|
&& mv winetricks /usr/local/bin
|
||||||
|
|
||||||
|
RUN apt-get clean
|
||||||
|
|
||||||
|
# wine settings
|
||||||
|
ENV WINEARCH win64
|
||||||
|
ENV WINEDEBUG fixme-all
|
||||||
|
ENV WINEPREFIX /wine
|
||||||
|
|
||||||
|
# PYPI repository location
|
||||||
|
ENV PYPI_URL=https://pypi.python.org/
|
||||||
|
# PYPI index location
|
||||||
|
ENV PYPI_INDEX_URL=https://pypi.python.org/simple
|
||||||
|
|
||||||
|
# install python in wine, using the msi packages to install, extracting
|
||||||
|
# the files directly, since installing isn't running correctly.
|
||||||
|
RUN set -x \
|
||||||
|
&& winetricks win7 \
|
||||||
|
&& for msifile in `echo core dev exe lib path pip tools`; do \
|
||||||
|
wget -nv "https://www.python.org/ftp/python/$PYTHON_VERSION/amd64/${msifile}.msi"; \
|
||||||
|
wine msiexec /i "${msifile}.msi" /qb TARGETDIR=C:/Python37; \
|
||||||
|
echo "Installed ${msifile}"; \
|
||||||
|
rm ${msifile}.msi; \
|
||||||
|
done \
|
||||||
|
&& cd /wine/drive_c/Python37 \
|
||||||
|
&& echo 'wine '\''C:\Python37\python.exe'\'' "$@"' > /usr/bin/python \
|
||||||
|
&& echo 'wine '\''C:\Python37\Scripts\easy_install.exe'\'' "$@"' > /usr/bin/easy_install \
|
||||||
|
&& echo 'wine '\''C:\Python37\Scripts\pip.exe'\'' "$@"' > /usr/bin/pip \
|
||||||
|
&& echo 'wine '\''C:\Python37\Scripts\pyupdater.exe'\'' "$@"' > /usr/bin/pyupdater \
|
||||||
|
&& echo 'assoc .py=PythonScript' | wine cmd \
|
||||||
|
&& echo 'ftype PythonScript=c:\Python37\python.exe "%1" %*' | wine cmd \
|
||||||
|
&& while pgrep wineserver >/dev/null; do echo "Waiting for wineserver"; sleep 1; done \
|
||||||
|
&& chmod +x /usr/bin/python /usr/bin/easy_install /usr/bin/pip /usr/bin/pyupdater \
|
||||||
|
&& (pip install -U pip || true) \
|
||||||
|
&& rm -rf /tmp/.wine-*
|
||||||
|
|
||||||
|
ENV W_DRIVE_C=/wine/drive_c
|
||||||
|
ENV W_WINDIR_UNIX="$W_DRIVE_C/windows"
|
||||||
|
ENV W_SYSTEM64_DLLS="$W_WINDIR_UNIX/system32"
|
||||||
|
ENV W_TMP="$W_DRIVE_C/windows/temp/_$0"
|
||||||
|
|
||||||
|
# install Microsoft Visual C++ Redistributable for Visual Studio 2017 dll files
|
||||||
|
RUN set -x \
|
||||||
|
&& rm -f "$W_TMP"/* \
|
||||||
|
&& wget -P "$W_TMP" https://download.visualstudio.microsoft.com/download/pr/11100230/15ccb3f02745c7b206ad10373cbca89b/VC_redist.x64.exe \
|
||||||
|
&& cabextract -q --directory="$W_TMP" "$W_TMP"/VC_redist.x64.exe \
|
||||||
|
&& cabextract -q --directory="$W_TMP" "$W_TMP/a10" \
|
||||||
|
&& cabextract -q --directory="$W_TMP" "$W_TMP/a11" \
|
||||||
|
&& cd "$W_TMP" \
|
||||||
|
&& rename 's/_/\-/g' *.dll \
|
||||||
|
&& cp "$W_TMP"/*.dll "$W_SYSTEM64_DLLS"/
|
||||||
|
|
||||||
|
|
||||||
|
ARG QT_VERSION=5.14.1
|
||||||
|
ARG QT_COMPONENTS="qtbase qtquickcontrols qtquickcontrols2 qtmultimedia qtimageformats qtgraphicaleffects qtdeclarative qtconnectivity qtcharts"
|
||||||
|
|
||||||
|
# Installing Qt & PySide2
|
||||||
|
# Gathering silent install script
|
||||||
|
# RUN wget https://download.ad5001.eu/other/qt-noninteractive-install.qs
|
||||||
|
# RUN mv qt-noninteractive-install.qs /wine/drive_c/
|
||||||
|
#RUN wget https://download.ad5001.eu/other/install-qt.sh \
|
||||||
|
# && chmod +x install-qt.sh \
|
||||||
|
# && ./install-qt.sh --host windows_x86 --version $QT_VERSION --directory /wine/drive_c/Qt --toolchain win64_msvc2017_64 $QT_COMPONENTS
|
||||||
|
#RUN rm install-qt.sh
|
||||||
|
RUN ls /wine/drive_c/Python37/Scripts
|
||||||
|
RUN /usr/bin/pip install PySide2 pyinstaller
|
|
@ -1,5 +1,9 @@
|
||||||
FROM ubuntu:eoan
|
FROM ubuntu:hirsute
|
||||||
|
|
||||||
|
ARG DEBIAN_FRONTEND=noninteractive
|
||||||
|
ARG PYSIDE2_VERSION=5.15.2
|
||||||
|
|
||||||
|
ENV TZ=Europe/Paris
|
||||||
RUN apt-get update
|
RUN apt-get update
|
||||||
RUN apt-get -y install qt5-default make git python3-pip qml-module-qtquick-controls2 qml-module-qtmultimedia qml-module-qtgraphicaleffects qml-module-qtquick2 xvfb
|
RUN apt-get -y install make git python3-pip qml-module-qtquick-controls2 qml-module-qtmultimedia qml-module-qtgraphicaleffects qml-module-qtquick2 xvfb
|
||||||
RUN pip3 install PySide2
|
RUN pip3 install PySide2==$PYSIDE2_VERSION
|
||||||
|
|
Loading…
Reference in a new issue