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

[cqlsh] Add environment variable to validate server hostname #10

Open
wants to merge 1 commit into
base: master
Choose a base branch
from

Conversation

iSignal
Copy link
Contributor

@iSignal iSignal commented May 9, 2022

Summary

This change adds the ability for ycqlsh to check the server certificate to verify that it matches the connection hostname. Verification is still disabled by default but can be enabled by using the SSL_CHECK_HOSTNAME env var or an equivalent cqlsh entry.

Test Plan

Start a yugabyte cluster with client cert CN set to 127.0.0.1 and server listening on 127.0.0.1. Also forward connections from 127.0.0.2:9042 to 127.0.0.1:9042 by using an ssh tunnel. This way, connections to 127.0.0.1 should pass server cert verification but conns to 127.0.0.2 should fail.

For all cases below, set export SSL_CERTFILE=<ca.crt>

Test cases

  1. /usr/bin/python3 ~/code/cqlsh/bin/ycqlsh.py --ssl 127.0.0.2 9042 succeeds with no env vars as before.
  2. SSL_CHECK_HOSTNAME=true /usr/bin/python3 ~/code/cqlsh/bin/ycqlsh.py --ssl 127.0.0.2 9042 fails with
    /home/sanketh/code/cqlsh/bin/ycqlsh.py:464: DeprecationWarning: Legacy execution parameters will be removed in 4.0. 
    Consider using execution profiles.
    /home/sanketh/code/cqlsh/bin/ycqlsh.py:464: DeprecationWarning: Using ssl_options without ssl_context is deprecated and 
    will result in an error in the next major release. Please use ssl_context to prepare for that release.
    Connection error: ('Unable to connect to any servers', {'127.0.0.2:9042': OSError(None, 'Tried connecting to [(\'127.0.0.2\', 9042)]. Last error: ("hostname \'127.0.0.2\' doesn\'t match \'127.0.0.1\'",)')})
    
  3. SSL_CHECK_HOSTNAME=false/usr/bin/python3 ~/code/cqlsh/bin/ycqlsh.py --ssl 127.0.0.2 9042 succeeds
  4. SSL_VALIDATE=false SSL_CHECK_HOSTNAME=true /usr/bin/python3 ~/code/cqlsh/bin/ycqlsh.py --ssl 127.0.0.2 9042 succeeds

@iSignal iSignal requested review from m-iancu and OlegLoginov May 9, 2022 01:15
@iSignal iSignal force-pushed the check_hostname branch 2 times, most recently from 39ca999 to dbc879e Compare May 9, 2022 01:17
@iSignal iSignal changed the title Add environment variable to validate server hostname [cqlsh] Add environment variable to validate server hostname May 9, 2022
Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
None yet
Projects
None yet
Development

Successfully merging this pull request may close these issues.

1 participant