mirror of
https://github.com/xtekky/gpt4free.git
synced 2025-09-27 04:36:17 +08:00

- **Docs** - `docs/file.md`: update upload instructions to use inline `bucket` content parts instead of `tool_calls/bucket_tool`. - `docs/media.md`: add asynchronous audio transcription example, detailed explanation, and notes. - **New audio provider** - Add `g4f/Provider/audio/EdgeTTS.py` implementing Edge Text‑to‑Speech (`EdgeTTS`). - Create `g4f/Provider/audio/__init__.py` for provider export. - Register provider in `g4f/Provider/__init__.py`. - **Refactor image → media** - Introduce `generated_media/` directory and `get_media_dir()` helper in `g4f/image/copy_images.py`; add `ensure_media_dir()`; keep back‑compat with legacy `generated_images/`. - Replace `images_dir` references with `get_media_dir()` across: - `g4f/api/__init__.py` - `g4f/client/stubs.py` - `g4f/gui/server/api.py` - `g4f/gui/server/backend_api.py` - `g4f/image/copy_images.py` - Rename CLI/API config field/flag from `image_provider` to `media_provider` (`g4f/cli.py`, `g4f/api/__init__.py`, `g4f/client/__init__.py`). - Extend `g4f/image/__init__.py` - add `MEDIA_TYPE_MAP`, `get_extension()` - revise `is_allowed_extension()`, `to_input_audio()` to support wider media types. - **Provider adjustments** - `g4f/Provider/ARTA.py`: swap `raise_error()` parameter order. - `g4f/Provider/Cloudflare.py`: drop unused `MissingRequirementsError` import; move `get_args_from_nodriver()` inside try; handle `FileNotFoundError`. - **Core enhancements** - `g4f/providers/any_provider.py`: use `default_model` instead of literal `"default"`; broaden model/provider matching; update model list cleanup. - `g4f/models.py`: safeguard provider count logic when model name is falsy. - `g4f/providers/base_provider.py`: catch `json.JSONDecodeError` when reading auth cache, delete corrupted file. - `g4f/providers/response.py`: allow `AudioResponse` to accept extra kwargs. - **Misc** - Remove obsolete `g4f/image.py`. - `g4f/Provider/Cloudflare.py`, `g4f/client/types.py`: minor whitespace and import tidy‑ups.
84 lines
4.4 KiB
Python
84 lines
4.4 KiB
Python
from __future__ import annotations
|
|
|
|
import argparse
|
|
from argparse import ArgumentParser
|
|
|
|
from g4f import Provider
|
|
from g4f.gui.run import gui_parser, run_gui_args
|
|
import g4f.cookies
|
|
|
|
def get_api_parser():
|
|
api_parser = ArgumentParser(description="Run the API and GUI")
|
|
api_parser.add_argument("--bind", default=None, help="The bind string. (Default: 0.0.0.0:1337)")
|
|
api_parser.add_argument("--port", "-p", default=None, help="Change the port of the server.")
|
|
api_parser.add_argument("--debug", "-d", action="store_true", help="Enable verbose logging.")
|
|
api_parser.add_argument("--gui", "-g", default=None, action="store_true", help="Start also the gui.")
|
|
api_parser.add_argument("--model", default=None, help="Default model for chat completion. (incompatible with --reload and --workers)")
|
|
api_parser.add_argument("--provider", choices=[provider.__name__ for provider in Provider.__providers__ if provider.working],
|
|
default=None, help="Default provider for chat completion. (incompatible with --reload and --workers)")
|
|
api_parser.add_argument("--media-provider", choices=[provider.__name__ for provider in Provider.__providers__ if provider.working and bool(getattr(provider, "image_models", False))],
|
|
default=None, help="Default provider for image generation. (incompatible with --reload and --workers)"),
|
|
api_parser.add_argument("--proxy", default=None, help="Default used proxy. (incompatible with --reload and --workers)")
|
|
api_parser.add_argument("--workers", type=int, default=None, help="Number of workers.")
|
|
api_parser.add_argument("--disable-colors", action="store_true", help="Don't use colors.")
|
|
api_parser.add_argument("--ignore-cookie-files", action="store_true", help="Don't read .har and cookie files. (incompatible with --reload and --workers)")
|
|
api_parser.add_argument("--g4f-api-key", type=str, default=None, help="Sets an authentication key for your API. (incompatible with --reload and --workers)")
|
|
api_parser.add_argument("--ignored-providers", nargs="+", choices=[provider.__name__ for provider in Provider.__providers__ if provider.working],
|
|
default=[], help="List of providers to ignore when processing request. (incompatible with --reload and --workers)")
|
|
api_parser.add_argument("--cookie-browsers", nargs="+", choices=[browser.__name__ for browser in g4f.cookies.browsers],
|
|
default=[], help="List of browsers to access or retrieve cookies from. (incompatible with --reload and --workers)")
|
|
api_parser.add_argument("--reload", action="store_true", help="Enable reloading.")
|
|
api_parser.add_argument("--demo", action="store_true", help="Enable demo mode.")
|
|
|
|
api_parser.add_argument("--ssl-keyfile", type=str, default=None, help="Path to SSL key file for HTTPS.")
|
|
api_parser.add_argument("--ssl-certfile", type=str, default=None, help="Path to SSL certificate file for HTTPS.")
|
|
api_parser.add_argument("--log-config", type=str, default=None, help="Custom log config.")
|
|
|
|
return api_parser
|
|
|
|
def main():
|
|
parser = argparse.ArgumentParser(description="Run gpt4free")
|
|
subparsers = parser.add_subparsers(dest="mode", help="Mode to run the g4f in.")
|
|
subparsers.add_parser("api", parents=[get_api_parser()], add_help=False)
|
|
subparsers.add_parser("gui", parents=[gui_parser()], add_help=False)
|
|
|
|
args = parser.parse_args()
|
|
if args.mode == "api":
|
|
run_api_args(args)
|
|
elif args.mode == "gui":
|
|
run_gui_args(args)
|
|
else:
|
|
parser.print_help()
|
|
exit(1)
|
|
|
|
def run_api_args(args):
|
|
from g4f.api import AppConfig, run_api
|
|
|
|
AppConfig.set_config(
|
|
ignore_cookie_files=args.ignore_cookie_files,
|
|
ignored_providers=args.ignored_providers,
|
|
g4f_api_key=args.g4f_api_key,
|
|
provider=args.provider,
|
|
media_provider=args.media_provider,
|
|
proxy=args.proxy,
|
|
model=args.model,
|
|
gui=args.gui,
|
|
demo=args.demo,
|
|
)
|
|
if args.cookie_browsers:
|
|
g4f.cookies.browsers = [g4f.cookies[browser] for browser in args.cookie_browsers]
|
|
run_api(
|
|
bind=args.bind,
|
|
port=args.port,
|
|
debug=args.debug,
|
|
workers=args.workers,
|
|
use_colors=not args.disable_colors,
|
|
reload=args.reload,
|
|
ssl_keyfile=args.ssl_keyfile,
|
|
ssl_certfile=args.ssl_certfile,
|
|
log_config=args.log_config,
|
|
)
|
|
|
|
if __name__ == "__main__":
|
|
main()
|