| 123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277 | #!/bin/shexport LANG=CBASE_DIR="$(dirname -- "`readlink -f -- "$0"`")"cd -- "$BASE_DIR"set -e# subshellPYTHONPATH="$BASE_DIR"SEARX_DIR="$BASE_DIR/searx"ACTION="$1"## Python#update_packages() {    pip install --upgrade pip    pip install --upgrade setuptools    pip install -r "$BASE_DIR/requirements.txt"}update_dev_packages() {    update_packages    pip install -r "$BASE_DIR/requirements-dev.txt"}install_geckodriver() {    echo '[!] Checking geckodriver'    # TODO : check the current geckodriver version    set -e    geckodriver -V > /dev/null 2>&1 || NOTFOUND=1    set +e    if [ -z "$NOTFOUND" ]; then        return    fi    GECKODRIVER_VERSION="v0.24.0"    PLATFORM="`python -c "import six; import platform; six.print_(platform.system().lower(), platform.architecture()[0])"`"    case "$PLATFORM" in        "linux 32bit" | "linux2 32bit") ARCH="linux32";;        "linux 64bit" | "linux2 64bit") ARCH="linux64";;        "windows 32 bit") ARCH="win32";;        "windows 64 bit") ARCH="win64";;        "mac 64bit") ARCH="macos";;    esac    GECKODRIVER_URL="https://github.com/mozilla/geckodriver/releases/download/$GECKODRIVER_VERSION/geckodriver-$GECKODRIVER_VERSION-$ARCH.tar.gz";    if [ -z "$1" ]; then        if [ -z "$VIRTUAL_ENV" ]; then            printf "geckodriver can't be installed because VIRTUAL_ENV is not set, you should download it from\n  %s" "$GECKODRIVER_URL"            exit        else            GECKODRIVER_DIR="$VIRTUAL_ENV/bin"        fi    else        GECKODRIVER_DIR="$1"        mkdir -p -- "$GECKODRIVER_DIR"    fi    printf "Installing %s/geckodriver from\n  %s" "$GECKODRIVER_DIR" "$GECKODRIVER_URL"    FILE="`mktemp`"    wget -qO "$FILE" -- "$GECKODRIVER_URL" && tar xz -C "$GECKODRIVER_DIR" -f "$FILE" geckodriver    rm -- "$FILE"    chmod 777 -- "$GECKODRIVER_DIR/geckodriver"}locales() {    pybabel compile -d "$SEARX_DIR/translations"}update_useragents() {    echo '[!] Updating user agent versions'    python utils/fetch_firefox_version.py}pep8_check() {    echo '[!] Running pep8 check'    # ignored rules:    #  E402 module level import not at top of file    #  W503 line break before binary operator    pep8 --exclude=searx/static --max-line-length=120 --ignore "E402,W503" "$SEARX_DIR" "$BASE_DIR/tests"}unit_tests() {    echo '[!] Running unit tests'    python -m nose2 -s "$BASE_DIR/tests/unit"}py_test_coverage() {    echo '[!] Running python test coverage'    PYTHONPATH="`pwd`" python -m nose2 -C --log-capture --with-coverage --coverage "$SEARX_DIR" -s "$BASE_DIR/tests/unit" \    && coverage report \    && coverage html}robot_tests() {    echo '[!] Running robot tests'    PYTHONPATH="`pwd`" python "$SEARX_DIR/testing.py" robot}tests() {    set -e    pep8_check    unit_tests    install_geckodriver    robot_tests    set +e}## Web#npm_path_setup() {    which npm || (printf 'Error: npm is not found\n'; exit 1)    export PATH="$(npm bin)":$PATH}npm_packages() {    npm_path_setup    echo '[!] install NPM packages'    cd -- "$BASE_DIR"    npm install less@2.7 less-plugin-clean-css grunt-cli    echo '[!] install NPM packages for oscar theme'    cd -- "$BASE_DIR/searx/static/themes/oscar"    npm install    echo '[!] install NPM packages for simple theme'    cd -- "$BASE_DIR/searx/static/themes/simple"    npm install}build_style() {    npm_path_setup    lessc --clean-css="--s1 --advanced --compatibility=ie9" "$BASE_DIR/searx/static/$1" "$BASE_DIR/searx/static/$2"}styles() {    npm_path_setup    echo '[!] Building legacy style'    build_style themes/legacy/less/style.less themes/legacy/css/style.css    build_style themes/legacy/less/style-rtl.less themes/legacy/css/style-rtl.css    echo '[!] Building courgette style'    build_style themes/courgette/less/style.less themes/courgette/css/style.css    build_style themes/courgette/less/style-rtl.less themes/courgette/css/style-rtl.css    echo '[!] Building pix-art style'    build_style themes/pix-art/less/style.less themes/pix-art/css/style.css    echo '[!] Building bootstrap style'    build_style less/bootstrap/bootstrap.less css/bootstrap.min.css}grunt_build() {    npm_path_setup    echo '[!] Grunt build : oscar theme'    grunt --gruntfile "$SEARX_DIR/static/themes/oscar/gruntfile.js"    echo '[!] Grunt build : simple theme'    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#help() {    [ -z "$1" ] || printf 'Error: %s\n' "$1"    echo "Searx manage.sh helpCommands========    help                 - This text    Build requirements    ------------------    update_packages      - Check & update production dependency changes    update_dev_packages  - Check & update development and production dependency changes    install_geckodriver  - Download & install geckodriver if not already installed (required for robot_tests)    npm_packages         - Download & install npm dependencies    update_useragents    - Update useragents.json with the most recent versions of Firefox    Build    -----    locales              - Compile locales    styles               - Build less files    grunt_build          - Build files for themes    docker_build         - Build Docker image    Tests    -----    unit_tests           - Run unit tests    pep8_check           - Pep8 validation    robot_tests          - Run selenium tests    tests                - Run all python tests (pep8, unit, robot_tests)    py_test_coverage     - Unit test coverage"}[ "$(command -V "$ACTION" | grep ' function$')" = "" ] \    && help "action not found" \    || "$ACTION" "$2"
 |