CartoDB-SQL-API/NEWS.md
2014-09-17 00:04:10 +02:00

9.2 KiB

1.17.1 - 2014-mm-dd

1.17.0 - 2014-09-17

Bug fixes:

  • Returns 401 Unauthorized for queries without permission

New features:

  • New header for database host serving the request
  • Health check endpoint

Enhancements:

  • Upgrades dependencies:
    • cartodb-redis
    • cartodb-psql
    • log4js

1.16.0 - 2014-08-19

Enhancements:

  • Metrics revamp: removes and adds some metrics

1.15.0 - 2014-08-18

Enhancements:

  • Upgrades cartodb-redis
  • Upgrades underscore, removes underscore.string dependency
  • Uses https endpoints for dependencies

1.14.1 - 2014-08-08

Other changes:

  • Constraint for pg_ queries if request is non authenticated

1.14.0 - 2014-08-07

Other changes:

  • Removes sql statements restriction on pg_ queries

1.13.0 - 2014-08-07

New features:

  • New authentication mechanism: checks in advance if credentials are provided in order to do a single request to redis to retrieve the required database connection parameters.
  • Retrieves OAuth hash values using new cartodb-redis method so it will reuse the redis pool from cartodb-redis instead of using just one pool for oauth.

1.12.1 - 2014-08-05

Bug fixes:

  • Fixes GeoJSON stream error responses
  • Fixes GeoJSON stream empty responses
  • JSONP callbacks return with 200 status error code

Enhancements:

  • Re-enables tests

1.12.0 - 2014-08-04

New features:

  • Add header for host serving the request
  • Stream JSON/GeoJSON responses

1.11.0 - 2014-07-30

New features:

  • Support for different schemas and different public users

Enhancements:

  • Profiler header sent as JSON string

Other changes:

  • Revamped documentation

Bug fixes:

  • Pick redis pool configuration values

1.10.1 - 2014-06-05

Bug fixes:

  • Backing out Stream JSON responses

1.10.0 - 2014-06-04

New features:

  • Order by and sort order through http query params
  • Cancelling queries in Postgresql when HTTP request is aborted/closed

Enhancements:

  • Stream JSON responses
  • Pre-compiling may write regex
  • Set default PostgreSQL application name to "cartodb_sqlapi"

Bug fixes:

  • Support trailing semicolons (#147)

1.9.1 - 2014-03-27

Bug fixes:

  • Fix paging with queries starting with comments (#144)

1.9.0 - 2014-03-20

New features:

  • Add optional support for rollbar (#137)
  • Add '/version' endpoint (#138)
  • Add profiler support (#142)
  • Add statsd support (#133)

Enhancements:

  • Allow configuring log_format (#131)
  • Use log4js for logging (#136)
  • Include version in startup log
  • Allow passing environment configuration name via NODE_ENV to app.js
  • Print environment configuration name on app start
  • Upgrade node-zipfile to ~0.5.0
  • Add support for node-0.10 (#132)
  • Fix lack of response on backend crash (#135)
  • Reduce work on aborted requests (#129)

Other changes:

  • Switch to 3-clause BSD license (#143)

1.8.3 - 2014-02-10

Bug fixes:

  • Honour the 'node_socket_timeout' configuration directive (#128)

Enhancements:

  • Add support for error handling in assert.request
  • Stop using ANSI colors in the logs (#130)

1.8.2 - 2014-01-20

Bug fixes:

  • Restore compatibility with 1.6.x configuration
  • Use db_port in ogr2ogr

1.8.1 - 2014-01-10

Bug fixes:

  • Fix use of "SELECT .. INTO" with windowing params (#127)

1.8.0 - 2013-12-18

New features:

  • Add 'user_from_host' directive to generalize username extraction (#124)

Improvements:

  • Enhance error message on unknown cartodb username (#126)

1.7.1 - 2013-12-02

  • Fix documentation for CSV export format: geoms are in hexewkb, not ewkt.
  • Fix field types names lookup after PSQL model refactoring NOTE: fixes missing .prj in shapefile export regression (#122)

1.7.0 - 2013-11-19

New features:

  • Optionally read user-specific database_host and database_password from redis, as per CartoDB-2.5.0 model (#120, #121)
  • Add warnings and notices to JSON response (#104)

Other changes:

  • CartoDB redis interaction delegated to "cartodb-redis" module

1.6.3 - 2013-11-10

  • JSON format: correctly recognize "numeric" type columns (#119)

1.6.2 - 2013-11-07

  • JSON format: correctly recognize "date" type columns (#117)
  • Allow access to tables whose name contains (but does not start with) the "pg_" substring (#118)

1.6.1 - 2013-11-05

  • Still set a meaningful X-Cache-Channel with cache_policy=persist (#105)
  • Fix wrong projection in KML exports for manually altered tables (#116)
  • Set KML folder name to the requested filename (#115)
  • Make public PostgreSQL user name a configuration parameter (#56)

1.6.0 - 2013-10-02

  • Fix shapefile export for non-linestring results starting with NULLs (#111)
  • Fix missing .prj in shapefile export (#110)
  • Improve recognition of non-standard field types names by db lookup (#112)
  • Upgrade node-pg dependency to 2.6.2
  • Drop support for cluster

1.5.4 - 2013-10-01

  • Honour skipfields in JSON schema response (#109)

1.5.3

  • Set Last-Modified header with cache_policy=persist
  • Raise max-age to one year for all cacheable queries
  • Set max-age to 0 for uncacheable (mutating) queries
  • Add REINDEX to the list of uncacheable queries
  • Support all parameters with POST as well as GET
  • Ensure testsuite passes with both GDAL-0.9 and GDAL-0.10
  • JSON output: report boolean types as boolean, not string (#106)

1.5.2

  • Keep numbers as such in JSON output (#100)
  • Revert max-age=0 in Cache-Control when using no-cache

1.5.1

  • Improve cacheability of queries selecting "updated_at" fields (#99)

1.5.0

  • Add "fields" member in JSON return (#97)
  • Add --skipfields switch to cdbsql
  • Fix windowing with CTE
  • Retain UTC offset in JSON date output
  • Set max-age=0 in Cache-Control when using no-cache

1.4.1

  • Fix windowing support for non-uppercased SELECT queries
  • Fix oAuth testcase

1.4.0

  • Add arraybuffer format
  • Fix filesystem access conflict among clustered processes
  • Fix discard of queued export requests on error
  • Really fix problem identifying OAuth requests

1.3.10

  • Fixed problem identifying OAuth request protocol
  • Make base url configurable
  • Update underscore dependency
  • Add munin plugin
  • Make PostgreSQL client pooling settings configurable (#47)
  • Do not execute queries on OPTIONS (#94)
  • Survive postgresql connection losses (#95)

1.3.9

  • Do not choke on multiple skipfields parameter
  • Do not request caching of TRUNCATE queries

1.3.8

  • Make using SET or querying system catalogues harder
  • Allow sql queries to end with a semicolon (#90)
  • Testsuite fixes, jenkins ready :)

1.3.7

  • Fix parsing of numeric arrays (#88)
  • node-pool upgraded to 2.0.3
  • Reduce memory use on KML export
  • Fix concurrent request for KML and Shapefile exports
  • Send an empty-like KML when exporting zero-rows queries
  • Make temporary dir a configuration setting
  • Use OGR for CSV output, reducing memory requirement

1.3.6 (DD/MM/YY)

  • Do not confuse warnings with errors on shapefile output (#87)

1.3.5 (19/02/13)

  • Fix skipfields use with SHP output format (#81)
  • Fix Content-Disposition for error responses (#82)
  • Add pid to /cachestatus (#83)
  • Check CDB_QueryTable response before saving into cache (#83)
  • Use an expiring LRU cache for query tables (#83)
  • Fix X-Cache-Channel computation with paging parameters (#85)

1.3.4 (21/01/13)

  • Improve mixed-geometry export error message (#78)
  • Remove NULL the_geom features from topojson output (#80)
  • Fix crash when issuing SQL "COPY" command
  • Return an error when "the_geom" is in skipfield for SVG output (#73)

1.3.3 (11/01/13)

  • Fix Date format in CSV output (#77)
  • Add TopoJSON output format (#79)

1.3.2 (30/11/12)

  • Fix KML export truncation (#70)
  • Fix UTF8 in shapefile export (#66)

1.3.1 (DD/MM/YY)

  • Support 'format' and 'filename' params in POST
  • Fix oAuth bug introduced by 'skipfields' param in 1.3.0 (#69)

1.3.0 (DD/MM/YY)

  • Support for specifying a filename for exports (#64)
  • Support for specifying a list of fields to skip from output (#63)
  • Add 'cache_policy' parameter (#62)

1.2.1 (DD/MM/YY)

  • Added timeout default to 600 miliseconds in cluster.js

1.2.0 (DD/MM/YY)

  • New output formats:
    • ESRI Shapefile (format=shp)
    • SVG (format=svg)
    • KML (format=kml)
  • Advertise header presence in CSV Content-Type
  • Fix CSV output with no rows (#60)
  • Use "attachment" Content-Disposition for all output formats (#61)
  • Only use last format parameter when multiple are requested
  • Return a 400 response on unsupported format request
  • Added X-Prototype-Version, X-CSRF-Token to Access-Control-Allow-Headers

1.1.0 (30/10/12)

  • Fixed problem in cluster2 with pidfile name
  • SVG output format
  • Enhancement to the cdbsql tool:
    • New switches: --format, --key, --dp
    • Interactive mode
  • API documentation
  • ./configure script
  • Restrict listening to a node host

1.0.0 (03/10/12)

  • Migrated to node 0.8 version

0.9.0 (18/09/12)

  • Fix INSERT and UPDATE with RETURNING clause