Em qualquer uma das distribuições da Red Hat, como Fedora, CentOS ou RHEL, o comando mkpasswd
não inclui o mesmo conjunto de comutadores que a versão normalmente inclusa no Debian / Ubuntu.
NOTA: O comando mkpasswd
é, na verdade, parte do pacote expect
e provavelmente deve ser evitado. Você pode descobrir a qual pacote ele pertence com um desses comandos.
$ yum whatprovides "*/mkpasswd"
-or-
$ repoquery -q --file */mkpasswd
Exemplo
$ repoquery -q --file */mkpasswd
expect-0:5.43.0-8.el5.x86_64
expect-0:5.43.0-8.el5.i386
Ambos os métodos são superiores ao uso de rpm
, pois os pacotes não precisam ser instalados para localizar */mkpasswd
.
Soluções alternativas
Para contornar isso, você pode usar os seguintes liners Python ou Perl para gerar senhas SHA-512. Tome nota que estes são salgados:
Python (> = 3,3)
$ python -c 'import crypt,getpass; print(crypt.crypt(getpass.getpass(), crypt.mksalt(crypt.METHOD_SHA512)))'
ou com script -
$ python -c 'import crypt; print(crypt.crypt("somesecret", crypt.mksalt(crypt.METHOD_SHA512)))'
Python (2.x ou 3.x)
$ python -c "import crypt, getpass, pwd; \
print(crypt.crypt('password', '\\$saltsalt\$'))"
$6$saltsalt$qFmFH.bQmmtXzyBY0s9v7Oicd2z4XSIecDzlB5KiA2/jctKu9YterLp8wwnSq.qc.eoxqOmSuNp2xS0ktL3nh/
Nota: $ 6 $ designa sha512. O suporte para esse método de especificação do algoritmo depende do suporte na função de biblioteca crypt (3) do nível do sistema operacional (geralmente em libcrypt). Não é dependente da versão do python.
Perl
$ perl -e 'print crypt("password","\\$saltsalt\$") . "\n"'
$6$saltsalt$qFmFH.bQmmtXzyBY0s9v7Oicd2z4XSIecDzlB5KiA2/jctKu9YterLp8wwnSq.qc.eoxqOmSuNp2xS0ktL3nh/
Nestes exemplos, a senha é a string "senha" e o sal é "saisalt". Ambos os exemplos estão usando $ 6 $ , o que denota que você deseja que o crypt use o SHA-512.