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

Don't convert timezone naive dates to timezone aware #15

Open
timworx opened this issue Jul 14, 2017 · 3 comments
Open

Don't convert timezone naive dates to timezone aware #15

timworx opened this issue Jul 14, 2017 · 3 comments

Comments

@timworx
Copy link

timworx commented Jul 14, 2017

I noticed this behavior while dealing with an MLS that appears to be using EST for it's time.

However there is no system TimeZoneOffset and the actual dates are coming through as timezone naive ISO strings - 2017-07-14T16:47:57.210.

The rets package appears to be adding UTC timezone to the timezone naive strings. To me, this looks like an issue with their implementation, as they should really utilize TimeZoneOffset. Nonetheless, I don't see anything in the RETS docs about treating dates without timezone as UTC.

What are you thoughts on this?

@martinxsliu
Copy link
Contributor

Thanks for flagging this issue! Timezone behaviour hasn't been something I've given a lot of thought towards.

You're right that the RETS doc doesn't seem to explicitly specify what the timezone of returned dates ought to be, however it does make a mention of timezones for dates in the search query. (e.g. see https://github.com/troydavisson/PHRETS/wiki/Timezone-Handling). The part that stands out to me is (in section 7.7.2):

If the time offset is not declared in the query, the server system MUST interpret the request using the default System time zone offset. This default must match the advertised time zone offset of the SYSTEM-METADATA. If no time zone offset is advertised for the server system system, the default time zone offset MUST be UTC.

This seems to suggest that if the TimeZoneOffset is omitted, then the system timezone and returned dates is UTC. Caveat that I may be reading too much into this, and of course it is up to the MLS to adhere to this as you point out.

Separately, this brings up another issue that if the MLS does advertise aTimeZoneOffset, then the current parsing does not take this into account – it only parses the date string according to RFC3339 and nothing more. Should we add the system timezone to such parsed timestamps? And what should be behaviour be if the date string contains a different timezone offset?

@timworx
Copy link
Author

timworx commented Jul 19, 2017

That tends to be the case with timezone stuff. It's very out of sight out of mind, until it bites and you have to deal with it. :P

My general thinking with this would be:

  • If system TimeZoneOffset is set, then use that for any dates returned without a specific timezone. (This is what I interpret the RETS docs to say is proper protocol)
  • If there is no TimeZoneOffset and dates are timezone naive, then don't attach any timezone data. Leave it up the the application using the library to determine how to handle it, because there is no safe assumption.

RETS doesn't give much help here. The snippet you mention above is somewhat ambiguous:

If no time zone offset is advertised for the server system system, the default time zone offset MUST be UTC.

I'm not sure it it's just talking about queries, as it is in the sentences before it, or the data returned as well.

In the RETS implementation I'm currently working with there is not offset specified and the dates are tz naive. However, they're being serialized by the library as UTC which causes some quiet bugs.

@mlucic
Copy link

mlucic commented Nov 23, 2017

Contingent on the RETS server supporting date queries using alternate timezones (e.g. 2017-11-23T16:50:00-05:00), if you retrieve a listing by querying for it via its modification timestamp with a specific timezone, then run a second query for the same date/time but altering it by an hour and changing the timezone to compensate, you can compare a date field between the two listings to determine the timezone being used by date values returned by the server, and whether the timezone in the query affects the returned values timezone.

E.g.
First query -> (ModificationTimestamp=2017-01-01T12:00:00+04:00)
Second query -> (ModificationTimestamp=2017-01-01T13:00:00+03:00)

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

No branches or pull requests

3 participants