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

Make advanced type casting actually advanced #66

Open
maxstudener opened this issue Oct 8, 2014 · 2 comments
Open

Make advanced type casting actually advanced #66

maxstudener opened this issue Oct 8, 2014 · 2 comments

Comments

@maxstudener
Copy link

Right now it only support converting true/false and date and times, is there anyways you can support more type for example the standard ones in soap: http://www.pocketsoap.com/4s4c/docs/datatypes.html

    def advanced_typecasting(value)
      split = value.split
      return value if split.size > 1

      case split.first
        when "true"       then true
        when "false"      then false
        when XS_DATE_TIME then try_to_convert(value) {|x| DateTime.parse(x)}
        when XS_DATE      then try_to_convert(value) {|x| Date.parse(x)}
        when XS_TIME      then try_to_convert(value) {|x| Time.parse(x)}
        else                   value
      end
    end
@tjarratt
Copy link
Contributor

tjarratt commented Oct 8, 2014

Hey @maxstudener thanks for opening this issue. I wasn't aware that this conversion was actually happening!

It seems like we're missing signed and unsigned bytes, ints, longs, int64 in addition to floats, doubles and decimals. Arrays would also be nice to add, but starting with some of the basic types probably makes sense.

Is this something you're interested in issuing a pull request for? I don't have any WSDLs or services that have any datatypes like you've mentioned, so it would a little difficult to functionally verify this or write unit tests.

If you have any questions about how this might work, I'm more than happy to work with you and answer any questions you might about Nori, its style and existing structure.

@maxstudener
Copy link
Author

I think all that needs to be done is in @@typecasts needs to be extended to add the soap types i.e int, ,ArrayOf. I had time to dig into code and found out you are trying to convert on the type attribute on each xml node which is on standard xml soap objects except when you use a soap generator set to use=literal, in the savon gem which i linked to this ticket that isnt in the response xml but it is in the wsdl definition of each object

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

No branches or pull requests

2 participants