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

[EmbeddedAnsible] Ensure newline for :ssh_key_data #20771

Merged

Conversation

NickLaMuro
Copy link
Member

SSH formats like OPENSSH require that a newline exist on the last line, otherwise it is considered an invalid format.

This adds a before_save callback to the model to ensure that it adds a newline to the key in case it was stripped off by the UI or via other means.

Links

Copy link
Member

@kbrock kbrock left a comment

Choose a reason for hiding this comment

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

this looks great.

@@ -54,6 +54,8 @@ class ManageIQ::Providers::EmbeddedAnsible::AutomationManager::ScmCredential < M
alias ssh_key_data auth_key
alias ssh_key_unlock auth_key_password

before_save :ensure_newline_for_ssh_key
Copy link
Member

Choose a reason for hiding this comment

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

would before_validation work as well?

feel like data manipulation should happen before validation rather than before save

Copy link
Member Author

@NickLaMuro NickLaMuro Nov 2, 2020

Choose a reason for hiding this comment

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

Seems like it still passes the tests, so either way works and I have no strong preference myself.

@Fryguy since I expect that you will give a final say anyway, do you want to weigh in on which you prefer before I end up rebasing this multiple times?

Copy link
Member

Choose a reason for hiding this comment

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

Hi @NickLaMuro, Would preserving the private key as entered be an option here? The reason I ask is that an RSA private key without the newline works fine in Ansible. The problem we encountered was specific to ssh keys generated on 5.11 (rhel 8). There wasn't a problem when we used ssh keys generated on 5.11 (rhel 8) with the -m PEM option which creates the RSA private key as opposed tp the OPENSSH private key.

Copy link
Member

Choose a reason for hiding this comment

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

I think before_validation is the better choice

Copy link
Member Author

Choose a reason for hiding this comment

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

@tinaafitz I tested both types of private keys on a generic git clone with the following done to them:

$ echo "" >> ~/.ssh/id_rsa
$ echo "" >> ~/.ssh/id_rsa
$ echo "" >> ~/.ssh/id_rsa

So any number of newlines applied was no problem. However, lack of a \n seemed to be problematic, so I am airing on the side of "add a new line if it doesn't exist" universally instead of trying to parse specific keys.

If you find a key where this is not the case, we can address, but it seems like the following line:

-----END OPENSSH PRIVATE KEY-----

And

-----END RSA PRIVATE KEY-----

Are all that need to be in place, and subsequent lines are ignored.

Copy link
Member

Choose a reason for hiding this comment

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

Thanks @NickLaMuro. I feel better about it. :-)

@NickLaMuro
Copy link
Member Author

cc @tinaafitz @djberg96

@@ -66,4 +68,8 @@ def self.params_to_attributes(params)

attrs
end

def ensure_newline_for_ssh_key
self.auth_key = "#{auth_key}\n" unless auth_key.to_s[-1] == "\n"
Copy link
Contributor

Choose a reason for hiding this comment

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

Is the auth_key encoding already guaranteed? Just want to make sure to_s[-1] doesn't break with an encoding compatibility error.

Copy link
Member

Choose a reason for hiding this comment

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

Should we only do this for when the key has the OPENSSH guard kind?

Copy link
Member

Choose a reason for hiding this comment

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

Oh I just read the gitter channel, and yeah, if you think that all keys could benefit from a trailing newline, then I'm good with this.

Copy link
Member

Choose a reason for hiding this comment

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

Also I can't tell from the diff, but please make this a private method.

Copy link
Member

@Fryguy Fryguy Nov 2, 2020

Choose a reason for hiding this comment

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

Oh I just noticed a problem here...if auth_key is nil (for a non-ssh based authentication), then will this change the nil to a blank + \n, which is probably not wanted?

Copy link
Member Author

Choose a reason for hiding this comment

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

Also I can't tell from the diff, but please make this a private method.

@Fryguy Missed this oringally, but will do.

Oh I just noticed a problem here...if auth_key is nil

@Fryguy fixed and added specs

Is the auth_key encoding already guaranteed? Just want to make sure to_s[-1] doesn't break with an encoding compatibility error.

@djberg96 this inherits from credential.rb, which inherits from app/models/authentication.rb, and that model shows this attributes are covered:

encrypt_column :auth_key
encrypt_column :auth_key_password
encrypt_column :become_password
encrypt_column :password
encrypt_column :service_account

Copy link
Member

@Fryguy Fryguy left a comment

Choose a reason for hiding this comment

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

Couple comments

@NickLaMuro NickLaMuro force-pushed the embedded_ansible_scm_cred_ensure_newline branch from 4ee4dc9 to cf52121 Compare November 2, 2020 19:34
@Fryguy Fryguy self-assigned this Nov 2, 2020
SSH formats like `OPENSSH` require that a newline exist on the last
line, otherwise it is considered an invalid format.

This adds a `before_validation` callback to the model to ensure that it
adds a newline to the key (if a key exists) in case it was stripped off
by the UI or via other means.
@NickLaMuro NickLaMuro force-pushed the embedded_ansible_scm_cred_ensure_newline branch from cf52121 to 89886e3 Compare November 2, 2020 19:41
@NickLaMuro
Copy link
Member Author

@Fryguy just pushed all of the requested fixes (after your approval). Hopefully those are good.

@miq-bot
Copy link
Member

miq-bot commented Nov 2, 2020

Checked commit NickLaMuro@89886e3 with ruby 2.6.3, rubocop 0.82.0, haml-lint 0.35.0, and yamllint
2 files checked, 0 offenses detected
Everything looks fine. 🏆

@kbrock kbrock merged commit 1895a65 into ManageIQ:master Nov 2, 2020
@kbrock
Copy link
Member

kbrock commented Nov 2, 2020

In the general case, rails trimming the last "\n" makes sense to me.
It also makes sense that we don't want that behavior.

this solution looks like a great and would be a good candidate for backporting

simaishi pushed a commit that referenced this pull request Nov 9, 2020
…nsure_newline

[EmbeddedAnsible] Ensure newline for :ssh_key_data

(cherry picked from commit 1895a65)
@simaishi
Copy link
Contributor

simaishi commented Nov 9, 2020

Kasparov backport details:

$ git log -1
commit a24481e6a1b2d444d6e0fcdf42f3b7b4d74ae599
Author: Keenan Brock <[email protected]>
Date:   Mon Nov 2 15:33:43 2020 -0500

    Merge pull request #20771 from NickLaMuro/embedded_ansible_scm_cred_ensure_newline

    [EmbeddedAnsible] Ensure newline for :ssh_key_data

    (cherry picked from commit 1895a653cbb81f0c472fd816f899dbc6f95265e5)

simaishi pushed a commit that referenced this pull request Nov 9, 2020
…nsure_newline

[EmbeddedAnsible] Ensure newline for :ssh_key_data

(cherry picked from commit 1895a65)
@simaishi
Copy link
Contributor

simaishi commented Nov 9, 2020

Jansa backport details:

$ git log -1
commit 4a50d87f7f609a7c69b8b0bd63998985df3308cc
Author: Keenan Brock <[email protected]>
Date:   Mon Nov 2 15:33:43 2020 -0500

    Merge pull request #20771 from NickLaMuro/embedded_ansible_scm_cred_ensure_newline

    [EmbeddedAnsible] Ensure newline for :ssh_key_data

    (cherry picked from commit 1895a653cbb81f0c472fd816f899dbc6f95265e5)

@simaishi
Copy link
Contributor

simaishi commented Nov 9, 2020

@NickLaMuro can this be ivanchuk/yes?

@NickLaMuro
Copy link
Member Author

@simaishi Probably should be okay to do so. Might have conflicts though.

@miq-bot add_label ivanchuk/yes

simaishi pushed a commit that referenced this pull request Nov 9, 2020
…nsure_newline

[EmbeddedAnsible] Ensure newline for :ssh_key_data

(cherry picked from commit 1895a65)

https://bugzilla.redhat.com/show_bug.cgi?id=1893014
@simaishi
Copy link
Contributor

simaishi commented Nov 9, 2020

No conflicts 😄

Ivanchuk backport details:

$ git log -1
commit 1f6a3bacf60fa9b7d756678aad3355d532305f23
Author: Keenan Brock <[email protected]>
Date:   Mon Nov 2 15:33:43 2020 -0500

    Merge pull request #20771 from NickLaMuro/embedded_ansible_scm_cred_ensure_newline

    [EmbeddedAnsible] Ensure newline for :ssh_key_data

    (cherry picked from commit 1895a653cbb81f0c472fd816f899dbc6f95265e5)

    https://bugzilla.redhat.com/show_bug.cgi?id=1893014

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

Successfully merging this pull request may close these issues.

8 participants