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

Correctly set BerIdentifiedString values to UTF-8 #212

Merged
merged 2 commits into from
Sep 18, 2015

Conversation

cmdrclueless
Copy link
Contributor

The existing code did not set the actual internal value to UTF-8 when the encoding is correct. This patch attempts to resolve that problem by passing a UTF-8 encoded string to the super class when possible.

@jch
Copy link
Member

jch commented Aug 25, 2015

The change makes sense. Could you add a test for this?

I think it might be more readable to split this into two statements. It threw me off a bit to see super begin.

encoded_args = begin
  args.respond_to?(:encode) ? args.encode('UTF-8') : args
rescue
  args
end

super(encoded_args)

Thoughts?

@cmdrclueless
Copy link
Contributor Author

@jch I would think the existing test handle the expectations on strings returned from the LDAP server. The problem is the original line

self.encode('UTF-8') if self.respond_to?(:encoding) rescue self

didn't really do anything. I think the intent of the code was to modify the string internally, so the correct call would have been self.encode!. Is there a particular test that you're looking for?

As to the the change you propose, it doesn't really matter to me. If you prefer what you've proposed I can change it. Either one is valid.

@jch
Copy link
Member

jch commented Aug 25, 2015

I'm not sure whether the intention is to modify the string in place. It's weird to me that this inherits from String rather than composing it, but looking at String::new, the doc does say it strings a new String object. I agree with you that the current code doesn't make sense though because that value isn't used or saved anywhere. Where are you running into an error with this?

@cmdrclueless
Copy link
Contributor Author

I ran into this error when dealing with Chinese names in Active Directory.

@cmdrclueless
Copy link
Contributor Author

@jch, is there something more you're looking for before you a decision is made on this request?

@jch
Copy link
Member

jch commented Sep 4, 2015

@cmdrclueless I'm sorry for the slow response. Work has been busy, and the other maintainer is out of town. I think it's a good idea, I just want to test it more thoroughly myself before merging.

@cmdrclueless
Copy link
Contributor Author

@jch, no worries. I just wanted to make sure I had not dropped the ball on my side.

@jch
Copy link
Member

jch commented Sep 18, 2015

Did an audit through the codebase and the only callsite that initializes BerIdentifiedString is

s = Net::BER::BerIdentifiedString.new(data || "")
. Seems like a reasonable fix. Thanks for the pull!

jch added a commit that referenced this pull request Sep 18, 2015
Correctly set BerIdentifiedString values to UTF-8
@jch jch merged commit 625674e into ruby-ldap:master Sep 18, 2015
jsonn pushed a commit to jsonn/pkgsrc that referenced this pull request Dec 12, 2015
=== Net::LDAP 0.12.1

* Whitespace formatting cleanup
  {#236}[ruby-ldap/ruby-net-ldap#236]
* Set operation result if LDAP server is not accessible
  {#232}[ruby-ldap/ruby-net-ldap#232]

=== Net::LDAP 0.12.0

* DRY up connection handling logic
  {#224}[ruby-ldap/ruby-net-ldap#224]
* Define auth adapters
  {#226}[ruby-ldap/ruby-net-ldap#226]
* add slash to attribute value filter
  {#225}[ruby-ldap/ruby-net-ldap#225]
* Add the ability to provide a list of hosts for a connection
  {#223}[ruby-ldap/ruby-net-ldap#223]
* Specify the port of LDAP server by giving INTEGRATION_PORT
  {#221}[ruby-ldap/ruby-net-ldap#221]
* Correctly set BerIdentifiedString values to UTF-8
  {#212}[ruby-ldap/ruby-net-ldap#212]
* Raise Net::LDAP::ConnectionRefusedError when new connection is
  refused. {#213}[ruby-ldap/ruby-net-ldap#213]
* obscure auth password upon #inspect, added test, closes #216
  {#217}[ruby-ldap/ruby-net-ldap#217]
* Fixing incorrect error class name
  {#207}[ruby-ldap/ruby-net-ldap#207]
* Travis update {#205}[ruby-ldap/ruby-net-ldap#205]
* Remove obsolete rbx-19mode from Travis
  {#204}[ruby-ldap/ruby-net-ldap#204]
* mv "sudo" from script/install-openldap to .travis.yml
  {#199}[ruby-ldap/ruby-net-ldap#199]
* Remove meaningless shebang
  {#200}[ruby-ldap/ruby-net-ldap#200]
* Fix Travis CI build
  {#202}[ruby-ldap/ruby-net-ldap#202]
* README.rdoc: fix travis link
  {#195}[ruby-ldap/ruby-net-ldap#195]
astratto pushed a commit to astratto/ruby-net-ldap that referenced this pull request Dec 18, 2015
Correctly set BerIdentifiedString values to UTF-8
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.

2 participants