Как настроить Maven для подключения к CVS с использованием аутентификации с открытым ключом?

У меня есть раздел в POM, который выглядит примерно так:

<scm>
    <connection>scm:cvs:ext:myhostname:/cvsroot/repo:module_name</connection>
</scm>

Я обычно использую publickey auth для аутентификации на этом сервере cvs, хотя он также должен принять мой пароль.

Когда я пытаюсь бежать mvn scm:update, mvn release:prepareили любой другой цели Maven, которая включает в себя подключение к этой scm, я получаю следующую ошибку:

[INFO] Executing: cmd.exe /X /C "cvs -z3 -f -q update -d"
[INFO] Working directory: C:\Documents and Settings\matt\workspace\projectname
org.netbeans.lib.cvsclient.connection.AuthenticationException: Cannot authenticate. Reason: Publickey authentication failed.
    at org.apache.maven.scm.provider.cvslib.cvsjava.util.ExtConnection.open(ExtConnection.java:136)
    at org.apache.maven.scm.provider.cvslib.cvsjava.util.CvsConnection.connect(CvsConnection.java:166)
    at org.apache.maven.scm.provider.cvslib.cvsjava.util.CvsConnection.processCommand(CvsConnection.java:498)
    at org.apache.maven.scm.provider.cvslib.cvsjava.command.update.CvsJavaUpdateCommand.executeCvsCommand(CvsJavaUpdateCommand.java:53)
    at org.apache.maven.scm.provider.cvslib.command.update.AbstractCvsUpdateCommand.executeUpdateCommand(AbstractCvsUpdateCommand.java:78)
    at org.apache.maven.scm.command.update.AbstractUpdateCommand.executeCommand(AbstractUpdateCommand.java:63)
    at org.apache.maven.scm.command.AbstractCommand.execute(AbstractCommand.java:59)
    at org.apache.maven.scm.provider.cvslib.AbstractCvsScmProvider.executeCommand(AbstractCvsScmProvider.java:750)
    at org.apache.maven.scm.provider.cvslib.AbstractCvsScmProvider.update(AbstractCvsScmProvider.java:348)
    at org.apache.maven.scm.provider.AbstractScmProvider.update(AbstractScmProvider.java:821)
    at org.apache.maven.scm.provider.AbstractScmProvider.update(AbstractScmProvider.java:770)
    at org.apache.maven.scm.manager.AbstractScmManager.update(AbstractScmManager.java:526)
    at org.apache.maven.scm.plugin.UpdateMojo.execute(UpdateMojo.java:89)

(намного больше трассировки стека....)

И далее вниз по трассе стека:

Caused by: java.io.IOException: Decrypted PEM has wrong padding, did you specify the correct password?
    at ch.ethz.ssh2.crypto.PEMDecoder.removePadding(PEMDecoder.java:109)
    at ch.ethz.ssh2.crypto.PEMDecoder.decryptPEM(PEMDecoder.java:286)
    at ch.ethz.ssh2.crypto.PEMDecoder.decode(PEMDecoder.java:319)

С последующим:

[ERROR] Provider message:
[ERROR] The cvs command failed.
[ERROR] Command output:

Я запускаю это на компьютере с Windows, без CVS исполняемого файла на PATH, У меня есть открытый ключ под $HOME/.ssh, но не похоже, что cvs / maven / scm загружает его сюда - поскольку меня не спрашивают о ключевой фразе для него.

Итак, мой вопрос... есть ли что-то особенное, что мне нужно сделать с Maven или провайдером SCM/CVS, чтобы он узнал, где установлен мой открытый ключ, или как его использовать? В настоящее время кажется, что он даже не используется, так как мне не предлагается его пароль.

2 ответа

Решение

Поэтому после отладки и загрузки исходного кода для пакета maven-scm-provider-cvs я обнаружил, что библиотека CVS, используемая этим плагином, использует пустую строку ("") для значения ключевой фразы, если он находит ваш закрытый ключ. Чтобы использовать правильную фразу-пароль, библиотека ожидает, что вы зададите системное свойство с именем ключа maven.scm.cvs.java.ssh.passphrase,

Итак, если я бегу scm:status цель вот так:

mvn scm:status -Dmaven.scm.cvs.java.ssh.passphrase=<my passphrase>

Я могу подключиться к CVS.

Ну и дела - я действительно желаю, чтобы это было задокументировано!

Я решил эту проблему, выполнив команду cvs + ssh login из консоли перед использованием maven. Это добавило магические числа в $ home /.ssh для автоматического входа в систему.

Если это из-за самоподписанного сертификата, ознакомьтесь с кодом InstallCert о том, как добавить самоподписанный сертификат в клиент. Или этот пример о том, как заменить код доверия X509 по умолчанию.

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