Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

Add passphrase input to the add SSH key dialog #1157

Merged
merged 2 commits into from
Sep 16, 2024
Merged

Add passphrase input to the add SSH key dialog #1157

merged 2 commits into from
Sep 16, 2024

Conversation

vinokurig
Copy link
Contributor

@vinokurig vinokurig commented Jul 31, 2024

What does this PR do?

DO NOT MERGE

  • Add a new input for passphrase value to the add SSH key dialog:
    screenshot-eclipse-che apps rosa kd8yx-tndh6-rve jav8 p3 openshiftapps com-2024 08 01-09_52_48
  • Propagate the new passphrase value to the ssh key secret.

What issues does this PR fix or reference?

https://issues.redhat.com/browse/CRW-6614

Is it tested? How?

  1. Go to User Preferences -> Ssh Keys tab
  2. Fill the public and private key inputs, enter some value to the passphrase input.
  3. Save the key and get the git-ssh-key secret data.

See: the passphrase field is present in the data map and its value equals to the input.

Release Notes

Docs PR

@che-bot
Copy link
Contributor

che-bot commented Jul 31, 2024

Click here to review and test in web IDE: Contribute

@vinokurig vinokurig force-pushed the CRW-6614 branch 7 times, most recently from f1637af to 78c98d4 Compare July 31, 2024 12:07
@akurinnoy
Copy link
Contributor

@vinokurig can you please take a look at why the build failed?

@vinokurig vinokurig force-pushed the CRW-6614 branch 4 times, most recently from f7704fa to 74efd2c Compare August 1, 2024 06:40
Copy link

github-actions bot commented Aug 1, 2024

Docker image build succeeded: quay.io/eclipse/che-dashboard:pr-1157

kubectl patch command
kubectl patch -n eclipse-che "checluster/eclipse-che" --type=json -p="[{"op": "replace", "path": "/spec/components/dashboard/deployment", "value": {containers: [{image: "quay.io/eclipse/che-dashboard:pr-1157", name: che-dashboard}]}}]"

Copy link

codecov bot commented Aug 1, 2024

Codecov Report

Attention: Patch coverage is 94.44444% with 4 lines in your changes missing coverage. Please review.

Project coverage is 89.56%. Comparing base (b8be17e) to head (bde4177).
Report is 1 commits behind head on main.

Files Patch % Lines
...es/UserPreferences/SshKeys/AddModal/Form/index.tsx 77.77% 4 Missing ⚠️
Additional details and impacted files
@@            Coverage Diff             @@
##             main    #1157      +/-   ##
==========================================
- Coverage   89.67%   89.56%   -0.12%     
==========================================
  Files         415      416       +1     
  Lines       42461    42532      +71     
  Branches     2843     2846       +3     
==========================================
+ Hits        38077    38092      +15     
- Misses       4357     4412      +55     
- Partials       27       28       +1     

☔ View full report in Codecov by Sentry.
📢 Have feedback on the report? Share it here.

@dmytro-ndp
Copy link
Contributor

@vinokurig : could you. please, confirm, that it should be enough to install Eclipse Che Next with User Dashboard deployed from quay.io/eclipse/che-dashboard:pr-1157 to validate the PR?

Asking, because the message in PR description mentioned devfile/devworkspace-operator#1291, so I am curious if it's needed to have specific devworkspace-operator as well.

@AObuchow
Copy link

AObuchow commented Aug 1, 2024

Asking, because the message in PR description mentioned devfile/devworkspace-operator#1291, so I am curious if it's needed to have specific devworkspace-operator as well.

@dmytro-ndp For a full test flow in Che, I believe you'll need to use the DWO project clone container built from devfile/devworkspace-operator#1291

I've already built this image and pushed it here: quay.io/aobuchow/project-clone:ihor-sshkey-pr

To make DWO use it, you'll need to configure your DWOC as follows:

kind: DevWorkspaceOperatorConfig
config:
  workspace:
+    projectClone:
+      image: quay.io/aobuchow/project-clone:ihor-sshkey-pr

Then create a new workspace for it to use the newly configured project clone container.

This should work with the che-owned DWOC IIRC.

@AObuchow
Copy link

AObuchow commented Aug 1, 2024

@dmytro-ndp sorry, my above comment was wrong. What I described was testing the entire flow of the ssh passphrase feature.

Based on @vinokurig's PR description:

See: the passphrase field is present in the data map and its value equals to the input.

I believe there should be a secret created in the user's namespace regarding the ssh key, and it should contain a passphrase field in it's data. Verifying that does not require a modified version of DWO or the project clone container.

@vinokurig
Copy link
Contributor Author

@dmytro-ndp

@vinokurig : could you. please, confirm, that it should be enough to install Eclipse Che Next with User Dashboard deployed from quay.io/eclipse/che-dashboard:pr-1157 to validate the PR?

As @AObuchow mentioned in his comment above we do not need the modified DWO image here. In the scope of the pull request it would be enough to verify that the Add SSH key dialog has the Passphrase input and that the ssh-secret created after adding the SSH key has the passphrase data.

@dmytro-ndp
Copy link
Contributor

dmytro-ndp commented Aug 2, 2024

Thank you for the explanation, @AObuchow , @vinokurig !

I wanted to test whole cycle - starting from setting up git passphrase and ending by cloning the project inside the workspace editor using passphrase.

I can do it in two steps:

  1. Check adding SSH key with passphrase in User Dashboard;
  2. Check cloning project using SSH key with passphrase after Override the default ssh askpass flow on project clone step devfile/devworkspace-operator#1291 is merged

@dmytro-ndp
Copy link
Contributor

@vinokurig: I faced error Failed to add the SSH key. Unable to add SSH key "git-ssh-key": Secret in version "v1" cannot be handled as a Secret: illegal base64 data at input byte 4 when executed step "3. Save the key and get the git-ssh-key secret data." with SSH key of size 2048:
Screenshot from 2024-08-05 21-54-32
screencast-bpconcjcammlapcogcnnelfmaeghhagj-2024.08.05-21_47_01.webm

Test environment: OCP 4.16 cluster with Eclipse Che Next. using User Dashboard quay.io/eclipse/che-dashboard:pr-1157 , and DWOC quay.io/devfile/devworkspace-controller:sha-e176ec0

SSH key were created by the command: ssh-keygen -b 2048 -t rsa -N "123qwe"

It would be great if you could take a look.

@openshift-ci openshift-ci bot removed the lgtm label Aug 6, 2024
@vinokurig
Copy link
Contributor Author

@dmytro-ndp Thank you for reporting the error. I fixed the error in the latest commit. Also I changed the passphrase input type to password so the sensitive data is hidden:
screenshot-eclipse-che apps rosa gwoee-g8jth-qqt 1742 p3 openshiftapps com-2024 08 06-10_21_31

Copy link

github-actions bot commented Aug 6, 2024

Docker image build succeeded: quay.io/eclipse/che-dashboard:pr-1157

kubectl patch command
kubectl patch -n eclipse-che "checluster/eclipse-che" --type=json -p="[{"op": "replace", "path": "/spec/components/dashboard/deployment", "value": {containers: [{image: "quay.io/eclipse/che-dashboard:pr-1157", name: che-dashboard}]}}]"

Copy link

openshift-ci bot commented Aug 6, 2024

@vinokurig: The following test failed, say /retest to rerun all failed tests or /retest-required to rerun all mandatory failed tests:

Test name Commit Details Required Rerun command
ci/prow/v14-dashboard-happy-path 4420202 link true /test v14-dashboard-happy-path

Full PR test history. Your PR dashboard.

Instructions for interacting with me using PR comments are available here. If you have questions or suggestions related to my behavior, please file an issue against the kubernetes-sigs/prow repository. I understand the commands that are listed here.

@dmytro-ndp
Copy link
Contributor

dmytro-ndp commented Aug 6, 2024

@vinokurig : thanks for the improvement.

I was successfully added ssh key with passphrase to the user preferences in dashboard quay.io/eclipse/che-dashboard@sha256:ac07ba98b10ee8b40eedfa4b8aae51f084a6396a627abdad774de6004b9a89cc = latest version of quay.io/eclipse/che-dashboard:pr-1157 and then created workspace from GitHub repo using this ssh key.

Let.Dev.Spaces.keep.ssh.passphrase.for.git.webm

Well done!

At the same time, I faced an error Git: Warning: Permanently added the ECDSA host key for IP address '140.82.112.3' to the list of known hosts. when tried to push changes to the repo using Source Control view of VS Code Editor.
git-error log:

> git pull --tags origin main
Warning: Permanently added the ECDSA host key for IP address '140.82.112.3' to the list of known hosts.
[email protected]: Permission denied (publickey).
fatal: Could not read from remote repository.

Please make sure you have the correct access rights
and the repository exists.

Screenshot from 2024-08-06 14-42-49

I had been asked to enter passphrase for key '/etc/ssh/dwo_ssh_key" when tried to push changes using Terminal:
Screenshot from 2024-08-06 14-42-00

screencast-bpconcjcammlapcogcnnelfmaeghhagj-2024.08.06-14_39_32.webm

It didn't look like an expected behavior, IMHO.
(@AObuchow : cc)

@dmytro-ndp
Copy link
Contributor

@vinokurig : one more notice: Uses Dashboard failed to add SSH key with passphrase containing Cyrillic symbols: Failed to add the SSH key. Unable to add SSH key "git-ssh-key": Invalid character
Screenshot from 2024-08-06 15-14-05

SSH key were created using the command ssh-keygen -b 2048 -t rsa -N "тест".

@vinokurig
Copy link
Contributor Author

@dmytro-ndp Thank you for the deep testing and reporting the bugs. Despite that fact that the bugs are not related to the pull request, I think we should fix the bugs before merging the pull request. It is my bad that I did not try some git operations in the scope of the DWO pull request.
@dmytro-ndp Could you please create an issue for the found bugs?

@vinokurig vinokurig changed the title Add passphrase input to the add SSH key dialog [Do not merge] Add passphrase input to the add SSH key dialog Aug 6, 2024
@dmytro-ndp
Copy link
Contributor

@vinokurig , @AObuchow : here is the issue about pushing changes to the git repo: devfile/devworkspace-operator#1295

@ibuziuk
Copy link
Member

ibuziuk commented Aug 8, 2024

In this case I propose to postpone this feature and move it to 3.17 / 7.91

@vinokurig vinokurig changed the title [Do not merge] Add passphrase input to the add SSH key dialog Add passphrase input to the add SSH key dialog Sep 10, 2024
@vinokurig
Copy link
Contributor Author

@dmytro-ndp The SSH flow works for both git UI and terminal commands, could you please validate the pull request again?

Copy link
Contributor

@dmytro-ndp dmytro-ndp left a comment

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

@vinokurig : fixed version Eclipse Che Next + quay.io/eclipse/che-dashboard@sha256:ac07ba98b10ee8b40eedfa4b8aae51f084a6396a627abdad774de6004b9a89cc worked as expected with ssh key using passphrase:

  1. push changes from the terminal in workspace
  2. push changes using GitHub Pull extension

Well done!

Screencast:

screencast-bpconcjcammlapcogcnnelfmaeghhagj-2024.09.13-21_39_37.webm

Copy link
Contributor

@olexii4 olexii4 left a comment

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

LGTM

@ibuziuk ibuziuk merged commit e35bccb into main Sep 16, 2024
15 of 16 checks passed
@ibuziuk ibuziuk deleted the CRW-6614 branch September 16, 2024 13:36
@devstudio-release
Copy link

Build 3.17 :: dashboard_3.x/543: Console, Changes, Git Data

Copy link

openshift-ci bot commented Sep 16, 2024

[APPROVALNOTIFIER] This PR is NOT APPROVED

This pull-request has been approved by: akurinnoy, dmytro-ndp, ibuziuk, olexii4, vinokurig

The full list of commands accepted by this bot can be found here.

Needs approval from an approver in each of these files:

Approvers can indicate their approval by writing /approve in a comment
Approvers can cancel approval by writing /approve cancel in a comment

@devstudio-release
Copy link

@devstudio-release
Copy link

Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
Projects
None yet
Development

Successfully merging this pull request may close these issues.

8 participants