mirror of
https://github.com/xtekky/gpt4free.git
synced 2024-11-22 15:05:57 +03:00
Change default port for gui
Change default host for api Disable gui in build Add custom docker user
This commit is contained in:
parent
d743ee0c26
commit
b2d02ed624
@ -10,6 +10,6 @@ services:
|
|||||||
volumes:
|
volumes:
|
||||||
- .:/app
|
- .:/app
|
||||||
ports:
|
ports:
|
||||||
- '8080:80'
|
- '8080:8080'
|
||||||
- '1337:1337'
|
- '1337:1337'
|
||||||
- '7900:7900'
|
- '7900:7900'
|
@ -1,13 +1,27 @@
|
|||||||
FROM selenium/node-chrome
|
FROM selenium/node-chrome
|
||||||
|
|
||||||
ENV SE_SCREEN_WIDTH 1850
|
ENV SE_SCREEN_WIDTH 1850
|
||||||
ENV G4F_LOGIN_URL http://localhost:7900/?autoconnect=1&resize=scale&password=secret
|
|
||||||
ENV PYTHONUNBUFFERED 1
|
ENV PYTHONUNBUFFERED 1
|
||||||
|
ENV G4F_DIR /app
|
||||||
|
ENV G4F_LOGIN_URL http://localhost:7900/?autoconnect=1&resize=scale&password=secret
|
||||||
ARG G4F_VERSION
|
ARG G4F_VERSION
|
||||||
ENV G4F_VERSION ${G4F_VERSION}
|
ENV G4F_VERSION ${G4F_VERSION}
|
||||||
|
ARG G4F_USER
|
||||||
|
ENV G4F_USER ${G4F_USER:-g4f}
|
||||||
|
ARG G4F_USER_ID
|
||||||
|
ENV G4F_USER_ID ${G4F_USER_ID:-1000}
|
||||||
|
ARG G4F_NO_GUI
|
||||||
|
ENV G4F_NO_GUI ${G4F_NO_GUI}
|
||||||
|
ENV HOME /home/$G4F_USER
|
||||||
|
|
||||||
USER root
|
USER root
|
||||||
|
|
||||||
|
# If docker compose, install git
|
||||||
|
RUN if [ "$G4F_VERSION" = "" ] ; then \
|
||||||
|
apt-get -qqy update && \
|
||||||
|
apt-get -qqy install git \
|
||||||
|
; fi
|
||||||
|
|
||||||
# Python packages
|
# Python packages
|
||||||
RUN apt-get -qqy update \
|
RUN apt-get -qqy update \
|
||||||
&& apt-get -qqy install \
|
&& apt-get -qqy install \
|
||||||
@ -22,24 +36,32 @@ RUN rm -rf /var/lib/apt/lists/* /var/cache/apt/* \
|
|||||||
|
|
||||||
# Update entrypoint
|
# Update entrypoint
|
||||||
COPY docker/supervisor.conf /etc/supervisor/conf.d/selenium.conf
|
COPY docker/supervisor.conf /etc/supervisor/conf.d/selenium.conf
|
||||||
|
COPY docker/supervisor-gui.conf /etc/supervisor/conf.d/gui.conf
|
||||||
|
|
||||||
|
# If no gui
|
||||||
|
RUN if [ "$G4F_NO_GUI" ] ; then \
|
||||||
|
rm /etc/supervisor/conf.d/gui.conf \
|
||||||
|
; fi
|
||||||
|
|
||||||
# Change background image
|
# Change background image
|
||||||
COPY docker/background.png /usr/share/images/fluxbox/ubuntu-light.png
|
COPY docker/background.png /usr/share/images/fluxbox/ubuntu-light.png
|
||||||
|
|
||||||
# Switch user
|
# Switch user
|
||||||
USER 1200
|
RUN groupadd -g $G4F_USER_ID $G4F_USER
|
||||||
|
RUN useradd -rm -G sudo -u $G4F_USER_ID -g $G4F_USER_ID $G4F_USER
|
||||||
|
USER $G4F_USER_ID
|
||||||
|
|
||||||
# Set the working directory in the container.
|
# Set the working directory in the container.
|
||||||
WORKDIR /app
|
WORKDIR $G4F_DIR
|
||||||
|
|
||||||
# Copy the project's requirements file into the container.
|
# Copy the project's requirements file into the container.
|
||||||
COPY requirements.txt /app/
|
COPY requirements.txt $G4F_DIR
|
||||||
|
|
||||||
# Upgrade pip for the latest features and install the project's Python dependencies.
|
# Upgrade pip for the latest features and install the project's Python dependencies.
|
||||||
RUN pip install --upgrade pip && pip install -r requirements.txt
|
RUN pip install --upgrade pip && pip install -r requirements.txt
|
||||||
|
|
||||||
# Copy the entire package into the container.
|
# Copy the entire package into the container.
|
||||||
COPY g4f /app/g4f
|
ADD --chown=$G4F_USER g4f $G4F_DIR/
|
||||||
|
|
||||||
# Expose ports
|
# Expose ports
|
||||||
EXPOSE 80 1337
|
EXPOSE 8080 1337
|
12
docker/supervisor-gui.conf
Executable file
12
docker/supervisor-gui.conf
Executable file
@ -0,0 +1,12 @@
|
|||||||
|
[program:g4f-gui]
|
||||||
|
priority=15
|
||||||
|
command=python -m g4f.cli gui
|
||||||
|
directory=/app
|
||||||
|
stopasgroup=true
|
||||||
|
autostart=true
|
||||||
|
autorestart=true
|
||||||
|
|
||||||
|
;Logs (all Hub activity redirected to stdout so it can be seen through "docker logs"
|
||||||
|
redirect_stderr=true
|
||||||
|
stdout_logfile=/dev/stdout
|
||||||
|
stdout_logfile_maxbytes=0
|
@ -57,19 +57,6 @@ stopasgroup=true
|
|||||||
autostart=true
|
autostart=true
|
||||||
autorestart=true
|
autorestart=true
|
||||||
|
|
||||||
;Logs (all Hub activity redirected to stdout so it can be seen through "docker logs"
|
|
||||||
redirect_stderr=true
|
|
||||||
stdout_logfile=/dev/stdout
|
|
||||||
stdout_logfile_maxbytes=0
|
|
||||||
|
|
||||||
[program:g4f-gui]
|
|
||||||
priority=15
|
|
||||||
command=python -m g4f.cli gui
|
|
||||||
directory=/app
|
|
||||||
stopasgroup=true
|
|
||||||
autostart=true
|
|
||||||
autorestart=true
|
|
||||||
|
|
||||||
;Logs (all Hub activity redirected to stdout so it can be seen through "docker logs"
|
;Logs (all Hub activity redirected to stdout so it can be seen through "docker logs"
|
||||||
redirect_stderr=true
|
redirect_stderr=true
|
||||||
stdout_logfile=/dev/stdout
|
stdout_logfile=/dev/stdout
|
||||||
|
@ -15,7 +15,7 @@ def main():
|
|||||||
parser = argparse.ArgumentParser(description="Run gpt4free")
|
parser = argparse.ArgumentParser(description="Run gpt4free")
|
||||||
subparsers = parser.add_subparsers(dest="mode", help="Mode to run the g4f in.")
|
subparsers = parser.add_subparsers(dest="mode", help="Mode to run the g4f in.")
|
||||||
api_parser=subparsers.add_parser("api")
|
api_parser=subparsers.add_parser("api")
|
||||||
api_parser.add_argument("--bind", default="127.0.0.1:1337", help="The bind string.")
|
api_parser.add_argument("--bind", default="0.0.0.0:1337", help="The bind string.")
|
||||||
api_parser.add_argument("--debug", type=bool, default=False, help="Enable verbose logging")
|
api_parser.add_argument("--debug", type=bool, default=False, help="Enable verbose logging")
|
||||||
api_parser.add_argument("--ignored-providers", nargs="+", choices=[provider.name for provider in IgnoredProviders],
|
api_parser.add_argument("--ignored-providers", nargs="+", choices=[provider.name for provider in IgnoredProviders],
|
||||||
default=[], help="List of providers to ignore when processing request.")
|
default=[], help="List of providers to ignore when processing request.")
|
||||||
|
10
g4f/debug.py
10
g4f/debug.py
@ -1,6 +1,6 @@
|
|||||||
from os import environ
|
from os import environ
|
||||||
from requests import get
|
from requests import get
|
||||||
from importlib.metadata import version, PackageNotFoundError
|
from importlib.metadata import version as get_package_version, PackageNotFoundError
|
||||||
from subprocess import check_output, CalledProcessError, PIPE
|
from subprocess import check_output, CalledProcessError, PIPE
|
||||||
from .errors import VersionNotFoundError
|
from .errors import VersionNotFoundError
|
||||||
|
|
||||||
@ -10,7 +10,7 @@ version_check = True
|
|||||||
def get_version() -> str:
|
def get_version() -> str:
|
||||||
# Read from package manager
|
# Read from package manager
|
||||||
try:
|
try:
|
||||||
return version("g4f")
|
return get_package_version("g4f")
|
||||||
except PackageNotFoundError:
|
except PackageNotFoundError:
|
||||||
pass
|
pass
|
||||||
# Read from docker environment
|
# Read from docker environment
|
||||||
@ -33,7 +33,7 @@ def check_pypi_version() -> None:
|
|||||||
try:
|
try:
|
||||||
version = get_version()
|
version = get_version()
|
||||||
latest_version = get_lastet_version()
|
latest_version = get_lastet_version()
|
||||||
|
if version != latest_version:
|
||||||
|
print(f'New pypi version: {latest_version} (current: {version}) | pip install -U g4f')
|
||||||
except Exception as e:
|
except Exception as e:
|
||||||
print(f'Failed to check g4f pypi version: {e}')
|
print(f'Failed to check g4f pypi version: {e}')
|
||||||
if version != latest_version:
|
|
||||||
print(f'New pypi version: {latest_version} (current: {version}) | pip install -U g4f')
|
|
@ -6,7 +6,7 @@ from g4f.gui import run_gui
|
|||||||
def gui_parser():
|
def gui_parser():
|
||||||
parser = ArgumentParser(description="Run the GUI")
|
parser = ArgumentParser(description="Run the GUI")
|
||||||
parser.add_argument("-host", type=str, default="0.0.0.0", help="hostname")
|
parser.add_argument("-host", type=str, default="0.0.0.0", help="hostname")
|
||||||
parser.add_argument("-port", type=int, default=80, help="port")
|
parser.add_argument("-port", type=int, default=8080, help="port")
|
||||||
parser.add_argument("-debug", action="store_true", help="debug mode")
|
parser.add_argument("-debug", action="store_true", help="debug mode")
|
||||||
return parser
|
return parser
|
||||||
|
|
||||||
|
Loading…
Reference in New Issue
Block a user