A significant amount of internal cleanup, resulting in more consistent code and API. There are some minor breaking changes, but they're small enough that migrating to 5.0 shouldn't be much effort. The Example Usage has been updated to show 5.x patterns.
- object stream queries now have events with a
type
field to make discrimination easier, with the following possibilities:dataStream
, for a stream containing an object's raw datalocation
, when no stream is available but a URL is available in theheaderInfo
(as per theLocation: 1
option)headerInfo
, with the headers for the outer multipart responseerror
, for an error corresponding to a single object rather than the stream as a whole
- search stream queries now return an object with a
retsStream
field rather than the bare stream - the
searchRets
method now returns an object with arawStream
field rather than the bare stream - headerInfo is now available on every query made
- login and logout set
client.loginHeaderInfo
andclient.logoutHeaderInfo
- every streaming query will include an event with
type: 'headerInfo'
- every buffered query (and most streaming queries) will return an object including a
headerInfo
field
- login and logout set
- errors now consistently include response headers as well as the request options
- all calls made to the RETS server now obey
settings.method
for POST vs GET
Added support for Location: 1
option on getObject
calls.
Added a new error class for RETS permissions problems on login.
Added a new parserEncoding
param for client.search.query()
and client.search.stream.query()
calls. UTF-8 is the
default value, so this is to support RETS servers using ISO-8859-1 or some other encoding.
Added support for TimeZoneOffset and Comments in the metadata.getSystem()
call response.
Improved error handling and error classes. See the error documentation.
Added client configuration option to use POST instead of GET for all requests, as this seems to work better for some RETS servers. See the Example Usage.
Version 4.0! This represents a substantial rewrite of the object-retrieval code, making it more robust and flexible,
adding support for streaming object results, and allowing for additional query options (like Location
and
ObjectData
). See the simple photo query example at the end of the Example RETS Session, and
the photo streaming example.
Also new in version 4.0, just about every API call now gives access to header info from the RETS response. For some
queries, in particular object queries, headers are often used as a vehicle for important metadata about the response,
so this is an important feature. The exact mechanism varies depending on whether it a call that resolves to a stream
(which now emits a headerInfo
event) or a call that resolves to an object (which now has a headerInfo
field). Also,
the RetsServerError and RetsReplyError objects now both contain a headerInfo
field.
Version 3.3 adds support for debugging via the debug and request-debug modules. See the debugging section.
Version 3.2.2 adds support for per-object errors when calling client.objects.getPhotos()
. The
Example RETS Session illustrates proper error checking.
Version 3.2 passes through any multipart headers (except for content-disposition, which gets split up first;
content-type which is renamed to mime
; and content-transfer-encoding which is used internally and not passed) onto
the objects resolved from client.objects.getPhotos()
. It also fixes a race condition in client.objects.getPhotos()
.
Version 3.1 adds a response
field to the object resolved from client.objects.getObject()
, containing the full HTTP
response object. It also fixes a major bug interfering with client.objects.getPhotos()
and
client.objects.getObject()
calls.
Version 3.x is out! This represents a substantial rewrite of the underlying code, which should improve performance (both CPU and memory use) for almost all RETS calls by using node-expat instead of xml2js for xml parsing. The changes are mostly internal, however there is 1 small backward-incompatible change needed for correctness, described below. The large internal refactor plus even a small breaking change warrants a major version bump.
Version 3.x has almost the same interface as 2.x, which is completely different from 1.x. If you wish to continue to use the 1.x version, you can use the v1 branch.
Many of the metadata methods are capable of returning multiple sets of data, including (but not limited to) the
getAll* methods. Versions 1.x and 2.x did not handle this properly; version 1.x returns the values from the last set
encountered, and version 2.x returns the values from the first set encountered. (This has been corrected in version
1.2.0.) Version 3.x always returns all values encountered, by returning an array of data sets rather than a single one.
In addition to the methods available in 2.x, version 3.0 adds client.search.stream.searchRets()
, which returns a
text stream of the raw XML result, and client.search.stream.query()
, which returns a stream of low-level objects
parsed from the XML. (See the streaming example below.) These streams, if used properly,
should result in a much lower memory footprint than their corresponding non-streaming counterparts.