2021-02-09 01:24:34 +01:00
|
|
|
import argparse
|
2021-03-28 16:19:19 +02:00
|
|
|
import operator
|
2022-02-20 09:09:02 +01:00
|
|
|
import sys
|
2021-05-18 05:51:33 +02:00
|
|
|
|
2021-02-09 01:24:34 +01:00
|
|
|
from app.app import create_app
|
2021-07-12 22:43:06 +02:00
|
|
|
from app.default_values import DEFAULT_ARGUMENTS as DEFARGS
|
2021-02-09 01:24:34 +01:00
|
|
|
|
2021-05-18 05:41:02 +02:00
|
|
|
|
2022-04-02 22:26:37 +02:00
|
|
|
def get_args():
|
2021-05-18 05:41:02 +02:00
|
|
|
parser = argparse.ArgumentParser(
|
|
|
|
description="LibreTranslate - Free and Open Source Translation API"
|
|
|
|
)
|
|
|
|
parser.add_argument(
|
2021-07-12 22:43:06 +02:00
|
|
|
"--host", type=str, help="Hostname (%(default)s)", default=DEFARGS['HOST']
|
2021-05-18 05:41:02 +02:00
|
|
|
)
|
2021-07-12 22:43:06 +02:00
|
|
|
parser.add_argument("--port", type=int, help="Port (%(default)s)", default=DEFARGS['PORT'])
|
2021-05-18 05:41:02 +02:00
|
|
|
parser.add_argument(
|
|
|
|
"--char-limit",
|
2021-07-12 22:43:06 +02:00
|
|
|
default=DEFARGS['CHAR_LIMIT'],
|
2021-05-18 05:41:02 +02:00
|
|
|
type=int,
|
|
|
|
metavar="<number of characters>",
|
|
|
|
help="Set character limit (%(default)s)",
|
|
|
|
)
|
|
|
|
parser.add_argument(
|
|
|
|
"--req-limit",
|
2021-07-12 22:43:06 +02:00
|
|
|
default=DEFARGS['REQ_LIMIT'],
|
2021-05-18 05:41:02 +02:00
|
|
|
type=int,
|
|
|
|
metavar="<number>",
|
|
|
|
help="Set the default maximum number of requests per minute per client (%(default)s)",
|
|
|
|
)
|
2022-10-14 19:27:34 +02:00
|
|
|
parser.add_argument(
|
|
|
|
"--req-limit-storage",
|
|
|
|
default=DEFARGS['REQ_LIMIT_STORAGE'],
|
|
|
|
type=str,
|
|
|
|
metavar="<Storage URI>",
|
|
|
|
help="Storage URI to use for request limit data storage. See https://flask-limiter.readthedocs.io/en/stable/configuration.html. (%(default)s)",
|
|
|
|
)
|
2021-05-18 05:41:02 +02:00
|
|
|
parser.add_argument(
|
|
|
|
"--daily-req-limit",
|
2021-07-12 23:41:03 +02:00
|
|
|
default=DEFARGS['DAILY_REQ_LIMIT'],
|
2021-05-18 05:41:02 +02:00
|
|
|
type=int,
|
|
|
|
metavar="<number>",
|
|
|
|
help="Set the default maximum number of requests per day per client, in addition to req-limit. (%(default)s)",
|
|
|
|
)
|
|
|
|
parser.add_argument(
|
|
|
|
"--req-flood-threshold",
|
2021-07-12 22:43:06 +02:00
|
|
|
default=DEFARGS['REQ_FLOOD_THRESHOLD'],
|
2021-05-18 05:41:02 +02:00
|
|
|
type=int,
|
|
|
|
metavar="<number>",
|
2021-11-24 18:49:07 +01:00
|
|
|
help="Set the maximum number of request limit offences that a client can exceed before being banned. (%(default)s)",
|
2021-05-18 05:41:02 +02:00
|
|
|
)
|
|
|
|
parser.add_argument(
|
|
|
|
"--batch-limit",
|
2021-07-12 22:43:06 +02:00
|
|
|
default=DEFARGS['BATCH_LIMIT'],
|
2021-05-18 05:41:02 +02:00
|
|
|
type=int,
|
|
|
|
metavar="<number of texts>",
|
|
|
|
help="Set maximum number of texts to translate in a batch request (%(default)s)",
|
|
|
|
)
|
|
|
|
parser.add_argument(
|
|
|
|
"--ga-id",
|
|
|
|
type=str,
|
2021-07-12 22:43:06 +02:00
|
|
|
default=DEFARGS['GA_ID'],
|
2021-05-18 05:41:02 +02:00
|
|
|
metavar="<GA ID>",
|
|
|
|
help="Enable Google Analytics on the API client page by providing an ID (%(default)s)",
|
|
|
|
)
|
|
|
|
parser.add_argument(
|
2021-07-12 22:43:06 +02:00
|
|
|
"--debug", default=DEFARGS['DEBUG'], action="store_true", help="Enable debug environment"
|
2021-05-18 05:41:02 +02:00
|
|
|
)
|
|
|
|
parser.add_argument(
|
2021-07-12 22:43:06 +02:00
|
|
|
"--ssl", default=DEFARGS['SSL'], action="store_true", help="Whether to enable SSL"
|
2021-05-18 05:41:02 +02:00
|
|
|
)
|
|
|
|
parser.add_argument(
|
|
|
|
"--frontend-language-source",
|
|
|
|
type=str,
|
2021-07-12 22:43:06 +02:00
|
|
|
default=DEFARGS['FRONTEND_LANGUAGE_SOURCE'],
|
2021-05-18 05:41:02 +02:00
|
|
|
metavar="<language code>",
|
|
|
|
help="Set frontend default language - source (%(default)s)",
|
|
|
|
)
|
|
|
|
parser.add_argument(
|
|
|
|
"--frontend-language-target",
|
|
|
|
type=str,
|
2021-07-12 22:43:06 +02:00
|
|
|
default=DEFARGS['FRONTEND_LANGUAGE_TARGET'],
|
2021-05-18 05:41:02 +02:00
|
|
|
metavar="<language code>",
|
|
|
|
help="Set frontend default language - target (%(default)s)",
|
|
|
|
)
|
|
|
|
parser.add_argument(
|
|
|
|
"--frontend-timeout",
|
|
|
|
type=int,
|
2021-07-12 22:43:06 +02:00
|
|
|
default=DEFARGS['FRONTEND_TIMEOUT'],
|
2021-05-18 05:41:02 +02:00
|
|
|
metavar="<milliseconds>",
|
|
|
|
help="Set frontend translation timeout (%(default)s)",
|
|
|
|
)
|
|
|
|
parser.add_argument(
|
|
|
|
"--api-keys",
|
2021-07-12 22:43:06 +02:00
|
|
|
default=DEFARGS['API_KEYS'],
|
2021-05-18 05:41:02 +02:00
|
|
|
action="store_true",
|
|
|
|
help="Enable API keys database for per-user rate limits lookup",
|
2022-07-15 13:22:04 +02:00
|
|
|
)
|
|
|
|
parser.add_argument(
|
|
|
|
"--api-keys-db-path",
|
|
|
|
default=DEFARGS['API_KEYS_DB_PATH'],
|
|
|
|
type=str,
|
|
|
|
help="Use a specific path inside the container for the local database. Can be absolute or relative (%(default)s)",
|
2021-05-18 05:41:02 +02:00
|
|
|
)
|
2022-06-21 20:57:32 +02:00
|
|
|
parser.add_argument(
|
|
|
|
"--api-keys-remote",
|
|
|
|
default=DEFARGS['API_KEYS_REMOTE'],
|
|
|
|
type=str,
|
|
|
|
help="Use this remote endpoint to query for valid API keys instead of using the local database",
|
|
|
|
)
|
2022-06-21 21:17:42 +02:00
|
|
|
parser.add_argument(
|
|
|
|
"--get-api-key-link",
|
|
|
|
default=DEFARGS['GET_API_KEY_LINK'],
|
|
|
|
type=str,
|
|
|
|
help="Show a link in the UI where to direct users to get an API key",
|
|
|
|
)
|
2021-05-18 05:41:02 +02:00
|
|
|
parser.add_argument(
|
|
|
|
"--require-api-key-origin",
|
|
|
|
type=str,
|
2021-07-12 22:43:06 +02:00
|
|
|
default=DEFARGS['REQUIRE_API_KEY_ORIGIN'],
|
2021-05-18 05:41:02 +02:00
|
|
|
help="Require use of an API key for programmatic access to the API, unless the request origin matches this domain",
|
|
|
|
)
|
|
|
|
parser.add_argument(
|
|
|
|
"--load-only",
|
|
|
|
type=operator.methodcaller("split", ","),
|
2021-07-12 22:43:06 +02:00
|
|
|
default=DEFARGS['LOAD_ONLY'],
|
2021-05-18 05:41:02 +02:00
|
|
|
metavar="<comma-separated language codes>",
|
|
|
|
help="Set available languages (ar,de,en,es,fr,ga,hi,it,ja,ko,pt,ru,zh)",
|
|
|
|
)
|
2022-07-15 18:12:20 +02:00
|
|
|
parser.add_argument(
|
|
|
|
"--threads",
|
|
|
|
default=DEFARGS['THREADS'],
|
|
|
|
type=int,
|
|
|
|
metavar="<number of threads>",
|
|
|
|
help="Set number of threads (%(default)s)",
|
|
|
|
)
|
2021-10-09 15:45:58 +02:00
|
|
|
parser.add_argument(
|
|
|
|
"--suggestions", default=DEFARGS['SUGGESTIONS'], action="store_true", help="Allow user suggestions"
|
|
|
|
)
|
2021-10-25 17:00:44 +02:00
|
|
|
parser.add_argument(
|
2022-04-02 22:26:37 +02:00
|
|
|
"--disable-files-translation", default=DEFARGS['DISABLE_FILES_TRANSLATION'], action="store_true",
|
|
|
|
help="Disable files translation"
|
2021-10-25 17:00:44 +02:00
|
|
|
)
|
2022-02-07 11:02:32 +01:00
|
|
|
parser.add_argument(
|
|
|
|
"--disable-web-ui", default=DEFARGS['DISABLE_WEB_UI'], action="store_true", help="Disable web ui"
|
|
|
|
)
|
2021-02-09 01:24:34 +01:00
|
|
|
|
2022-04-02 22:26:37 +02:00
|
|
|
return parser.parse_args()
|
|
|
|
|
|
|
|
|
|
|
|
def main():
|
|
|
|
args = get_args()
|
2021-02-15 19:30:28 +01:00
|
|
|
app = create_app(args)
|
2021-02-09 01:24:34 +01:00
|
|
|
|
2021-07-07 02:26:06 +02:00
|
|
|
if sys.argv[0] == '--wsgi':
|
|
|
|
return app
|
2021-02-09 01:24:34 +01:00
|
|
|
else:
|
2021-07-07 02:26:06 +02:00
|
|
|
if args.debug:
|
|
|
|
app.run(host=args.host, port=args.port)
|
|
|
|
else:
|
|
|
|
from waitress import serve
|
2021-05-18 05:41:02 +02:00
|
|
|
|
2022-06-21 22:56:48 +02:00
|
|
|
url_scheme = "https" if args.ssl else "http"
|
|
|
|
print("Running on %s://%s:%s" % (url_scheme, args.host, args.port))
|
|
|
|
|
2021-07-07 02:26:06 +02:00
|
|
|
serve(
|
|
|
|
app,
|
|
|
|
host=args.host,
|
|
|
|
port=args.port,
|
2022-06-21 22:56:48 +02:00
|
|
|
url_scheme=url_scheme,
|
2022-07-15 18:12:20 +02:00
|
|
|
threads=args.threads
|
2021-07-07 02:26:06 +02:00
|
|
|
)
|
2021-05-18 05:41:02 +02:00
|
|
|
|
2021-02-09 01:24:34 +01:00
|
|
|
|
|
|
|
if __name__ == "__main__":
|
|
|
|
main()
|