Ubuntu 20.04 “NENHUMA senha LanMan definida para o usuário”

Ubuntu 20.04 “NENHUMA senha LanMan definida para o usuário”

Minha configuração: Servidor com Ubuntu 20.04 com compartilhamentos de samba. Impressora HP Deskjet 8620 Pro.

A impressora oferece um recurso chamado “Digitalizar para pasta de rede”. Costumava funcionar com o Ubuntu 16.04, mas não funciona desde a atualização. Pesquisando no Google, descobri que esta impressora está usando uma versão de protocolo muito antiga do smb.

eu encontreiessepostagem que sugere configuração

[global]
   ntlm auth = yes
   lanman auth = yes

em smb.conf.

Depois de adicionar essas duas linhas reiniciei o samba e alterei a senha do usuário smb correspondente:

sudo systemctl restart smbd.server nmbd.service
sudo smbpasswd hpscanner

O log de depuração do Samba ainda informa "NENHUMA senha LanMan definida para o usuário hpscanner":

[2021/06/06 19:37:36.401815,  3] ../../source3/auth/auth.c:199(auth_check_ntlm_password)
  check_ntlm_password:  Checking password for unmapped user [SERVER]\[hpscanner]@[WORKSTATION] with the new password interface
[2021/06/06 19:37:36.401828,  3] ../../source3/auth/auth.c:202(auth_check_ntlm_password)
  check_ntlm_password:  mapped user is: [SERVER]\[hpscanner]@[WORKSTATION]
[2021/06/06 19:37:36.402019,  3] ../../source3/passdb/lookup_sid.c:1684(get_primary_group_sid)
  Forcing Primary Group to 'Domain Users' for hpscanner
[2021/06/06 19:37:36.402147,  3] ../../libcli/auth/ntlm_check.c:403(ntlm_password_check)
  ntlm_password_check: NTLMv2 password check failed
[2021/06/06 19:37:36.402163,  3] ../../libcli/auth/ntlm_check.c:451(ntlm_password_check)
  ntlm_password_check: NO LanMan password set for user hpscanner (and no NT password supplied)
[2021/06/06 19:37:36.402215,  3] ../../libcli/auth/ntlm_check.c:593(ntlm_password_check)
  ntlm_password_check: LM password, NT MD4 password in LM field and LMv2 failed for user hpscanner
[2021/06/06 19:37:36.402394,  2] ../../source3/auth/auth.c:343(auth_check_ntlm_password)
  check_ntlm_password:  Authentication for user [hpscanner] -> [hpscanner] FAILED with error NT_STATUS_WRONG_PASSWORD, authoritative=1
supplied)

Então, como configuro a senha do LanMan corretamente?

Posso configurar o samba para excluir esta autenticação antiga apenas para este usuário?

Obrigado!

Editar:

Eu adicionei

server min protocol = NT1

conforme sugerido nas respostas. Isso não mudou nada.

registro:

[2021/08/05 19:51:46.005653,  3] ../../source3/auth/auth.c:199(auth_check_ntlm_password)
  check_ntlm_password:  Checking password for unmapped user [SERVER]\[hpscanner]@[WORKSTATION] with the new password interface
[2021/08/05 19:51:46.005665,  3] ../../source3/auth/auth.c:202(auth_check_ntlm_password)
  check_ntlm_password:  mapped user is: [SERVER]\[hpscanner]@[WORKSTATION]
[2021/08/05 19:51:46.005848,  3] ../../source3/passdb/lookup_sid.c:1684(get_primary_group_sid)
  Forcing Primary Group to 'Domain Users' for hpscanner
[2021/08/05 19:51:46.005967,  3] ../../libcli/auth/ntlm_check.c:403(ntlm_password_check)
  ntlm_password_check: NTLMv2 password check failed
[2021/08/05 19:51:46.005982,  3] ../../libcli/auth/ntlm_check.c:451(ntlm_password_check)
  ntlm_password_check: NO LanMan password set for user hpscanner (and no NT password supplied)
[2021/08/05 19:51:46.006036,  3] ../../libcli/auth/ntlm_check.c:593(ntlm_password_check)
  ntlm_password_check: LM password, NT MD4 password in LM field and LMv2 failed for user hpscanner
[2021/08/05 19:51:46.006198,  2] ../../source3/auth/auth.c:343(auth_check_ntlm_password)
  check_ntlm_password:  Authentication for user [hpscanner] -> [hpscanner] FAILED with error NT_STATUS_WRONG_PASSWORD, authoritative=1
[2021/08/05 19:51:46.006239,  2] ../../auth/auth_log.c:635(log_authentication_event_human_readable)
  Auth: [SMB,(null)] user [SERVER]\[hpscanner] at [Thu, 05 Aug 2021 19:51:46.006227 UTC] with [NTLMv2] status [NT_STATUS_WRONG_PASSWORD] workstation [WORKSTATION] remote host [ipv4:10.0.0.210:1024] mapped to [SERVER]\[hpscanner]. local host [ipv4:10.0.0.200:445] 
  {"timestamp": "2021-08-05T19:51:46.006293+0000", "type": "Authentication", "Authentication": {"version": {"major": 1, "minor": 2}, "eventId": 4625, "logonId": "0", "logonType": 3, "status": "NT_STATUS_WRONG_PASSWORD", "localAddress": "ipv4:10.0.0.200:445", "remoteAddress": "ipv4:10.0.0.210:1024", "serviceDescription": "SMB", "authDescription": null, "clientDomain": "SERVER", "clientAccount": "hpscanner", "workstation": "WORKSTATION", "becameAccount": null, "becameDomain": null, "becameSid": null, "mappedAccount": "hpscanner", "mappedDomain": "SERVER", "netlogonComputer": null, "netlogonTrustAccount": null, "netlogonNegotiateFlags": "0x00000000", "netlogonSecureChannelType": 0, "netlogonTrustAccountSid": null, "passwordType": "NTLMv2", "duration": 5104}}
[2021/08/05 19:51:46.006332,  3] ../../auth/gensec/spnego.c:1442(gensec_spnego_server_negTokenTarg_step)
  gensec_spnego_server_negTokenTarg_step: SPNEGO(ntlmssp) login failed: NT_STATUS_WRONG_PASSWORD
[2021/08/05 19:51:46.006368,  3] ../../source3/smbd/error.c:78(error_packet_set)
  NT error packet at ../../source3/smbd/sesssetup.c(246) cmd=115 (SMBsesssetupX) NT_STATUS_LOGON_FAILURE
[2021/08/05 19:51:46.007110,  3] ../../source3/smbd/server_exit.c:243(exit_server_common)
  Server exit (failed to receive smb request)

alguma ideia?

Responder1

Acho que você está quase lá.

Sua impressora HP está tentando se conectar ao servidor Ubuntu usando o dialeto SMB1 (o Samba o chama de NT1) do smb. No Ubuntu 16 ou 18 isso não foi um problema. No Ubuntu 20, o Samba desativou por padrão.

Você pode habilitá-lo no Ubuntu 20 editando smb.conf e na linha workgroup = WORKGROUP adicione este:

server min protocol = NT1

Você pode tentar reiniciar o smbd sudo service smbd restart, mas talvez seja necessário apenas reiniciar.

Responder2

Finalmente resolvi:

[global]
   server min protocol = NT1
   ntlm auth = yes
   lanman auth = yes

e definindo umnovosenha por

sudo smbpasswd username

resolveu como sugerido por Morbius1.

Mas eu tinha mais duas coisas a considerar:

  1. Definir a mesma senha de antes não redefinirá o hash.
  2. O comprimento máximo da senha é de 14 caracteres. Com senhas mais longas o hash não será definido.

O hash pode ser verificado com

pdbedit -L -w

XXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXX significa não definido.

informação relacionada