Convert between ISO-8601 date strings and Time.Posix


License: BSD-3-Clause

Language: Elm


Convert ISO-8601 date strings into POSIX times.

This package takes the view that it is a mistake to use ISO-8601 strings as a data transfer format. Nevertheless, third-party endpoints may use them, so even if we'd rather avoid them, sometimes they may be unavoidable.

The only design goal of this package is to "correct the mistake" by translating ISO-8601 strings to and from Time.Posix values. If it encounters a UTC offset in the string, it normalizes and discards it such that the resulting Time.Posix value is in UTC no matter what.

That's all this package does, and all it aims to do!

Why are integers better?

Integer milliseconds since the epoch is a better choice for data transfer because ISO-8601 strings can potentially include a UTC offset.

This is much worse than not having the possibility of including a UTC offset. Consider:

  • UTC offsets are not time zones. This does not and cannot tell us the time zone in which the date was recorded. So what are we supposed to do with this information?
  • Users typically want dates formatted according to their local time zone. What if the provided UTC offset is different from the current user's time zone? What are we supposed to do with it then?
  • Despite it being useless (or worse, a source of bugs), the UTC offset creates a larger payload to transfer.

Even without the UTC offset, an ISO-8601 string is still much larger to transfer than an integer. The usual argument in favor of ISO-8601 strings is that they are more human-readable than integers, but making data readable for humans is a better job for developer tools than data transfer formats between machines.

Project Statistics

Sourcerank 6
Repository Size 24.4 KB
Stars 12
Forks 9
Watchers 1
Open issues 4
Dependencies 0
Contributors 6
Tags 4
Last updated
Last pushed

Top Contributors See all

Richard Feldman Andrey Kuzmin Reiner Dolp Justin Mimbs Nick Fedor Nezhivoi

Recent Tags See all

1.1.2 September 01, 2018
1.1.1 September 01, 2018
1.1.0 August 31, 2018
1.0.0 August 20, 2018

Something wrong with this page? Make a suggestion

Last synced: 2018-11-19 22:24:54 UTC

Login to resync this repository