Как решить dpkg: ошибка (--configure)

Таким образом, эта ошибка возникает при установке Prey Anti-theft программного обеспечения:

Installing init scripts.
dpkg: error processing package prey (--configure):
 subprocess installed post-installation script returned error exit status 1
Errors were encountered while processing:
 prey

Вы можете использовать эту ссылку , чтобы понять сообщение об ошибке.

Таким образом, это сообщение об ошибке говорит нам, что есть ошибка со сценарием после установки ... который не очень нам помогает.

Кто-нибудь сталкивался с такой проблемой раньше и знает, как ее исправить? (Подобные вопросы были размещены на форуме по адресу https://help.preyproject.com/topics , но без каких-либо полезных ответов)

- Правка -

Это сценарий prey.postinst:

    #!/bin/bash -x
####################################################################
# Prey Debian Postinst Script
# Written by Tomás Pollak <tomas@forkhq.com> - (c) 2011 Fork Ltd.
# License: GPLv3
####################################################################

set -e

VERSION='1.3.8'
BASE_PATH="/usr/lib/prey"
INSTALL_PATH="${BASE_PATH}/versions/${VERSION}"
PREY_BIN="bin/prey"
PREY_USER="prey"
TEMP_OLD_CONFIG="/tmp/prey-config.old"

get_current_user() {
  export PS_FORMAT=user:16,command
  ps ax | grep ssh-agent | grep -v grep | cut -d' ' -f1 | head -1
}

case "$1" in
  configure)

    if [ -d /usr/share/prey ]; then
      echo "Previous installation found. Removing..."

      if [ -f /usr/share/prey/config.backup ]; then
        cp /usr/share/prey/config.backup "$TEMP_OLD_CONFIG"
      else
        cp /usr/share/prey/config "$TEMP_OLD_CONFIG" || true
      fi

      if [ -f "$TEMP_OLD_CONFIG" ]; then
        chmod 666 "$TEMP_OLD_CONFIG"
      fi

      # remove from root crontab
      (crontab -l 2> /dev/null | grep -v prey || true) | crontab -

      # remove from prey crontab, if present
      if test "$(id ${PREY_USER} 2> /dev/null)"; then
        (crontab -u $PREY_USER -l 2> /dev/null | grep -v prey || true) | crontab -u $PREY_USER -
      fi

      # wipe out old folder
      rm -Rf /usr/share/prey
    fi

    cd "$INSTALL_PATH"

    # as root, set up init script and activate current installation
    "$PREY_BIN" config hooks post_install

    # check if API_KEY env var was passed
    if [ -n "$API_KEY" ]; then 

      echo "API Key detected! Verifying..."
      "$PREY_BIN" config account authorize -a "$API_KEY"

    else # no API key, so let's show up the GUI

      # before firing gui, allow prey user to access current X screen
      if [ -n "$(which xhost)" ]; then
        CURRENT_USER=$(get_current_user)
        if [ -n "$CURRENT_USER" ]; then
          su $CURRENT_USER -c "DISPLAY=:0.0 xhost +si:localuser:${PREY_USER}" || true
        fi
      fi

      # run config gui as prey user, previously checking for old config keys
      DISPLAY=:0.0 su $PREY_USER -c "$PREY_BIN config gui --check-file $TEMP_OLD_CONFIG"

    fi

    rm -f "$TEMP_OLD_CONFIG"
  ;;

  abort-upgrade|abort-remove|abort-deconfigure)
  ;;

  *)
    echo "postinst called with unknown argument \`$1'" >&2
    exit 1
  ;;

esac

exit 0
2
задан 13 April 2017 в 15:37

1 ответ

Я изучил prey.postinst сценарий, найденный в/var/lib/dpkg/info, и использовал set -x для определения местоположения ошибки. Казалось, было что-то не так со Строкой 72:

DISPLAY=:0.0 su $PREY_USER -c "$PREY_BIN config gui --check-file $TEMP_OLD_CONFIG"

После комментария этой строки я смог закончить, установка (sudo склонный - получают установку-f).

я также удалил prey-config-XXXXXXXXXXXXXXX.log файлы, которые были расположены в моей/temp/папке (при наличии)

- РЕДАКТИРОВАНИИ -

Так со справкой the_Seppi, я изменил строку следующим образом:

env DISPLAY=:0.0 gksu $PREY_USER "$PREY_BIN config gui --check-file $TEMP_OLD_CONFIG"

установка может затем быть завершена с помощью sudo dpkg --configure -a

4
ответ дан 14 April 2017 в 01:37

Другие вопросы по тегам:

Похожие вопросы: