From fbe40001d35ea5cf74c92f35d76c642a480a5c9f Mon Sep 17 00:00:00 2001 From: Dalf Date: Sat, 29 Jun 2019 11:59:13 +0200 Subject: [PATCH 1/5] Update Docker image See #1561 , use uwsgi and Alpine Linux Volume: /var/log/uwsgi contains error log for 2 days (file uwsgi.log) /etc/searx contains the settings.yml and uwsgi.ini files. The docker image creates them if they don't exist. The two files can be modified after the first run. See below. Environement variables: MORTY_URL : external URL of Morty MORTY_KEY : base64 encoded key BASE_URL : external URL of Searx BIND_ADDRESS : internal HTTP port to listen to Labels : org.label-schema.schema.* Parameters: -h : display this help -d : will update the settings and quit immediately (settings.yml and uwsgi.ini) -f : always update the settings (previous version saved with suffix .old). without this parameter, the new settings are copied with suffix .new When the Docker image contains newer settings: - without -f parameter: the new versions are copied to /etc/searx/settings.yml.new and /etc/searx/uwsgi.ini.new. - with -f parameter: the old versions are renamed with .old suffix. The new version replaces /etc/searx/settings.yml and /etc/searx/uwsgi.ini Build using "./manage.sh docker_build", add "push" as parameter also push the Docker image. The script requires a git repository to work (it makes sure that the last git tag matches searx/version.py) "git describe" is used to create a meaningful version. Example : 0.15.0-90-49c5bcb4-dirty (dirty means that the docker image was made with uncommited changes). Use "docker inspect -f {{.Config.Labels.version}} searx" to get the version of an existing image. .dockerignore based on .gitignore .travis.yml: include docker stage --- .dockerignore | 41 ++++++++++ .gitignore | 1 + .travis.yml | 33 ++++++-- Dockerfile | 104 +++++++++++++++---------- dockerfiles/docker-entrypoint.sh | 128 +++++++++++++++++++++++++++++++ dockerfiles/uwsgi.ini | 33 ++++++++ manage.sh | 69 +++++++++++++++++ 7 files changed, 362 insertions(+), 47 deletions(-) create mode 100644 .dockerignore create mode 100755 dockerfiles/docker-entrypoint.sh create mode 100644 dockerfiles/uwsgi.ini diff --git a/.dockerignore b/.dockerignore new file mode 100644 index 000000000..f4d03376c --- /dev/null +++ b/.dockerignore @@ -0,0 +1,41 @@ +*~ +*/*~ +*/*/*~ +*/*/*/*~ +*/*/*/*/*~ + +# Git +.git +.gitignore + +# CI +.codeclimate.yml +.travis.yml +.taskcluster.yml + +# Byte-compiled / optimized / DLL files +__pycache__/ +*/__pycache__/ +*/*/__pycache__/ +*/*/*/__pycache__/ +*.py[cod] +*/*.py[cod] +*/*/*.py[cod] +*/*/*/*.py[cod] + +# to sync with .gitignore +.coverage +coverage/ +.installed.cfg +engines.cfg +env +searx-ve +robot_log.html +robot_output.xml +robot_report.html +test_basic/ +setup.cfg + +node_modules/ + +.tx/ \ No newline at end of file diff --git a/.gitignore b/.gitignore index 3da4d0386..db20da83e 100644 --- a/.gitignore +++ b/.gitignore @@ -1,3 +1,4 @@ +# to sync with .dockerignore .coverage coverage/ .installed.cfg diff --git a/.travis.yml b/.travis.yml index 08bcfaadd..04654ac23 100644 --- a/.travis.yml +++ b/.travis.yml @@ -1,16 +1,14 @@ +language: python sudo: false cache: - pip - npm - directories: - $HOME/.cache/pip + addons: firefox: "latest" -language: python -python: - - "2.7" - - "3.5" - - "3.6" + before_install: - "export DISPLAY=:99.0" - "sh -e /etc/init.d/xvfb start" @@ -27,6 +25,31 @@ script: after_success: - ./manage.sh py_test_coverage - codecov + +stages: + - test + - name: docker + if: branch = master AND type != pull_request AND env(DOCKER_USERNAME) IS present + +jobs: + include: + - python: "2.7" + - python: "3.5" + - python: "3.6" + - stage: docker + python: "3.6" + git: + depth: false + services: + - docker + addons: [] + before_install: true + install: true + script: + - echo "$DOCKER_PASSWORD" | docker login -u "$DOCKER_USERNAME" --password-stdin + - ./manage.sh docker_build push + after_success: true + notifications: irc: channels: diff --git a/Dockerfile b/Dockerfile index 95e21813f..03c4b76a1 100644 --- a/Dockerfile +++ b/Dockerfile @@ -1,57 +1,77 @@ -FROM alpine:3.8 -LABEL maintainer="searx " -LABEL description="A privacy-respecting, hackable metasearch engine." +FROM alpine:3.10 + +ARG VERSION_GITCOMMIT=unknow +ARG SEARX_GIT_VERSION=unknow + +ARG SEARX_GID=1000 +ARG SEARX_UID=1000 + +ARG TIMESTAMP_SETTINGS=0 +ARG TIMESTAMP_UWSGI=0 +ARG LABEL_VCS_REF= +ARG LABEL_VCS_URL= + +ENV BASE_URL= \ + MORTY_KEY= \ + MORTY_URL= +EXPOSE 8080 +VOLUME /etc/searx +VOLUME /var/log/uwsgi -ENV BASE_URL=False IMAGE_PROXY=False HTTP_PROXY_URL= HTTPS_PROXY_URL= -EXPOSE 8888 WORKDIR /usr/local/searx -CMD ["/sbin/tini","--","/usr/local/searx/run.sh"] -RUN adduser -D -h /usr/local/searx -s /bin/sh searx searx \ - && echo '#!/bin/sh' >> run.sh \ - && echo 'sed -i "s|base_url : False|base_url : $BASE_URL|g" searx/settings.yml' >> run.sh \ - && echo 'sed -i "s/image_proxy : False/image_proxy : $IMAGE_PROXY/g" searx/settings.yml' >> run.sh \ - && echo 'sed -i "s/ultrasecretkey/`openssl rand -hex 16`/g" searx/settings.yml' >> run.sh \ - && echo 'if [ -n "$HTTP_PROXY_URL" ] || [ -n "$HTTPS_PROXY_URL" ]; then' >> run.sh \ - && echo ' sed -i "s~^# proxies :~ proxies:\\n http: ${HTTP_PROXY_URL}\\n https: ${HTTPS_PROXY_URL}\\n~" searx/settings.yml' >> run.sh \ - && echo 'fi' >> run.sh \ - && echo 'python searx/webapp.py' >> run.sh \ - && chmod +x run.sh +RUN addgroup -g ${SEARX_GID} searx && \ + adduser -u ${SEARX_UID} -D -h /usr/local/searx -s /bin/sh -G searx searx COPY requirements.txt ./requirements.txt -RUN echo "@commuedge http://nl.alpinelinux.org/alpine/edge/community" >> /etc/apk/repositories \ - && apk -U add \ +RUN apk -U upgrade \ + && apk add -t build-dependencies \ build-base \ - python \ - python-dev \ - py-pip \ + py3-setuptools \ + python3-dev \ + libffi-dev \ + libxslt-dev \ + libxml2-dev \ + openssl-dev \ + tar \ + git \ + && apk add \ + ca-certificates \ + su-exec \ + python3 \ libxml2 \ - libxml2-dev \ libxslt \ - libxslt-dev \ - libffi-dev \ openssl \ - openssl-dev \ - ca-certificates \ - tini@commuedge \ - && pip install --upgrade pip \ - && pip install --no-cache -r requirements.txt \ - && apk del \ - build-base \ - python-dev \ - libffi-dev \ - openssl-dev \ - libxslt-dev \ - libxml2-dev \ - openssl-dev \ - ca-certificates \ + tini \ + uwsgi \ + uwsgi-python3 \ + && pip3 install --upgrade pip \ + && pip3 install --no-cache -r requirements.txt \ + && apk del build-dependencies \ && rm -f /var/cache/apk/* -COPY . . +COPY --chown=searx:searx . . -RUN chown -R searx:searx * +RUN su searx -c "/usr/bin/python3 -m compileall -q searx"; \ + touch -c --date=@${TIMESTAMP_SETTINGS} searx/settings.yml; \ + touch -c --date=@${TIMESTAMP_UWSGI} dockerfiles/uwsgi.ini; \ + if [ ! -z $VERSION_GITCOMMIT ]; then\ + echo "VERSION_STRING = VERSION_STRING + \"-$VERSION_GITCOMMIT\"" >> /usr/local/searx/searx/version.py; \ + fi -USER searx +ENTRYPOINT ["/sbin/tini","--","/usr/local/searx/dockerfiles/docker-entrypoint.sh"] -RUN sed -i "s/127.0.0.1/0.0.0.0/g" searx/settings.yml +# Keep this argument at the end since it change each time +ARG LABEL_DATE= +LABEL maintainer="searx " \ + description="A privacy-respecting, hackable metasearch engine." \ + version="${SEARX_GIT_VERSION}" \ + org.label-schema.schema-version="1.0" \ + org.label-schema.name="searx" \ + org.label-schema.schema-version="${SEARX_GIT_VERSION}" \ + org.label-schema.url="${LABEL_VCS_URL}" \ + org.label-schema.vcs-ref=${LABEL_VCS_REF} \ + org.label-schema.vcs-url=${LABEL_VCS_URL} \ + org.label-schema.build-date="${LABEL_DATE}" \ + org.label-schema.usage="https://github.com/searx/searx-docker" diff --git a/dockerfiles/docker-entrypoint.sh b/dockerfiles/docker-entrypoint.sh new file mode 100755 index 000000000..60e26fd94 --- /dev/null +++ b/dockerfiles/docker-entrypoint.sh @@ -0,0 +1,128 @@ +#!/bin/sh + +export SEARX_VERSION=$(su searx -c 'python3 -c "import six; import searx.version; six.print_(searx.version.VERSION_STRING)"') +printf 'searx version %s\n\n' "${SEARX_VERSION}" + +export UWSGI_SETTINGS_PATH=/etc/searx/uwsgi.ini +export SEARX_SETTINGS_PATH=/etc/searx/settings.yml + +if [ -z "${BIND_ADDRESS}" ]; then + export BIND_ADDRESS=":8080" +fi + +# Parse command line +FORCE_CONF_UPDATE=0 +DRY_RUN=0 +while getopts "fdh" option +do + case $option in + f) + FORCE_CONF_UPDATE=1 + ;; + d) + DRY_RUN=1 + ;; + h) + printf "Command line:\n\n" + printf " -h Display this help\n" + printf " -d Dry run to update the configuration files.\n" + printf " -f Always update on the configuration files (existing files are renamed with the .old suffix)\n" + printf " Without this option, new configuration files are copied with the .new suffix\n" + printf "\nEnvironment variables:\n\n" + printf " BASE_URL settings.yml : server.base_url\n" + printf " MORTY_URL settings.yml : result_proxy.url\n" + printf " MORTY_KEY settings.yml : result_proxy.key\n" + printf " BIND_ADDRESS where uwsgi will accept HTTP request (format : host:port)\n" + exit 0 + esac +done + +# helpers to update the configuration files +patch_uwsgi_settings() { + CONF="$1" + + # Nothing +} + +patch_searx_settings() { + CONF="$1" + + # Make sure that there is trailing slash at the end of BASE_URL + # see http://www.gnu.org/savannah-checkouts/gnu/bash/manual/bash.html#Shell-Parameter-Expansion + export BASE_URL="${BASE_URL%/}/" + + # update settings.yml + sed -i -e "s|base_url : False|base_url : ${BASE_URL}|g" \ + -e "s/ultrasecretkey/$(openssl rand -hex 32)/g" \ + "${CONF}" + + # Morty configuration + if [ ! -z "${MORTY_KEY}" -a ! -z "${MORTY_URL}" ]; then + sed -i -e "s/image_proxy : False/image_proxy : True/g" \ + "${CONF}" + cat >> "${CONF}" <<-EOF + +# Morty configuration +result_proxy: + url : ${MORTY_URL} + key : !!binary "${MORTY_KEY}" +EOF + fi +} + +update_conf() { + FORCE_CONF_UPDATE="$1" + CONF="$2" + NEW_CONF="${2}.new" + OLD_CONF="${2}.old" + REF_CONF="$3" + PATCH_REF_CONF="$4" + + if [ -f "${CONF}" ]; then + if [ "${REF_CONF}" -nt "${CONF}" ]; then + # There is a new version + if [ $FORCE_CONF_UPDATE ]; then + # Replace the current configuration + printf '⚠️ Automaticaly update %s to the new version\n' "${CONF}" + if [ ! -f "${OLD_CONF}" ]; then + printf 'The previous configuration is saved to %s\n' "${OLD_CONF}" + mv "${CONF}" "${OLD_CONF}" + fi + cp "${REF_CONF}" "${CONF}" + $PATCH_REF_CONF "${CONF}" + else + # Keep the current configuration + printf '⚠️ Check new version %s to make sure searx is working properly\n' "${NEW_CONF}" + cp "${REF_CONF}" "${NEW_CONF}" + $PATCH_REF_CONF "${NEW_CONF}" + fi + else + printf 'Use existing %s\n' "${CONF}" + fi + else + printf 'Create %s\n' "${CONF}" + cp "${REF_CONF}" "${CONF}" + $PATCH_REF_CONF "${CONF}" + fi +} + +# make sure there are uwsgi settings +update_conf "${FORCE_CONF_UPDATE}" "${UWSGI_SETTINGS_PATH}" "/usr/local/searx/dockerfiles/uwsgi.ini" "patch_uwsgi_settings" + +# make sure there are searx settings +update_conf "${FORCE_CONF_UPDATE}" "${SEARX_SETTINGS_PATH}" "/usr/local/searx/searx/settings.yml" "patch_searx_settings" + +# dry run (to update configuration files, then inspect them) +if [ $DRY_RUN -eq 1 ]; then + printf 'Dry run\n' + exit +fi + +# +touch /var/run/uwsgi-logrotate +chown -R searx:searx /var/log/uwsgi /var/run/uwsgi-logrotate +unset MORTY_KEY + +# Start uwsgi +printf 'Listen on %s\n' "${BIND_ADDRESS}" +exec su-exec searx:searx uwsgi --master --http-socket "${BIND_ADDRESS}" "${UWSGI_SETTINGS_PATH}" diff --git a/dockerfiles/uwsgi.ini b/dockerfiles/uwsgi.ini new file mode 100644 index 000000000..fa2fd6302 --- /dev/null +++ b/dockerfiles/uwsgi.ini @@ -0,0 +1,33 @@ +[uwsgi] +# Who will run the code +uid = searx +gid = searx + +# Number of workers (usually CPU count) +workers = 4 + +# The right granted on the created socket +chmod-socket = 666 + +# Plugin to use and interpretor config +single-interpreter = true +master = true +plugin = python3 +lazy-apps = true +enable-threads = true + +# Module to import +module = searx.webapp + +# Virtualenv and python path +pythonpath = /usr/local/searx/ +chdir = /usr/local/searx/searx/ + +# Disable logging for privacy +disable-logging=True + +# But keep errors for 2 days +touch-logrotate = /run/uwsgi-logrotate +unique-cron = 15 0 -1 -1 -1 { touch /run/uwsgi-logrotate } +log-backupname = /var/log/uwsgi/uwsgi.log.1 +logto = /var/log/uwsgi/uwsgi.log diff --git a/manage.sh b/manage.sh index c564827ac..7279eaf39 100755 --- a/manage.sh +++ b/manage.sh @@ -158,6 +158,74 @@ grunt_build() { grunt --gruntfile "$SEARX_DIR/static/themes/simple/gruntfile.js" } +docker_build() { + # Check if it is a git repository + if [ ! -d .git ]; then + echo "This is not Git repository" + exit 1 + fi + + if [ ! -x "$(which git)" ]; then + echo "git is not installed" + exit 1 + fi + + if [ ! git remote get-url origin 2> /dev/null ]; then + echo "there is no remote origin" + exit 1 + fi + + # This is a git repository + + # "git describe" to get the Docker version (for example : v0.15.0-89-g0585788e) + # awk to remove the "v" and the "g" + SEARX_GIT_VERSION=$(git describe --match "v[0-9]*\.[0-9]*\.[0-9]*" HEAD 2>/dev/null | awk -F'-' '{OFS="-"; $1=substr($1, 2); $3=substr($3, 2); print}') + + # add the suffix "-dirty" if the repository has uncommited change + git update-index -q --refresh + if [ ! -z "$(git diff-index --name-only HEAD --)" ]; then + SEARX_GIT_VERSION="${SEARX_GIT_VERSION}-dirty" + fi + + # Get the last git commit id, will be added to the Searx version (see Dockerfile) + VERSION_GITCOMMIT=$(echo $SEARX_GIT_VERSION | cut -d- -f2-4) + echo "Last commit : $VERSION_GITCOMMIT" + + # Check consistency between the git tag and the searx/version.py file + # /!\ HACK : parse Python file with bash /!\ + # otherwise it is not possible build the docker image without all Python dependencies ( version.py loads __init__.py ) + # SEARX_PYTHON_VERSION=$(python -c "import six; import searx.version; six.print_(searx.version.VERSION_STRING)") + SEARX_PYTHON_VERSION=$(cat searx/version.py | grep "\(VERSION_MAJOR\|VERSION_MINOR\|VERSION_BUILD\) =" | cut -d\= -f2 | sed -e 's/^[[:space:]]*//' | paste -sd "." -) + if [ $(echo "$SEARX_GIT_VERSION" | cut -d- -f1) != "$SEARX_PYTHON_VERSION" ]; then + echo "Inconsistency between the last git tag and the searx/version.py file" + echo "git tag: $SEARX_GIT_VERSION" + echo "searx/version.py: $SEARX_PYTHON_VERSION" + exit 1 + fi + + # define the docker image name + # /!\ HACK to get the user name /!\ + GITHUB_USER=$(git remote get-url origin | sed 's/.*github\.com\/\([^\/]*\).*/\1/') + SEARX_IMAGE_NAME="${GITHUB_USER:-searx}/searx" + + # build Docker image + echo "Building image ${SEARX_IMAGE_NAME}:${SEARX_GIT_VERSION}" + sudo docker build \ + --build-arg SEARX_GIT_VERSION="${SEARX_GIT_VERSION}" \ + --build-arg VERSION_GITCOMMIT="${VERSION_GITCOMMIT}" \ + --build-arg LABEL_DATE=$(date -u +"%Y-%m-%dT%H:%M:%SZ") \ + --build-arg LABEL_VCS_REF=$(git rev-parse HEAD) \ + --build-arg LABEL_VCS_URL=$(git remote get-url origin) \ + --build-arg TIMESTAMP_SETTINGS=$(git log -1 --format="%cd" --date=unix -- searx/settings.yml) \ + --build-arg TIMESTAMP_UWSGI=$(git log -1 --format="%cd" --date=unix -- dockerfiles/uwsgi.ini) \ + -t ${SEARX_IMAGE_NAME}:latest -t ${SEARX_IMAGE_NAME}:${SEARX_GIT_VERSION} . + + if [ "$1" = "push" ]; then + sudo docker push ${SEARX_IMAGE_NAME}:latest + sudo docker push ${SEARX_IMAGE_NAME}:${SEARX_GIT_VERSION} + fi +} + # # Help # @@ -182,6 +250,7 @@ Commands locales - Compile locales styles - Build less files grunt_build - Build files for themes + docker_build - Build Docker image Tests ----- From 609ac5795ab16ab8a80a89feb54a9e23d4dec725 Mon Sep 17 00:00:00 2001 From: Dalf Date: Fri, 12 Jul 2019 19:35:36 +0200 Subject: [PATCH 2/5] .travis.yml: robot tests: remove the xvfb dependency --- .travis.yml | 3 --- searx/testing.py | 2 +- 2 files changed, 1 insertion(+), 4 deletions(-) diff --git a/.travis.yml b/.travis.yml index 04654ac23..e37b65864 100644 --- a/.travis.yml +++ b/.travis.yml @@ -9,9 +9,6 @@ cache: addons: firefox: "latest" -before_install: - - "export DISPLAY=:99.0" - - "sh -e /etc/init.d/xvfb start" install: - ./manage.sh install_geckodriver ~/drivers - export PATH=~/drivers:$PATH diff --git a/searx/testing.py b/searx/testing.py index 647c236fd..08a53e3f4 100644 --- a/searx/testing.py +++ b/searx/testing.py @@ -71,7 +71,7 @@ class SearxRobotLayer(): def run_robot_tests(tests): print('Running {0} tests'.format(len(tests))) for test in tests: - with Browser() as browser: + with Browser('firefox', headless=True) as browser: test(browser) From 45702b77ca4759043f3b87f24983039f21ba2c32 Mon Sep 17 00:00:00 2001 From: Dalf Date: Sat, 13 Jul 2019 07:57:10 +0200 Subject: [PATCH 3/5] embedded iframe (youtube, dailymotion, vimeo): use https --- searx/engines/dailymotion.py | 2 +- searx/engines/vimeo.py | 2 +- searx/engines/youtube_api.py | 2 +- searx/engines/youtube_noapi.py | 2 +- 4 files changed, 4 insertions(+), 4 deletions(-) diff --git a/searx/engines/dailymotion.py b/searx/engines/dailymotion.py index 06a9c41f3..069aceaa3 100644 --- a/searx/engines/dailymotion.py +++ b/searx/engines/dailymotion.py @@ -26,7 +26,7 @@ language_support = True # see http://www.dailymotion.com/doc/api/obj-video.html search_url = 'https://api.dailymotion.com/videos?fields=created_time,title,description,duration,url,thumbnail_360_url,id&sort=relevance&limit=5&page={pageno}&{query}' # noqa embedded_url = '' + 'data-src="https://www.dailymotion.com/embed/video/{videoid}" allowfullscreen>' supported_languages_url = 'https://api.dailymotion.com/languages' diff --git a/searx/engines/vimeo.py b/searx/engines/vimeo.py index 1408be8df..a92271019 100644 --- a/searx/engines/vimeo.py +++ b/searx/engines/vimeo.py @@ -24,7 +24,7 @@ paging = True base_url = 'https://vimeo.com/' search_url = base_url + '/search/page:{pageno}?{query}' -embedded_url = '' diff --git a/searx/engines/youtube_api.py b/searx/engines/youtube_api.py index 6de18aa2c..bc4c0d58e 100644 --- a/searx/engines/youtube_api.py +++ b/searx/engines/youtube_api.py @@ -23,7 +23,7 @@ base_url = 'https://www.googleapis.com/youtube/v3/search' search_url = base_url + '?part=snippet&{query}&maxResults=20&key={api_key}' embedded_url = '' base_youtube_url = 'https://www.youtube.com/watch?v=' diff --git a/searx/engines/youtube_noapi.py b/searx/engines/youtube_noapi.py index 3bf25932b..53a10bf35 100644 --- a/searx/engines/youtube_noapi.py +++ b/searx/engines/youtube_noapi.py @@ -30,7 +30,7 @@ time_range_dict = {'day': 'Ag', 'year': 'BQ'} embedded_url = '' base_youtube_url = 'https://www.youtube.com/watch?v=' From efc2a87e77ce6b5cb4e8a4fdd9e850f7b7bb0038 Mon Sep 17 00:00:00 2001 From: Alexandre Flament Date: Sat, 13 Jul 2019 17:41:15 +0200 Subject: [PATCH 4/5] README.rst: installation: add searx/searx-docker --- README.rst | 14 ++++++++++++-- 1 file changed, 12 insertions(+), 2 deletions(-) diff --git a/README.rst b/README.rst index 35d14d1b4..ab16a8280 100644 --- a/README.rst +++ b/README.rst @@ -17,6 +17,18 @@ See the `documentation `__ and the `wiki `__ project. + +Without Docker +------ +For all the details, follow this `step by step installation `__. + +Note: the documentation needs to be updated. + +If you are in hurry +------ - clone source: ``git clone https://github.com/asciimoo/searx.git && cd searx`` - install dependencies: ``./manage.sh update_packages`` @@ -25,8 +37,6 @@ Installation (set your ``secret_key``!) - run ``python searx/webapp.py`` to start the application -For all the details, follow this `step by step -installation `__. Bugs ~~~~ From a3368c07a70fd3e444c0f19a772578f4aee2ea1c Mon Sep 17 00:00:00 2001 From: Marc Abonce Seguin Date: Mon, 15 Jul 2019 13:17:16 -0500 Subject: [PATCH 5/5] [enh] Add Interlingua locale (requires requirements update) --- requirements-dev.txt | 1 - requirements.txt | 1 + searx/settings.yml | 1 + searx/translations/ia/LC_MESSAGES/messages.mo | Bin 0 -> 12068 bytes searx/translations/ia/LC_MESSAGES/messages.po | 998 ++++++++++++++++++ 5 files changed, 1000 insertions(+), 1 deletion(-) create mode 100644 searx/translations/ia/LC_MESSAGES/messages.mo create mode 100644 searx/translations/ia/LC_MESSAGES/messages.po diff --git a/requirements-dev.txt b/requirements-dev.txt index 86b99f8b6..5e015a88a 100644 --- a/requirements-dev.txt +++ b/requirements-dev.txt @@ -1,4 +1,3 @@ -babel==2.3.4 mock==2.0.0 nose2[coverage_plugin] cov-core==1.15.0 diff --git a/requirements.txt b/requirements.txt index 94a7ccf04..6e4df37a7 100644 --- a/requirements.txt +++ b/requirements.txt @@ -1,4 +1,5 @@ certifi==2019.3.9 +babel==2.7.0 flask-babel==0.12.2 flask==1.0.2 idna==2.8 diff --git a/searx/settings.yml b/searx/settings.yml index 0be07b1e5..0b10c5369 100644 --- a/searx/settings.yml +++ b/searx/settings.yml @@ -749,6 +749,7 @@ locales: he : עברית (Hebrew) hr : Hrvatski (Croatian) hu : Magyar (Hungarian) + ia : Interlingua (Interlingua) it : Italiano (Italian) ja : 日本語 (Japanese) nl : Nederlands (Dutch) diff --git a/searx/translations/ia/LC_MESSAGES/messages.mo b/searx/translations/ia/LC_MESSAGES/messages.mo new file mode 100644 index 0000000000000000000000000000000000000000..3536ca6514f34c975cf531dff1a81359486463f6 GIT binary patch literal 12068 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 literal 0 HcmV?d00001 diff --git a/searx/translations/ia/LC_MESSAGES/messages.po b/searx/translations/ia/LC_MESSAGES/messages.po new file mode 100644 index 000000000..d2acbb626 --- /dev/null +++ b/searx/translations/ia/LC_MESSAGES/messages.po @@ -0,0 +1,998 @@ +# Translations template for PROJECT. +# Copyright (C) 2017 ORGANIZATION +# This file is distributed under the same license as the PROJECT project. +# +# Translators: +# Guimarães Mello , 2017 +msgid "" +msgstr "" +"Project-Id-Version: searx\n" +"Report-Msgid-Bugs-To: EMAIL@ADDRESS\n" +"POT-Creation-Date: 2017-10-07 19:18+0200\n" +"PO-Revision-Date: 2019-02-23 17:39+0000\n" +"Last-Translator: Guimarães Mello \n" +"Language-Team: Interlingua (http://www.transifex.com/asciimoo/searx/language/ia/)\n" +"MIME-Version: 1.0\n" +"Content-Type: text/plain; charset=UTF-8\n" +"Content-Transfer-Encoding: 8bit\n" +"Generated-By: Babel 2.3.4\n" +"Language: ia\n" +"Plural-Forms: nplurals=2; plural=(n != 1);\n" + +#: searx/search.py:137 searx/search.py:182 +msgid "timeout" +msgstr "" + +#: searx/search.py:144 +msgid "request exception" +msgstr "" + +#: searx/search.py:151 +msgid "unexpected crash" +msgstr "" + +#: searx/webapp.py:135 +msgid "files" +msgstr "files" + +#: searx/webapp.py:136 +msgid "general" +msgstr "general" + +#: searx/webapp.py:137 +msgid "music" +msgstr "musica" + +#: searx/webapp.py:138 +msgid "social media" +msgstr "medios social" + +#: searx/webapp.py:139 +msgid "images" +msgstr "imagines" + +#: searx/webapp.py:140 +msgid "videos" +msgstr "videos" + +#: searx/webapp.py:141 +msgid "it" +msgstr "software" + +#: searx/webapp.py:142 +msgid "news" +msgstr "novas" + +#: searx/webapp.py:143 +msgid "map" +msgstr "mappa" + +#: searx/webapp.py:144 +msgid "science" +msgstr "scientia" + +#: searx/webapp.py:398 searx/webapp.py:653 +msgid "Invalid settings, please edit your preferences" +msgstr "Configurationes non valide, per favor, modifica tu preferentias." + +#: searx/webapp.py:410 +msgid "Invalid settings" +msgstr "" + +#: searx/webapp.py:444 searx/webapp.py:488 +msgid "search error" +msgstr "error in recerca" + +#: searx/webapp.py:525 +msgid "{minutes} minute(s) ago" +msgstr "{minutes} minuta(s) retro" + +#: searx/webapp.py:527 +msgid "{hours} hour(s), {minutes} minute(s) ago" +msgstr "{hours} hora(s), {minutes} minuta(s) retro" + +#: searx/answerers/random/answerer.py:53 +msgid "Random value generator" +msgstr "Generator de valores aleatori" + +#: searx/answerers/random/answerer.py:54 +msgid "Generate different random values" +msgstr "Generar differente valores aleatori" + +#: searx/answerers/statistics/answerer.py:53 +msgid "Statistics functions" +msgstr "Functiones statistic" + +#: searx/answerers/statistics/answerer.py:54 +msgid "Compute {functions} of the arguments" +msgstr "Computa {functions} del argumentos" + +#: searx/engines/__init__.py:194 +msgid "Engine time (sec)" +msgstr "Tempore de motor (secundas)" + +#: searx/engines/__init__.py:198 +msgid "Page loads (sec)" +msgstr "Cargas de pagina (secundas)" + +#: searx/engines/__init__.py:202 searx/templates/oscar/results.html:95 +#: searx/templates/simple/results.html:20 +msgid "Number of results" +msgstr "Numero de resultatos" + +#: searx/engines/__init__.py:206 +msgid "Scores" +msgstr "Punctos" + +#: searx/engines/__init__.py:210 +msgid "Scores per result" +msgstr "Punctos per resultato" + +#: searx/engines/__init__.py:214 +msgid "Errors" +msgstr "Errores" + +#: searx/engines/pdbe.py:87 +msgid "{title} (OBSOLETE)" +msgstr "{title} (OBSOLETE)" + +#: searx/engines/pdbe.py:91 +msgid "This entry has been superseded by" +msgstr "Iste entrata esseva substituite per" + +#: searx/plugins/doai_rewrite.py:7 +msgid "DOAI rewrite" +msgstr "rescriber DOAI " + +#: searx/plugins/doai_rewrite.py:8 +msgid "" +"Avoid paywalls by redirecting to open-access versions of publications when " +"available" +msgstr "Evita paywalls per redirectionar a versiones de publicationes in accesso aperte, quando disponibile" + +#: searx/plugins/https_rewrite.py:32 +msgid "Rewrite HTTP links to HTTPS if possible" +msgstr "Rescriber ligamines HTTP a HTTPS si possibile" + +#: searx/plugins/infinite_scroll.py:3 +msgid "Infinite scroll" +msgstr "Rolamento infinite" + +#: searx/plugins/infinite_scroll.py:4 +msgid "Automatically load next page when scrolling to bottom of current page" +msgstr "Automaticamente cargar le proxime pagina quando arrivar al fundo del pagina actual" + +#: searx/plugins/open_results_on_new_tab.py:18 +#: searx/templates/oscar/preferences.html:114 +#: searx/templates/simple/preferences.html:149 +msgid "Open result links on new browser tabs" +msgstr "Aperir le resultatos sur nove schedas del navigator" + +#: searx/plugins/open_results_on_new_tab.py:19 +msgid "" +"Results are opened in the same window by default. This plugin overwrites the" +" default behaviour to open links on new tabs/windows. (JavaScript required)" +msgstr "Resultatos es aperite in le mesme fenestra per predefinition. Iste extension superscribe le comportamento predefinite pro aperir ligamines in nove schedas/fenestras. (JavaScript es necessari)" + +#: searx/plugins/search_on_category_select.py:18 +msgid "Search on category select" +msgstr "Recercar in le categoria selectionate" + +#: searx/plugins/search_on_category_select.py:19 +msgid "" +"Perform search immediately if a category selected. Disable to select " +"multiple categories. (JavaScript required)" +msgstr "Exequer le recerca immediatemente si un categoria es selectionate. Disactiva lo pro selectionar multiple categorias. (JavaScript es necessari)" + +#: searx/plugins/self_info.py:20 +msgid "" +"Displays your IP if the query is \"ip\" and your user agent if the query " +"contains \"user agent\"." +msgstr "Monstra tu IP si le consulta es \"ip\"; e monstra tu agente de usator si le consulta contine \"user agent\"." + +#: searx/plugins/tracker_url_remover.py:26 +msgid "Tracker URL remover" +msgstr "Remover tracker del URL" + +#: searx/plugins/tracker_url_remover.py:27 +msgid "Remove trackers arguments from the returned URL" +msgstr "Remover argumentos del tracker ab le URL retornate" + +#: searx/plugins/vim_hotkeys.py:3 +msgid "Vim-like hotkeys" +msgstr "Vias breve de claviero tal como in Vim" + +#: searx/plugins/vim_hotkeys.py:4 +msgid "" +"Navigate search results with Vim-like hotkeys (JavaScript required). Press " +"\"h\" key on main or result page to get help." +msgstr "Navigar in le resultatos de recerca per vias breve de claviero à la Vim (JavaScript es necessari). Pulsa le clave \"h\" super le pagina del resultato pro obtener adjuta." + +#: searx/templates/courgette/404.html:4 searx/templates/legacy/404.html:4 +#: searx/templates/oscar/404.html:4 searx/templates/pix-art/404.html:4 +#: searx/templates/simple/404.html:4 +msgid "Page not found" +msgstr "Pagina non trovate" + +#: searx/templates/courgette/404.html:6 searx/templates/legacy/404.html:6 +#: searx/templates/oscar/404.html:6 searx/templates/pix-art/404.html:6 +#: searx/templates/simple/404.html:6 +#, python-format +msgid "Go to %(search_page)s." +msgstr "Ir al %(search_page)s." + +#: searx/templates/courgette/404.html:6 searx/templates/legacy/404.html:6 +#: searx/templates/oscar/404.html:6 searx/templates/pix-art/404.html:6 +#: searx/templates/simple/404.html:6 +msgid "search page" +msgstr "pagina de recerca" + +#: searx/templates/courgette/index.html:9 +#: searx/templates/courgette/index.html:13 +#: searx/templates/courgette/results.html:5 +#: searx/templates/legacy/index.html:8 searx/templates/legacy/index.html:12 +#: searx/templates/oscar/navbar.html:7 +#: searx/templates/oscar/preferences.html:3 +#: searx/templates/pix-art/index.html:8 +msgid "preferences" +msgstr "preferentias" + +#: searx/templates/courgette/index.html:11 +#: searx/templates/legacy/index.html:10 searx/templates/oscar/about.html:2 +#: searx/templates/oscar/navbar.html:6 searx/templates/pix-art/index.html:7 +msgid "about" +msgstr "a proposito" + +#: searx/templates/courgette/preferences.html:5 +#: searx/templates/legacy/preferences.html:5 +#: searx/templates/oscar/preferences.html:8 +#: searx/templates/pix-art/preferences.html:5 +#: searx/templates/simple/preferences.html:26 +msgid "Preferences" +msgstr "Preferentias" + +#: searx/templates/courgette/preferences.html:9 +#: searx/templates/legacy/preferences.html:9 +#: searx/templates/oscar/preferences.html:33 +#: searx/templates/oscar/preferences.html:35 +#: searx/templates/simple/preferences.html:34 +msgid "Default categories" +msgstr "categorias predefinite" + +#: searx/templates/courgette/preferences.html:13 +#: searx/templates/legacy/preferences.html:14 +#: searx/templates/oscar/preferences.html:41 +#: searx/templates/pix-art/preferences.html:9 +#: searx/templates/simple/preferences.html:39 +#: searx/templates/simple/preferences.html:163 +msgid "Search language" +msgstr "Lingua pro le recerca" + +#: searx/templates/courgette/preferences.html:16 +#: searx/templates/legacy/preferences.html:17 +#: searx/templates/oscar/languages.html:6 +#: searx/templates/pix-art/preferences.html:12 +#: searx/templates/simple/languages.html:2 +#: searx/templates/simple/preferences.html:42 +msgid "Default language" +msgstr "Lingua predefinite" + +#: searx/templates/courgette/preferences.html:24 +#: searx/templates/legacy/preferences.html:25 +#: searx/templates/oscar/preferences.html:47 +#: searx/templates/pix-art/preferences.html:20 +#: searx/templates/simple/preferences.html:120 +msgid "Interface language" +msgstr "Lingua del interfacie" + +#: searx/templates/courgette/preferences.html:34 +#: searx/templates/legacy/preferences.html:35 +#: searx/templates/oscar/preferences.html:57 +#: searx/templates/simple/preferences.html:51 +msgid "Autocomplete" +msgstr "Autocompletar" + +#: searx/templates/courgette/preferences.html:45 +#: searx/templates/legacy/preferences.html:46 +#: searx/templates/oscar/preferences.html:68 +#: searx/templates/simple/preferences.html:166 +msgid "Image proxy" +msgstr "Proxy pro imagines" + +#: searx/templates/courgette/preferences.html:48 +#: searx/templates/legacy/preferences.html:49 +#: searx/templates/oscar/preferences.html:72 +#: searx/templates/simple/preferences.html:169 +msgid "Enabled" +msgstr "Activate" + +#: searx/templates/courgette/preferences.html:49 +#: searx/templates/legacy/preferences.html:50 +#: searx/templates/oscar/preferences.html:73 +#: searx/templates/simple/preferences.html:170 +msgid "Disabled" +msgstr "Disactivate" + +#: searx/templates/courgette/preferences.html:54 +#: searx/templates/legacy/preferences.html:55 +#: searx/templates/oscar/preferences.html:77 +#: searx/templates/pix-art/preferences.html:30 +#: searx/templates/simple/preferences.html:156 +msgid "Method" +msgstr "Methodo" + +#: searx/templates/courgette/preferences.html:63 +#: searx/templates/legacy/preferences.html:64 +#: searx/templates/oscar/preferences.html:86 +#: searx/templates/oscar/preferences.html:153 +#: searx/templates/oscar/preferences.html:161 +#: searx/templates/simple/preferences.html:63 +#: searx/templates/simple/preferences.html:90 +msgid "SafeSearch" +msgstr "Filtro de contento potentialmente offensive" + +#: searx/templates/courgette/preferences.html:66 +#: searx/templates/legacy/preferences.html:67 +#: searx/templates/oscar/preferences.html:90 +#: searx/templates/simple/preferences.html:66 +msgid "Strict" +msgstr "Rigorose" + +#: searx/templates/courgette/preferences.html:67 +#: searx/templates/legacy/preferences.html:68 +#: searx/templates/oscar/preferences.html:91 +#: searx/templates/simple/preferences.html:67 +msgid "Moderate" +msgstr "Moderate" + +#: searx/templates/courgette/preferences.html:68 +#: searx/templates/legacy/preferences.html:69 +#: searx/templates/oscar/preferences.html:92 +#: searx/templates/simple/preferences.html:68 +msgid "None" +msgstr "Nulle" + +#: searx/templates/courgette/preferences.html:73 +#: searx/templates/legacy/preferences.html:74 +#: searx/templates/oscar/preferences.html:96 +#: searx/templates/pix-art/preferences.html:39 +#: searx/templates/simple/preferences.html:131 +msgid "Themes" +msgstr "Themas" + +#: searx/templates/courgette/preferences.html:83 +msgid "Color" +msgstr "Color" + +#: searx/templates/courgette/preferences.html:86 +msgid "Blue (default)" +msgstr "Blau (standard)" + +#: searx/templates/courgette/preferences.html:87 +msgid "Violet" +msgstr "Violette" + +#: searx/templates/courgette/preferences.html:88 +msgid "Green" +msgstr "Verde" + +#: searx/templates/courgette/preferences.html:89 +msgid "Cyan" +msgstr "Cyano" + +#: searx/templates/courgette/preferences.html:90 +msgid "Orange" +msgstr "Orange" + +#: searx/templates/courgette/preferences.html:91 +msgid "Red" +msgstr "Rubie" + +#: searx/templates/courgette/preferences.html:96 +#: searx/templates/legacy/preferences.html:93 +#: searx/templates/pix-art/preferences.html:49 +#: searx/templates/simple/preferences.html:77 +msgid "Currently used search engines" +msgstr "Motores de recerca actualmente usate" + +#: searx/templates/courgette/preferences.html:100 +#: searx/templates/legacy/preferences.html:97 +#: searx/templates/oscar/preferences.html:150 +#: searx/templates/oscar/preferences.html:164 +#: searx/templates/pix-art/preferences.html:53 +#: searx/templates/simple/preferences.html:87 +msgid "Engine name" +msgstr "Nomine del motor" + +#: searx/templates/courgette/preferences.html:101 +#: searx/templates/legacy/preferences.html:98 +msgid "Category" +msgstr "Categoria" + +#: searx/templates/courgette/preferences.html:102 +#: searx/templates/courgette/preferences.html:113 +#: searx/templates/legacy/preferences.html:99 +#: searx/templates/legacy/preferences.html:110 +#: searx/templates/oscar/preferences.html:149 +#: searx/templates/oscar/preferences.html:165 +#: searx/templates/pix-art/preferences.html:54 +#: searx/templates/pix-art/preferences.html:64 +#: searx/templates/simple/preferences.html:86 +msgid "Allow" +msgstr "Permitter" + +#: searx/templates/courgette/preferences.html:102 +#: searx/templates/courgette/preferences.html:114 +#: searx/templates/legacy/preferences.html:99 +#: searx/templates/legacy/preferences.html:111 +#: searx/templates/pix-art/preferences.html:54 +#: searx/templates/pix-art/preferences.html:65 +msgid "Block" +msgstr "Blocar" + +#: searx/templates/courgette/preferences.html:122 +#: searx/templates/legacy/preferences.html:119 +#: searx/templates/oscar/preferences.html:285 +#: searx/templates/pix-art/preferences.html:73 +#: searx/templates/simple/preferences.html:180 +msgid "" +"These settings are stored in your cookies, this allows us not to store this " +"data about you." +msgstr "Iste preferentias es salvate in tu cookies, le qual permitte nos non salvar iste datos super vos." + +#: searx/templates/courgette/preferences.html:124 +#: searx/templates/legacy/preferences.html:121 +#: searx/templates/oscar/preferences.html:287 +#: searx/templates/pix-art/preferences.html:75 +#: searx/templates/simple/preferences.html:182 +msgid "" +"These cookies serve your sole convenience, we don't use these cookies to " +"track you." +msgstr "Iste cookies servi solmente a tu convenientia, nos non usa iste cookies pro traciar te." + +#: searx/templates/courgette/preferences.html:127 +#: searx/templates/legacy/preferences.html:124 +#: searx/templates/oscar/preferences.html:293 +#: searx/templates/pix-art/preferences.html:78 +#: searx/templates/simple/preferences.html:185 +msgid "save" +msgstr "salveguardar" + +#: searx/templates/courgette/preferences.html:128 +#: searx/templates/legacy/preferences.html:125 +#: searx/templates/oscar/preferences.html:295 +#: searx/templates/simple/preferences.html:186 +msgid "Reset defaults" +msgstr "Restablir configurationes" + +#: searx/templates/courgette/preferences.html:129 +#: searx/templates/legacy/preferences.html:126 +#: searx/templates/oscar/preferences.html:294 +#: searx/templates/pix-art/preferences.html:79 +#: searx/templates/simple/preferences.html:187 +msgid "back" +msgstr "retroceder" + +#: searx/templates/courgette/results.html:12 +#: searx/templates/legacy/results.html:13 +#: searx/templates/oscar/results.html:136 +#: searx/templates/simple/results.html:58 +msgid "Search URL" +msgstr "Recercar URL" + +#: searx/templates/courgette/results.html:16 +#: searx/templates/legacy/results.html:17 +#: searx/templates/oscar/results.html:141 +#: searx/templates/simple/results.html:62 +msgid "Download results" +msgstr "Discargar resultatos" + +#: searx/templates/courgette/results.html:34 +#: searx/templates/legacy/results.html:35 +#: searx/templates/simple/results.html:10 +msgid "Answers" +msgstr "Replicas" + +#: searx/templates/courgette/results.html:42 +#: searx/templates/legacy/results.html:43 +#: searx/templates/oscar/results.html:116 +#: searx/templates/simple/results.html:42 +msgid "Suggestions" +msgstr "Suggestiones" + +#: searx/templates/courgette/results.html:70 +#: searx/templates/legacy/results.html:81 +#: searx/templates/oscar/results.html:68 searx/templates/oscar/results.html:78 +#: searx/templates/simple/results.html:130 +msgid "previous page" +msgstr "pagina previe" + +#: searx/templates/courgette/results.html:81 +#: searx/templates/legacy/results.html:92 +#: searx/templates/oscar/results.html:62 searx/templates/oscar/results.html:84 +#: searx/templates/simple/results.html:145 +msgid "next page" +msgstr "pagina sequente" + +#: searx/templates/courgette/search.html:3 +#: searx/templates/legacy/search.html:3 searx/templates/oscar/search.html:6 +#: searx/templates/oscar/search_full.html:9 +#: searx/templates/pix-art/search.html:3 searx/templates/simple/search.html:4 +msgid "Search for..." +msgstr "Recercar re..." + +#: searx/templates/courgette/stats.html:4 searx/templates/legacy/stats.html:4 +#: searx/templates/oscar/stats.html:5 searx/templates/pix-art/stats.html:4 +#: searx/templates/simple/stats.html:7 +msgid "Engine stats" +msgstr "Statisticas de motores" + +#: searx/templates/courgette/result_templates/images.html:4 +#: searx/templates/legacy/result_templates/images.html:4 +#: searx/templates/pix-art/result_templates/images.html:4 +msgid "original context" +msgstr "contexto original" + +#: searx/templates/courgette/result_templates/torrent.html:7 +#: searx/templates/legacy/result_templates/torrent.html:11 +#: searx/templates/oscar/result_templates/torrent.html:6 +#: searx/templates/simple/result_templates/torrent.html:9 +msgid "Seeder" +msgstr "Seeder" + +#: searx/templates/courgette/result_templates/torrent.html:7 +#: searx/templates/legacy/result_templates/torrent.html:11 +#: searx/templates/oscar/result_templates/torrent.html:6 +#: searx/templates/simple/result_templates/torrent.html:9 +msgid "Leecher" +msgstr "Leecher" + +#: searx/templates/courgette/result_templates/torrent.html:9 +#: searx/templates/legacy/result_templates/torrent.html:9 +#: searx/templates/oscar/macros.html:23 +#: searx/templates/simple/result_templates/torrent.html:6 +msgid "magnet link" +msgstr "ligamine magnetic" + +#: searx/templates/courgette/result_templates/torrent.html:10 +#: searx/templates/legacy/result_templates/torrent.html:10 +#: searx/templates/oscar/macros.html:24 +#: searx/templates/simple/result_templates/torrent.html:7 +msgid "torrent file" +msgstr "file torrente" + +#: searx/templates/legacy/categories.html:8 +#: searx/templates/simple/categories.html:6 +msgid "Click on the magnifier to perform search" +msgstr "Clicca sur le lupa pro exequer le recerca" + +#: searx/templates/legacy/preferences.html:84 +#: searx/templates/oscar/preferences.html:113 +#: searx/templates/simple/preferences.html:142 +msgid "Results on new tabs" +msgstr "Resultatos sur nove schedas" + +#: searx/templates/legacy/preferences.html:87 +#: searx/templates/oscar/preferences.html:117 +#: searx/templates/simple/preferences.html:145 +msgid "On" +msgstr "Activate" + +#: searx/templates/legacy/preferences.html:88 +#: searx/templates/oscar/preferences.html:118 +#: searx/templates/simple/preferences.html:146 +msgid "Off" +msgstr "Disactivate" + +#: searx/templates/legacy/result_templates/code.html:3 +#: searx/templates/legacy/result_templates/default.html:3 +#: searx/templates/legacy/result_templates/map.html:9 +#: searx/templates/oscar/macros.html:34 searx/templates/oscar/macros.html:48 +#: searx/templates/simple/macros.html:43 +msgid "cached" +msgstr "in cache" + +#: searx/templates/oscar/advanced.html:4 +msgid "Advanced settings" +msgstr "Configurationes avantiate" + +#: searx/templates/oscar/base.html:62 +#: searx/templates/oscar/messages/first_time.html:4 +#: searx/templates/oscar/messages/save_settings_successfull.html:5 +#: searx/templates/oscar/messages/unknow_error.html:5 +msgid "Close" +msgstr "Clauder" + +#: searx/templates/oscar/base.html:64 +#: searx/templates/oscar/messages/no_results.html:4 +#: searx/templates/simple/messages/no_results.html:4 +#: searx/templates/simple/results.html:25 +msgid "Error!" +msgstr "Error!" + +#: searx/templates/oscar/base.html:90 searx/templates/simple/base.html:55 +msgid "Powered by" +msgstr "Actionate per" + +#: searx/templates/oscar/base.html:90 searx/templates/simple/base.html:55 +msgid "a privacy-respecting, hackable metasearch engine" +msgstr "un motor de meta-recerca, capabile de reprogrammation e respectuose al confidentialitate" + +#: searx/templates/oscar/macros.html:36 searx/templates/oscar/macros.html:50 +#: searx/templates/simple/macros.html:43 +msgid "proxied" +msgstr "per proxy" + +#: searx/templates/oscar/macros.html:92 +msgid "supported" +msgstr "" + +#: searx/templates/oscar/macros.html:96 +msgid "not supported" +msgstr "" + +#: searx/templates/oscar/preferences.html:13 +#: searx/templates/oscar/preferences.html:22 +#: searx/templates/simple/preferences.html:32 +msgid "General" +msgstr "General" + +#: searx/templates/oscar/preferences.html:14 +#: searx/templates/oscar/preferences.html:134 +#: searx/templates/simple/preferences.html:76 +msgid "Engines" +msgstr "Motores" + +#: searx/templates/oscar/preferences.html:15 +#: searx/templates/oscar/preferences.html:207 +msgid "Plugins" +msgstr "Extensiones" + +#: searx/templates/oscar/preferences.html:16 +#: searx/templates/oscar/preferences.html:233 +msgid "Answerers" +msgstr "Modulos de Responsa" + +#: searx/templates/oscar/preferences.html:17 +#: searx/templates/oscar/preferences.html:260 +msgid "Cookies" +msgstr "Cookies" + +#: searx/templates/oscar/preferences.html:42 +#: searx/templates/simple/preferences.html:48 +msgid "What language do you prefer for search?" +msgstr "Qual lingua tu prefere pro recercar? " + +#: searx/templates/oscar/preferences.html:48 +#: searx/templates/simple/preferences.html:128 +msgid "Change the language of the layout" +msgstr "Cambia le lingua del interfacie" + +#: searx/templates/oscar/preferences.html:58 +#: searx/templates/simple/preferences.html:60 +msgid "Find stuff as you type" +msgstr "Trova cosas durante que tu scribe" + +#: searx/templates/oscar/preferences.html:69 +#: searx/templates/simple/preferences.html:173 +msgid "Proxying image results through searx" +msgstr "Usar proxy pro obtener resultatos de imagines per searx" + +#: searx/templates/oscar/preferences.html:78 +msgid "" +"Change how forms are submited, learn more about request methods" +msgstr "Cambiar como le formularios es submittite. apprende plus re methodos de requesta " + +#: searx/templates/oscar/preferences.html:87 +#: searx/templates/simple/preferences.html:71 +msgid "Filter content" +msgstr "Filtrar contento" + +#: searx/templates/oscar/preferences.html:97 +#: searx/templates/simple/preferences.html:139 +msgid "Change searx layout" +msgstr "Cambiar le interfacie de searx" + +#: searx/templates/oscar/preferences.html:106 +#: searx/templates/oscar/preferences.html:111 +msgid "Choose style for this theme" +msgstr "Selectiona un stilo pro iste thema" + +#: searx/templates/oscar/preferences.html:106 +#: searx/templates/oscar/preferences.html:111 +msgid "Style" +msgstr "Stilo" + +#: searx/templates/oscar/preferences.html:151 +#: searx/templates/oscar/preferences.html:163 +#: searx/templates/simple/preferences.html:88 +msgid "Shortcut" +msgstr "Via breve" + +#: searx/templates/oscar/preferences.html:152 +#: searx/templates/oscar/preferences.html:162 +msgid "Selected language" +msgstr "" + +#: searx/templates/oscar/preferences.html:154 +#: searx/templates/oscar/preferences.html:160 +#: searx/templates/simple/preferences.html:91 +msgid "Time range" +msgstr "Intervallo de tempore" + +#: searx/templates/oscar/preferences.html:155 +#: searx/templates/oscar/preferences.html:159 +#: searx/templates/simple/preferences.html:92 +msgid "Avg. time" +msgstr "Tempore medie" + +#: searx/templates/oscar/preferences.html:156 +#: searx/templates/oscar/preferences.html:158 +#: searx/templates/simple/preferences.html:93 +msgid "Max time" +msgstr "Tempore maxime" + +#: searx/templates/oscar/preferences.html:236 +msgid "This is the list of searx's instant answering modules." +msgstr "Isto es le lista del modulos de responsa instantanee de searx." + +#: searx/templates/oscar/preferences.html:240 +msgid "Name" +msgstr "Nomine" + +#: searx/templates/oscar/preferences.html:241 +msgid "Keywords" +msgstr "Parolas clave" + +#: searx/templates/oscar/preferences.html:242 +msgid "Description" +msgstr "Description" + +#: searx/templates/oscar/preferences.html:243 +msgid "Examples" +msgstr "Exemplos" + +#: searx/templates/oscar/preferences.html:263 +msgid "" +"This is the list of cookies and their values searx is storing on your " +"computer." +msgstr "Isto es le lista de cookies e lor valores que searx salva in tu computator." + +#: searx/templates/oscar/preferences.html:264 +msgid "With that list, you can assess searx transparency." +msgstr "Per iste lista, tu pote evalutar le transparentia de searx." + +#: searx/templates/oscar/preferences.html:269 +msgid "Cookie name" +msgstr "Nomine de cookie" + +#: searx/templates/oscar/preferences.html:270 +msgid "Value" +msgstr "Valor" + +#: searx/templates/oscar/preferences.html:289 +msgid "Search URL of the currently saved preferences" +msgstr "" + +#: searx/templates/oscar/preferences.html:289 +msgid "" +"Note: specifying custom settings in the search URL can reduce privacy by " +"leaking data to the clicked result sites." +msgstr "" + +#: searx/templates/oscar/results.html:17 +msgid "Search results" +msgstr "Resultatos de recerca" + +#: searx/templates/oscar/results.html:21 +#: searx/templates/simple/results.html:84 +msgid "Try searching for:" +msgstr "" + +#: searx/templates/oscar/results.html:100 +#: searx/templates/simple/results.html:25 +msgid "Engines cannot retrieve results" +msgstr "" + +#: searx/templates/oscar/results.html:131 +msgid "Links" +msgstr "Ligamines" + +#: searx/templates/oscar/search.html:8 +#: searx/templates/oscar/search_full.html:11 +#: searx/templates/simple/search.html:5 +msgid "Start search" +msgstr "Initiar recerca" + +#: searx/templates/oscar/stats.html:2 +msgid "stats" +msgstr "statisticas" + +#: searx/templates/oscar/time-range.html:3 +#: searx/templates/simple/time-range.html:3 +msgid "Anytime" +msgstr "Aliquando" + +#: searx/templates/oscar/time-range.html:6 +#: searx/templates/simple/time-range.html:6 +msgid "Last day" +msgstr "Le die passate" + +#: searx/templates/oscar/time-range.html:9 +#: searx/templates/simple/time-range.html:9 +msgid "Last week" +msgstr "Le septimana passate" + +#: searx/templates/oscar/time-range.html:12 +#: searx/templates/simple/time-range.html:12 +msgid "Last month" +msgstr "Le mense passate" + +#: searx/templates/oscar/time-range.html:15 +#: searx/templates/simple/time-range.html:15 +msgid "Last year" +msgstr "Le anno passate" + +#: searx/templates/oscar/messages/first_time.html:6 +#: searx/templates/oscar/messages/no_data_available.html:3 +msgid "Heads up!" +msgstr "Attention!" + +#: searx/templates/oscar/messages/first_time.html:7 +msgid "It look like you are using searx first time." +msgstr "Il pare que tu usa searx pro le prime vice." + +#: searx/templates/oscar/messages/no_cookies.html:3 +msgid "Information!" +msgstr "Information!" + +#: searx/templates/oscar/messages/no_cookies.html:4 +msgid "currently, there are no cookies defined." +msgstr "actualmente, il non ha cookies definite." + +#: searx/templates/oscar/messages/no_data_available.html:4 +msgid "There is currently no data available. " +msgstr "Actualmente, il non ha datos disponibile." + +#: searx/templates/oscar/messages/no_results.html:4 +#: searx/templates/simple/messages/no_results.html:4 +msgid "Engines cannot retrieve results." +msgstr "" + +#: searx/templates/oscar/messages/no_results.html:10 +#: searx/templates/simple/messages/no_results.html:10 +msgid "Please, try again later or find another searx instance." +msgstr "" + +#: searx/templates/oscar/messages/no_results.html:14 +#: searx/templates/simple/messages/no_results.html:14 +msgid "Sorry!" +msgstr "Pardono!" + +#: searx/templates/oscar/messages/no_results.html:15 +#: searx/templates/simple/messages/no_results.html:15 +msgid "" +"we didn't find any results. Please use another query or search in more " +"categories." +msgstr "Nos trovava nulle resultatos. Per favor, usa altere consulta o recerca in plus categorias." + +#: searx/templates/oscar/messages/save_settings_successfull.html:7 +msgid "Well done!" +msgstr "Bravo!" + +#: searx/templates/oscar/messages/save_settings_successfull.html:8 +msgid "Settings saved successfully." +msgstr "Le configurationes es salvate con successo." + +#: searx/templates/oscar/messages/unknow_error.html:7 +msgid "Oh snap!" +msgstr "Oh no!" + +#: searx/templates/oscar/messages/unknow_error.html:8 +msgid "Something went wrong." +msgstr "Alco occurreva mal." + +#: searx/templates/oscar/result_templates/default.html:7 +#: searx/templates/simple/result_templates/default.html:6 +msgid "show media" +msgstr "monstrar multimedia" + +#: searx/templates/oscar/result_templates/default.html:7 +#: searx/templates/simple/result_templates/default.html:6 +msgid "hide media" +msgstr "occultar multimedia" + +#: searx/templates/oscar/result_templates/images.html:30 +msgid "Get image" +msgstr "Obtener imagine" + +#: searx/templates/oscar/result_templates/images.html:33 +msgid "View source" +msgstr "Vider fonte" + +#: searx/templates/oscar/result_templates/map.html:7 +#: searx/templates/simple/result_templates/map.html:7 +msgid "show map" +msgstr "monstrar mappa" + +#: searx/templates/oscar/result_templates/map.html:7 +#: searx/templates/simple/result_templates/map.html:7 +msgid "hide map" +msgstr "occultar mappa" + +#: searx/templates/oscar/result_templates/map.html:11 +#: searx/templates/simple/result_templates/map.html:11 +msgid "show details" +msgstr "monstrar detalios" + +#: searx/templates/oscar/result_templates/map.html:11 +#: searx/templates/simple/result_templates/map.html:11 +msgid "hide details" +msgstr "occultar detalios" + +#: searx/templates/oscar/result_templates/torrent.html:7 +#: searx/templates/simple/result_templates/torrent.html:11 +msgid "Filesize" +msgstr "Dimension del file" + +#: searx/templates/oscar/result_templates/torrent.html:9 +#: searx/templates/simple/result_templates/torrent.html:12 +msgid "Bytes" +msgstr "Bytes" + +#: searx/templates/oscar/result_templates/torrent.html:10 +#: searx/templates/simple/result_templates/torrent.html:13 +msgid "kiB" +msgstr "kiB" + +#: searx/templates/oscar/result_templates/torrent.html:11 +#: searx/templates/simple/result_templates/torrent.html:14 +msgid "MiB" +msgstr "MiB" + +#: searx/templates/oscar/result_templates/torrent.html:12 +#: searx/templates/simple/result_templates/torrent.html:15 +msgid "GiB" +msgstr "GiB" + +#: searx/templates/oscar/result_templates/torrent.html:13 +#: searx/templates/simple/result_templates/torrent.html:16 +msgid "TiB" +msgstr "TiB" + +#: searx/templates/oscar/result_templates/torrent.html:15 +#: searx/templates/simple/result_templates/torrent.html:20 +msgid "Number of Files" +msgstr "Numero de Files" + +#: searx/templates/oscar/result_templates/videos.html:7 +#: searx/templates/simple/result_templates/videos.html:6 +msgid "show video" +msgstr "monstrar video" + +#: searx/templates/oscar/result_templates/videos.html:7 +#: searx/templates/simple/result_templates/videos.html:6 +msgid "hide video" +msgstr "occultar video" + +#: searx/templates/pix-art/results.html:28 +msgid "Load more..." +msgstr "Cargar plus..." + +#: searx/templates/simple/base.html:31 +msgid "No item found" +msgstr "" + +#: searx/templates/simple/preferences.html:89 +msgid "Supports selected language" +msgstr "Supporta le lingua selectionate" + +#: searx/templates/simple/preferences.html:118 +msgid "User interface" +msgstr "" + +#: searx/templates/simple/preferences.html:154 +msgid "Privacy" +msgstr ""