varredura SANE, botões scanbd e permissões de serviço

1

Eu tenho tentado fazer isso funcionar o dia todo. Estou quase lá, mas ainda falta alguma coisa. Aqui está a história até agora:

  • Servidor inicial sem-senha Debian Jessie 8.3
  • Scanner / impressora Canon MP140 MFP totalmente suportado pela SANE, via USB
  • SANE dll.conf configurado e funcionando (tudo comentado exceto net e pixma )

scanimage -p --resolution 300 --format=tiff --mode Gray -x 210 -y 297 > test300.tiff ... digitaliza um papel A4 em escala de cinza e o salva como tiff muito bem.

sudo service scanbd status
● scanbd.service - Scanner button polling Service
   Loaded: loaded (/lib/systemd/system/scanbd.service; disabled)
   Active: active (running) since Fri 2016-02-19 19:24:03 CET; 23min ago
 Main PID: 1740 (scanbd)
   CGroup: /system.slice/scanbd.service
           └─1740 /usr/sbin/scanbd -f

Feb 19 19:24:03 server scanbd[1740]: /usr/sbin/scanbd: dbus match type='signal',interface='org.freedesktop.Hal.Manager'

Parece estar em execução, mas não reage aos botões.

Eu tentei parar o serviço e iniciar o scanbd como root - E FUNCIONA!

sudo scanbd -f
scanbd: dbus match type='signal',interface='org.freedesktop.Hal.Manager'
scanbd: trigger action for button-1 for device pixma:04A9172B_ABCDEF with script example.script

Então, eu acho que é algum tipo de problema de permissão. Eu tentei mudar /etc/scanbd.conf e substituir

user = scand  
group = scanner  

com

user = root  
group = root

mas quando eu reinicio o serviço scanbd é o que eu recebo, e os botões não funcionam novamente:

● scanbd.service - Scanner button polling Service
   Loaded: loaded (/lib/systemd/system/scanbd.service; disabled)
   Active: active (running) since Fri 2016-02-19 20:07:11 CET; 4s ago
 Main PID: 2562 (scanbd)
   CGroup: /system.slice/scanbd.service
           └─2562 /usr/sbin/scanbd -f

Feb 19 20:07:11 server scanbd[2562]: /usr/sbin/scanbd: dbus match type='signal',interface='org.freedesktop.Hal.Manager'
Feb 19 20:07:11 server scanbd[2562]: /usr/sbin/scanbd: Not Primary Owner (-1)
Feb 19 20:07:11 server scanbd[2562]: /usr/sbin/scanbd: Name Error (Connection ":1.96" is not allowed to own the service "de.kmux.scanbd.server" due to security policies in the configuration file)

Eu provavelmente estou negligenciando alguns detalhes óbvios, mas não consigo entender o que é. Qualquer ajuda seria muito apreciada.

    
por vto80 19.02.2016 / 20:22

1 resposta

2

Eu finalmente tenho tudo funcionando ...

O objetivo final para mim era fazer com que os botões digitalizados funcionassem. Até o momento eu descobri, eu tenho os botões de digitalização funcionando e digitalização em rede também.

Acontece que eu estava olhando para o lado errado, e consequentemente indo para o lado errado.
Me desculpe, eu não posso escrever a sequência exata de comandos para fazer este trabalho, já que eu fiz uma grande bagunça quando terminei. Mas espero poder pelo menos ajudar com a lógica geral disso.

Portanto, scanbd (o serviço de botão do scanner) ou saned (o serviço do servidor de rede do scanner) podem acessar o scanner, mas não os dois ao mesmo tempo. scanbd bloqueia o scanner atualizando constantemente o estado do botão e saned o bloqueia para uso como um scanner de rede.

A maneira como funciona é usando APENAS scanbd como um serviço.
scanbd então monitora o estado dos botões constantemente e aciona alguma ação se um botão for pressionado. Mas também consegue escutar na sane-port 6566 (tcp) . Se detectar tráfego, ele deixará de monitorar os botões e iniciará o saned service que assumirá o controle. Quando saned for feito como um servidor de scanner de rede, scanbd continuará a aguardar um pressionamento de botão ou mais tráfego de rede na porta sã.

Para que isso funcione, saned deve ser configurado duas vezes.
Tanto como servidor e cliente na mesma máquina. A parte do servidor é iniciada quando scanbd detecta o tráfego da rede e é descrito no parágrafo acima.

A parte do cliente é iniciada manualmente quando você inicia uma verificação via scanimage ou quando scanbd detecta um botão. O cliente saned deve ser configurado para se conectar a uma rede saned servidor (a mesma máquina, portanto, localhost, 127.0.0.1 ou nome do host, backend ' rede ') - NÃO USB - evitando assim conflita com scanbd . scanbd , em seguida, detecta algum tráfego de rede na porta 6566 e dispara saned como servidor, como se fosse realmente algum cliente de rede.

A configuração do cliente está em /etc/sane.d , enquanto a configuração do servidor está em /etc/scanbd/sane.d . A configuração do servidor deve ser copiada de /etc/sane.d (basta copiar a pasta inteira) e modificada para funcionar como um servidor e se comunicar com o scanner via USB, ou seja, qualquer back-end que o scanner realmente usar. Em /etc/scanbd/scanbd.conf , o SANE_CONFIG_DIR deve apontar para a parte do servidor saned : /etc/scanbd/sane.d

Edit: Além disso, se a máquina for firewall, abra a porta 6566 e carregue o módulo do kernel nf_conntrack_sane:

sudo ufw allow 6566/tcp

sudo modprobe nf_conntrack_sane

e, se funcionar, adicione nf_conntrack_sane a /etc/modules

    
por 24.02.2016 / 00:59