{"html_url": "https://github.com/dogsheep/twitter-to-sqlite/releases/tag/0.4", "id": 19865891, "node_id": "MDc6UmVsZWFzZTE5ODY1ODkx", "tag_name": "0.4", "target_commitish": "master", "name": "0.4", "draft": 0, "author": {"value": 9599, "label": "simonw"}, "prerelease": 0, "created_at": "2019-09-09T22:41:25Z", "published_at": "2019-09-09T22:43:05Z", "body": "* New `users-lookup` command for fetching multiple user profiles, including using new `--sql` and `--attach` options\r\n* New `list-members` subcommand for fetching members of a list\r\n* Added `stop_after` option to `user-timeline` command", "repo": {"value": 206156866, "label": "twitter-to-sqlite"}, "reactions": null} {"html_url": "https://github.com/dogsheep/twitter-to-sqlite/releases/tag/0.3", "id": 19763200, "node_id": "MDc6UmVsZWFzZTE5NzYzMjAw", "tag_name": "0.3", "target_commitish": "master", "name": "0.3", "draft": 0, "author": {"value": 9599, "label": "simonw"}, "prerelease": 0, "created_at": "2019-09-04T22:10:07Z", "published_at": "2019-09-04T22:11:01Z", "body": "Extract places and media into separate tables\r\n\r\nDemo: https://twitter-to-sqlite-demo.now.sh/", "repo": {"value": 206156866, "label": "twitter-to-sqlite"}, "reactions": null} {"html_url": "https://github.com/dogsheep/twitter-to-sqlite/releases/tag/0.2", "id": 19763185, "node_id": "MDc6UmVsZWFzZTE5NzYzMTg1", "tag_name": "0.2", "target_commitish": "master", "name": "0.2", "draft": 0, "author": {"value": 9599, "label": "simonw"}, "prerelease": 0, "created_at": "2019-09-04T21:17:34Z", "published_at": "2019-09-04T22:09:46Z", "body": "Full text search for tweets table", "repo": {"value": 206156866, "label": "twitter-to-sqlite"}, "reactions": null} {"html_url": "https://github.com/dogsheep/twitter-to-sqlite/releases/tag/0.1a", "id": 19763160, "node_id": "MDc6UmVsZWFzZTE5NzYzMTYw", "tag_name": "0.1a", "target_commitish": "master", "name": "Alpha release", "draft": 0, "author": {"value": 9599, "label": "simonw"}, "prerelease": 0, "created_at": "2019-09-03T20:42:38Z", "published_at": "2019-09-04T22:08:18Z", "body": "", "repo": {"value": 206156866, "label": "twitter-to-sqlite"}, "reactions": null} {"html_url": "https://github.com/simonw/sqlite-utils/releases/tag/1.11", "id": 19704889, "node_id": "MDc6UmVsZWFzZTE5NzA0ODg5", "tag_name": "1.11", "target_commitish": "master", "name": "1.11", "draft": 0, "author": {"value": 9599, "label": "simonw"}, "prerelease": 0, "created_at": "2019-09-03T00:58:41Z", "published_at": "2019-09-03T01:03:27Z", "body": "https://sqlite-utils.readthedocs.io/en/stable/changelog.html#v1-11", "repo": {"value": 140912432, "label": "sqlite-utils"}, "reactions": null} {"html_url": "https://github.com/simonw/datasette/releases/tag/0.29.3", "id": 20795250, "node_id": "MDc6UmVsZWFzZTIwNzk1MjUw", "tag_name": "0.29.3", "target_commitish": "master", "name": "0.29.3", "draft": 0, "author": {"value": 9599, "label": "simonw"}, "prerelease": 0, "created_at": "2019-09-03T00:40:53Z", "published_at": "2019-10-18T05:24:54Z", "body": "https://datasette.readthedocs.io/en/stable/changelog.html#v0-29-3", "repo": {"value": 107914493, "label": "datasette"}, "reactions": null} {"html_url": "https://github.com/dogsheep/swarm-to-sqlite/releases/tag/0.1", "id": 19669553, "node_id": "MDc6UmVsZWFzZTE5NjY5NTUz", "tag_name": "0.1", "target_commitish": "master", "name": "0.1", "draft": 0, "author": {"value": 9599, "label": "simonw"}, "prerelease": 0, "created_at": "2019-08-31T02:46:58Z", "published_at": "2019-08-31T02:58:32Z", "body": "First usable release.", "repo": {"value": 205429375, "label": "swarm-to-sqlite"}, "reactions": null} {"html_url": "https://github.com/simonw/sqlite-utils/releases/tag/1.10", "id": 19704743, "node_id": "MDc6UmVsZWFzZTE5NzA0NzQz", "tag_name": "1.10", "target_commitish": "master", "name": "1.10", "draft": 0, "author": {"value": 9599, "label": "simonw"}, "prerelease": 0, "created_at": "2019-08-23T12:24:04Z", "published_at": "2019-09-03T00:46:27Z", "body": "https://sqlite-utils.readthedocs.io/en/stable/changelog.html#v1-10", "repo": {"value": 140912432, "label": "sqlite-utils"}, "reactions": null} {"html_url": "https://github.com/simonw/sqlite-utils/releases/tag/1.9", "id": 19704739, "node_id": "MDc6UmVsZWFzZTE5NzA0NzM5", "tag_name": "1.9", "target_commitish": "master", "name": "1.9", "draft": 0, "author": {"value": 9599, "label": "simonw"}, "prerelease": 0, "created_at": "2019-08-04T03:35:30Z", "published_at": "2019-09-03T00:46:02Z", "body": "https://sqlite-utils.readthedocs.io/en/stable/changelog.html#v1-9", "repo": {"value": 140912432, "label": "sqlite-utils"}, "reactions": null} {"html_url": "https://github.com/simonw/sqlite-utils/releases/tag/1.8", "id": 19704736, "node_id": "MDc6UmVsZWFzZTE5NzA0NzM2", "tag_name": "1.8", "target_commitish": "master", "name": "1.8", "draft": 0, "author": {"value": 9599, "label": "simonw"}, "prerelease": 0, "created_at": "2019-07-28T15:41:42Z", "published_at": "2019-09-03T00:45:42Z", "body": "https://sqlite-utils.readthedocs.io/en/stable/changelog.html#v1-8", "repo": {"value": 140912432, "label": "sqlite-utils"}, "reactions": null} {"html_url": "https://github.com/simonw/sqlite-utils/releases/tag/1.7.1", "id": 18911404, "node_id": "MDc6UmVsZWFzZTE4OTExNDA0", "tag_name": "1.7.1", "target_commitish": "master", "name": "1.7.1", "draft": 0, "author": {"value": 9599, "label": "simonw"}, "prerelease": 0, "created_at": "2019-07-28T12:00:51Z", "published_at": "2019-07-28T12:05:36Z", "body": "https://sqlite-utils.readthedocs.io/en/latest/changelog.html#v1-7-1", "repo": {"value": 140912432, "label": "sqlite-utils"}, "reactions": null} {"html_url": "https://github.com/dogsheep/healthkit-to-sqlite/releases/tag/0.3.2", "id": 18881253, "node_id": "MDc6UmVsZWFzZTE4ODgxMjUz", "tag_name": "0.3.2", "target_commitish": "master", "name": "0.3.2", "draft": 0, "author": {"value": 9599, "label": "simonw"}, "prerelease": 0, "created_at": "2019-07-26T06:02:30Z", "published_at": "2019-07-26T06:12:12Z", "body": "Fix for #9 - Too many SQL variables bug", "repo": {"value": 197882382, "label": "healthkit-to-sqlite"}, "reactions": null} {"html_url": "https://github.com/simonw/sqlite-utils/releases/tag/1.7", "id": 18911392, "node_id": "MDc6UmVsZWFzZTE4OTExMzky", "tag_name": "1.7", "target_commitish": "master", "name": "1.7", "draft": 0, "author": {"value": 9599, "label": "simonw"}, "prerelease": 0, "created_at": "2019-07-24T06:50:41Z", "published_at": "2019-07-28T12:03:21Z", "body": "https://sqlite-utils.readthedocs.io/en/latest/changelog.html#v1-7", "repo": {"value": 140912432, "label": "sqlite-utils"}, "reactions": null} {"html_url": "https://github.com/dogsheep/healthkit-to-sqlite/releases/tag/0.3.1", "id": 18823859, "node_id": "MDc6UmVsZWFzZTE4ODIzODU5", "tag_name": "0.3.1", "target_commitish": "master", "name": "0.3.1", "draft": 0, "author": {"value": 9599, "label": "simonw"}, "prerelease": 0, "created_at": "2019-07-24T06:33:22Z", "published_at": "2019-07-24T06:38:36Z", "body": "Uses less RAM - see #7 ", "repo": {"value": 197882382, "label": "healthkit-to-sqlite"}, "reactions": null} {"html_url": "https://github.com/dogsheep/healthkit-to-sqlite/releases/tag/0.3", "id": 18762495, "node_id": "MDc6UmVsZWFzZTE4NzYyNDk1", "tag_name": "0.3", "target_commitish": "master", "name": "0.3", "draft": 0, "author": {"value": 9599, "label": "simonw"}, "prerelease": 0, "created_at": "2019-07-22T03:31:54Z", "published_at": "2019-07-22T03:33:32Z", "body": "- Tool now displays a progress bar during import - you can disable it with `--silent` #5\r\n- You can pass a path to a decompressed XML file instead of a zip file, using `--xml`\r\n- Records table is now broken up into different tables for each type of recorded data #6", "repo": {"value": 197882382, "label": "healthkit-to-sqlite"}, "reactions": null} {"html_url": "https://github.com/dogsheep/healthkit-to-sqlite/releases/tag/0.2", "id": 18750559, "node_id": "MDc6UmVsZWFzZTE4NzUwNTU5", "tag_name": "0.2", "target_commitish": "master", "name": "0.2", "draft": 0, "author": {"value": 9599, "label": "simonw"}, "prerelease": 0, "created_at": "2019-07-20T16:44:05Z", "published_at": "2019-07-20T16:44:41Z", "body": "Fixed a bug where duplicate records could crash the import.", "repo": {"value": 197882382, "label": "healthkit-to-sqlite"}, "reactions": null} {"html_url": "https://github.com/dogsheep/healthkit-to-sqlite/releases/tag/0.1", "id": 18750551, "node_id": "MDc6UmVsZWFzZTE4NzUwNTUx", "tag_name": "0.1", "target_commitish": "master", "name": "Initial release", "draft": 0, "author": {"value": 9599, "label": "simonw"}, "prerelease": 0, "created_at": "2019-07-20T06:22:57Z", "published_at": "2019-07-20T16:43:09Z", "body": "", "repo": {"value": 197882382, "label": "healthkit-to-sqlite"}, "reactions": null} {"html_url": "https://github.com/simonw/sqlite-utils/releases/tag/1.6", "id": 18723202, "node_id": "MDc6UmVsZWFzZTE4NzIzMjAy", "tag_name": "1.6", "target_commitish": "master", "name": "1.6", "draft": 0, "author": {"value": 9599, "label": "simonw"}, "prerelease": 0, "created_at": "2019-07-19T04:51:21Z", "published_at": "2019-07-19T05:36:48Z", "body": "- `sqlite-utils insert` can now accept TSV data via the new `--tsv` option (#41)\r\n", "repo": {"value": 140912432, "label": "sqlite-utils"}, "reactions": null} {"html_url": "https://github.com/simonw/datasette/releases/tag/0.29.2", "id": 19704661, "node_id": "MDc6UmVsZWFzZTE5NzA0NjYx", "tag_name": "0.29.2", "target_commitish": "master", "name": "0.29.2", "draft": 0, "author": {"value": 9599, "label": "simonw"}, "prerelease": 0, "created_at": "2019-07-14T03:04:05Z", "published_at": "2019-09-03T00:33:35Z", "body": "* Bumped Uvicorn to 0.8.4, fixing a bug where the querystring was not included in the server logs. (#559)\r\n* Fixed bug where the navigation breadcrumbs were not displayed correctly on the page for a custom query. (#558)\r\n* Fixed bug where custom query names containing unicode characters caused errors.\r\n\r\nhttps://datasette.readthedocs.io/en/stable/changelog.html#v0-29-2", "repo": {"value": 107914493, "label": "datasette"}, "reactions": null} {"html_url": "https://github.com/simonw/datasette/releases/tag/0.29.1", "id": 18598489, "node_id": "MDc6UmVsZWFzZTE4NTk4NDg5", "tag_name": "0.29.1", "target_commitish": "master", "name": "0.29.1", "draft": 0, "author": {"value": 9599, "label": "simonw"}, "prerelease": 0, "created_at": "2019-07-11T16:17:55Z", "published_at": "2019-07-14T01:43:44Z", "body": "- Fixed bug with static mounts using relative paths which could lead to traversal exploits (#555) - thanks Abdussamet Kocak!\r\n\r\nhttps://datasette.readthedocs.io/en/stable/changelog.html#v0-29-1", "repo": {"value": 107914493, "label": "datasette"}, "reactions": null} {"html_url": "https://github.com/simonw/datasette/releases/tag/0.29", "id": 18461320, "node_id": "MDc6UmVsZWFzZTE4NDYxMzIw", "tag_name": "0.29", "target_commitish": "master", "name": "Datasette 0.29", "draft": 0, "author": {"value": 9599, "label": "simonw"}, "prerelease": 0, "created_at": "2019-07-08T03:14:27Z", "published_at": "2019-07-08T03:43:13Z", "body": "ASGI, new plugin hooks, facet by date and much, much more\u2026 See [the release notes](https://datasette.readthedocs.io/en/stable/changelog.html#v0-29) for full details.", "repo": {"value": 107914493, "label": "datasette"}, "reactions": null} {"html_url": "https://github.com/simonw/sqlite-utils/releases/tag/1.3", "id": 18307928, "node_id": "MDc6UmVsZWFzZTE4MzA3OTI4", "tag_name": "1.3", "target_commitish": "master", "name": "1.3", "draft": 0, "author": {"value": 9599, "label": "simonw"}, "prerelease": 0, "created_at": "2019-06-29T06:32:36Z", "published_at": "2019-06-29T06:39:32Z", "body": "https://sqlite-utils.readthedocs.io/en/latest/changelog.html#v1-3", "repo": {"value": 140912432, "label": "sqlite-utils"}, "reactions": null} {"html_url": "https://github.com/simonw/sqlite-utils/releases/tag/1.2.2", "id": 18226656, "node_id": "MDc6UmVsZWFzZTE4MjI2NjU2", "tag_name": "1.2.2", "target_commitish": "master", "name": "1.2.2", "draft": 0, "author": {"value": 9599, "label": "simonw"}, "prerelease": 0, "created_at": "2019-06-26T04:20:55Z", "published_at": "2019-06-26T04:24:33Z", "body": "https://sqlite-utils.readthedocs.io/en/latest/changelog.html#v1-2-2", "repo": {"value": 140912432, "label": "sqlite-utils"}, "reactions": null} {"html_url": "https://github.com/simonw/sqlite-utils/releases/tag/1.2.1", "id": 18132566, "node_id": "MDc6UmVsZWFzZTE4MTMyNTY2", "tag_name": "1.2.1", "target_commitish": "master", "name": "1.2.1", "draft": 0, "author": {"value": 9599, "label": "simonw"}, "prerelease": 0, "created_at": "2019-06-21T00:01:24Z", "published_at": "2019-06-21T00:06:29Z", "body": "https://sqlite-utils.readthedocs.io/en/latest/changelog.html#v1-2-1", "repo": {"value": 140912432, "label": "sqlite-utils"}, "reactions": null} {"html_url": "https://github.com/simonw/sqlite-utils/releases/tag/1.2", "id": 17961871, "node_id": "MDc6UmVsZWFzZTE3OTYxODcx", "tag_name": "1.2", "target_commitish": "master", "name": "1.2", "draft": 0, "author": {"value": 9599, "label": "simonw"}, "prerelease": 0, "created_at": "2019-06-13T06:39:59Z", "published_at": "2019-06-13T06:42:21Z", "body": "https://sqlite-utils.readthedocs.io/en/latest/changelog.html#v1-2", "repo": {"value": 140912432, "label": "sqlite-utils"}, "reactions": null} {"html_url": "https://github.com/simonw/sqlite-utils/releases/tag/1.1", "id": 17645877, "node_id": "MDc6UmVsZWFzZTE3NjQ1ODc3", "tag_name": "1.1", "target_commitish": "master", "name": "1.1", "draft": 0, "author": {"value": 9599, "label": "simonw"}, "prerelease": 0, "created_at": "2019-05-29T05:12:03Z", "published_at": "2019-05-29T05:15:22Z", "body": "https://sqlite-utils.readthedocs.io/en/latest/changelog.html#v1-1\r\n\r\n* Support for `ignore=True` / `--ignore` for ignoring inserted records if the primary key alread exists (#21)\r\n* Ability to add a column that is a foreign key reference using `fk=...` / `--fk` (#16)\r\n", "repo": {"value": 140912432, "label": "sqlite-utils"}, "reactions": null} {"html_url": "https://github.com/simonw/sqlite-utils/releases/tag/1.0.1", "id": 17616531, "node_id": "MDc6UmVsZWFzZTE3NjE2NTMx", "tag_name": "1.0.1", "target_commitish": "master", "name": "1.0.1", "draft": 0, "author": {"value": 9599, "label": "simonw"}, "prerelease": 0, "created_at": "2019-05-28T00:50:28Z", "published_at": "2019-05-28T00:51:21Z", "body": "https://sqlite-utils.readthedocs.io/en/latest/changelog.html#v1-0-1", "repo": {"value": 140912432, "label": "sqlite-utils"}, "reactions": null} {"html_url": "https://github.com/simonw/sqlite-utils/releases/tag/1.0", "id": 17583581, "node_id": "MDc6UmVsZWFzZTE3NTgzNTgx", "tag_name": "1.0", "target_commitish": "master", "name": "1.0", "draft": 0, "author": {"value": 9599, "label": "simonw"}, "prerelease": 0, "created_at": "2019-05-25T01:06:38Z", "published_at": "2019-05-25T01:19:21Z", "body": "https://sqlite-utils.readthedocs.io/en/latest/changelog.html#v1-0", "repo": {"value": 140912432, "label": "sqlite-utils"}, "reactions": null} {"html_url": "https://github.com/simonw/datasette/releases/tag/0.28", "id": 17450414, "node_id": "MDc6UmVsZWFzZTE3NDUwNDE0", "tag_name": "0.28", "target_commitish": "master", "name": "Datasette 0.28", "draft": 0, "author": {"value": 9599, "label": "simonw"}, "prerelease": 0, "created_at": "2019-05-19T21:37:49Z", "published_at": "2019-05-19T21:42:28Z", "body": "[Datasette 0.28](https://datasette.readthedocs.io/en/stable/changelog.html#v0-28) - a salmagundi of new features!\r\n * No longer immutable! Datasette now supports [databases that change](https://datasette.readthedocs.io/en/stable/changelog.html#supporting-databases-that-change).\r\n * [Faceting improvements](https://datasette.readthedocs.io/en/stable/changelog.html#faceting-improvements-and-faceting-plugins) including facet-by-JSON-array and the ability to define custom faceting using plugins.\r\n * [datasette publish cloudrun](https://datasette.readthedocs.io/en/stable/changelog.html#datasette-publish-cloudrun) lets you publish databasese to Google's new Cloud Run hosting service.\r\n * New [register_output_renderer](https://datasette.readthedocs.io/en/stable/changelog.html#register-output-renderer-plugins) plugin hook for adding custom output extensions to Datasette in addition to the default `.json` and `.csv`.\r\n * Dozens of other smaller features and tweaks - see [the release notes](https://datasette.readthedocs.io/en/stable/changelog.html#v0-28) for full details.", "repo": {"value": 107914493, "label": "datasette"}, "reactions": null} {"html_url": "https://github.com/simonw/sqlite-utils/releases/tag/0.14", "id": 15744513, "node_id": "MDc6UmVsZWFzZTE1NzQ0NTEz", "tag_name": "0.14", "target_commitish": "master", "name": "0.14", "draft": 0, "author": {"value": 9599, "label": "simonw"}, "prerelease": 0, "created_at": "2019-02-24T23:11:51Z", "published_at": "2019-02-24T23:15:16Z", "body": "https://sqlite-utils.readthedocs.io/en/latest/changelog.html#v0-14", "repo": {"value": 140912432, "label": "sqlite-utils"}, "reactions": null} {"html_url": "https://github.com/simonw/sqlite-utils/releases/tag/0.13", "id": 15739051, "node_id": "MDc6UmVsZWFzZTE1NzM5MDUx", "tag_name": "0.13", "target_commitish": "master", "name": "0.13", "draft": 0, "author": {"value": 9599, "label": "simonw"}, "prerelease": 0, "created_at": "2019-02-24T06:54:43Z", "published_at": "2019-02-24T07:00:14Z", "body": "https://sqlite-utils.readthedocs.io/en/latest/changelog.html#v0-13", "repo": {"value": 140912432, "label": "sqlite-utils"}, "reactions": null} {"html_url": "https://github.com/simonw/sqlite-utils/releases/tag/0.12", "id": 15731354, "node_id": "MDc6UmVsZWFzZTE1NzMxMzU0", "tag_name": "0.12", "target_commitish": "master", "name": "0.12", "draft": 0, "author": {"value": 9599, "label": "simonw"}, "prerelease": 0, "created_at": "2019-02-23T02:22:28Z", "published_at": "2019-02-23T02:31:29Z", "body": "https://sqlite-utils.readthedocs.io/en/latest/changelog.html#v0-12", "repo": {"value": 140912432, "label": "sqlite-utils"}, "reactions": null} {"html_url": "https://github.com/simonw/sqlite-utils/releases/tag/0.11", "id": 15731282, "node_id": "MDc6UmVsZWFzZTE1NzMxMjgy", "tag_name": "0.11", "target_commitish": "master", "name": "0.11", "draft": 0, "author": {"value": 9599, "label": "simonw"}, "prerelease": 0, "created_at": "2019-02-08T05:23:50Z", "published_at": "2019-02-23T02:15:34Z", "body": "https://sqlite-utils.readthedocs.io/en/latest/changelog.html#v0-11", "repo": {"value": 140912432, "label": "sqlite-utils"}, "reactions": null} {"html_url": "https://github.com/simonw/sqlite-utils/releases/tag/0.10", "id": 15439849, "node_id": "MDc6UmVsZWFzZTE1NDM5ODQ5", "tag_name": "0.10", "target_commitish": "master", "name": "0.10", "draft": 0, "author": {"value": 9599, "label": "simonw"}, "prerelease": 0, "created_at": "2019-02-07T05:17:52Z", "published_at": "2019-02-08T05:19:33Z", "body": "https://sqlite-utils.readthedocs.io/en/latest/changelog.html#v0-10", "repo": {"value": 140912432, "label": "sqlite-utils"}, "reactions": null} {"html_url": "https://github.com/simonw/datasette/releases/tag/0.27", "id": 15389392, "node_id": "MDc6UmVsZWFzZTE1Mzg5Mzky", "tag_name": "0.27", "target_commitish": "master", "name": "Datasette 0.27", "draft": 0, "author": {"value": 9599, "label": "simonw"}, "prerelease": 0, "created_at": "2019-02-01T03:47:05Z", "published_at": "2019-02-06T05:10:20Z", "body": "https://datasette.readthedocs.io/en/stable/changelog.html#v0-27", "repo": {"value": 107914493, "label": "datasette"}, "reactions": null} {"html_url": "https://github.com/simonw/sqlite-utils/releases/tag/0.9", "id": 15243253, "node_id": "MDc6UmVsZWFzZTE1MjQzMjUz", "tag_name": "0.9", "target_commitish": "master", "name": "0.9", "draft": 0, "author": {"value": 9599, "label": "simonw"}, "prerelease": 0, "created_at": "2019-01-28T06:34:33Z", "published_at": "2019-01-29T15:30:48Z", "body": "https://sqlite-utils.readthedocs.io/en/latest/changelog.html#v0-9", "repo": {"value": 140912432, "label": "sqlite-utils"}, "reactions": null} {"html_url": "https://github.com/simonw/sqlite-utils/releases/tag/0.8", "id": 15208430, "node_id": "MDc6UmVsZWFzZTE1MjA4NDMw", "tag_name": "0.8", "target_commitish": "master", "name": "0.8", "draft": 0, "author": {"value": 9599, "label": "simonw"}, "prerelease": 0, "created_at": "2019-01-26T02:13:29Z", "published_at": "2019-01-28T06:28:12Z", "body": "Two new commands: `sqlite-utils csv` and `sqlite-utils json`\r\n\r\nhttps://sqlite-utils.readthedocs.io/en/latest/changelog.html#v0-8", "repo": {"value": 140912432, "label": "sqlite-utils"}, "reactions": null} {"html_url": "https://github.com/simonw/sqlite-utils/releases/tag/0.7", "id": 15175633, "node_id": "MDc6UmVsZWFzZTE1MTc1NjMz", "tag_name": "0.7", "target_commitish": "master", "name": "0.7", "draft": 0, "author": {"value": 9599, "label": "simonw"}, "prerelease": 0, "created_at": "2019-01-25T07:20:49Z", "published_at": "2019-01-25T07:27:57Z", "body": "Release notes are here: https://sqlite-utils.readthedocs.io/en/latest/changelog.html#v0-7", "repo": {"value": 140912432, "label": "sqlite-utils"}, "reactions": null} {"html_url": "https://github.com/simonw/datasette/releases/tag/0.26.1", "id": 15206659, "node_id": "MDc6UmVsZWFzZTE1MjA2NjU5", "tag_name": "0.26.1", "target_commitish": "master", "name": "Datasette 0.26.1", "draft": 0, "author": {"value": 9599, "label": "simonw"}, "prerelease": 0, "created_at": "2019-01-11T00:51:38Z", "published_at": "2019-01-28T01:50:45Z", "body": "Release notes: https://datasette.readthedocs.io/en/stable/changelog.html#v0-26-1", "repo": {"value": 107914493, "label": "datasette"}, "reactions": null} {"html_url": "https://github.com/simonw/datasette/releases/tag/0.26", "id": 14914779, "node_id": "MDc6UmVsZWFzZTE0OTE0Nzc5", "tag_name": "0.26", "target_commitish": "master", "name": "Datasette 0.26", "draft": 0, "author": {"value": 9599, "label": "simonw"}, "prerelease": 0, "created_at": "2019-01-03T02:53:59Z", "published_at": "2019-01-10T21:41:00Z", "body": "[Datasette 0.26 release notes](https://datasette.readthedocs.io/en/stable/changelog.html#v0-26)", "repo": {"value": 107914493, "label": "datasette"}, "reactions": null} {"html_url": "https://github.com/simonw/datasette/releases/tag/0.25.2", "id": 14560304, "node_id": "MDc6UmVsZWFzZTE0NTYwMzA0", "tag_name": "0.25.2", "target_commitish": "master", "name": "Datasette 0.25.2", "draft": 0, "author": {"value": 9599, "label": "simonw"}, "prerelease": 0, "created_at": "2018-12-16T21:26:37Z", "published_at": "2018-12-16T21:45:39Z", "body": "* `datasette publish heroku` now uses the `python-3.6.7` runtime\r\n* Added documentation on [how to build the documentation](https://datasette.readthedocs.io/en/stable/contributing.html#editing-and-building-the-documentation)\r\n* Added documentation covering [our release process](https://datasette.readthedocs.io/en/stable/contributing.html#release-process)\r\n* Upgraded to pytest 4.0.2\r\n", "repo": {"value": 107914493, "label": "datasette"}, "reactions": null} {"html_url": "https://github.com/simonw/datasette/releases/tag/0.25.1", "id": 14560294, "node_id": "MDc6UmVsZWFzZTE0NTYwMjk0", "tag_name": "0.25.1", "target_commitish": "master", "name": "Datasette 0.25.1", "draft": 0, "author": {"value": 9599, "label": "simonw"}, "prerelease": 0, "created_at": "2018-11-05T06:31:41Z", "published_at": "2018-12-16T21:44:27Z", "body": "Documentation improvements plus a fix for publishing to Zeit Now.\r\n\r\n* `datasette publish now` now uses Zeit\u2019s v1 platform, to work around the new 100MB image limit. Thanks, @slygent - closes #366.\r\n", "repo": {"value": 107914493, "label": "datasette"}, "reactions": null} {"html_url": "https://github.com/simonw/datasette/releases/tag/0.25", "id": 12986637, "node_id": "MDc6UmVsZWFzZTEyOTg2NjM3", "tag_name": "0.25", "target_commitish": "master", "name": "Datasette 0.25", "draft": 0, "author": {"value": 9599, "label": "simonw"}, "prerelease": 0, "created_at": "2018-09-19T17:48:12Z", "published_at": "2018-09-19T18:27:21Z", "body": "New plugin hooks, improved database view support and an easier way to use more recent versions of SQLite.\r\n\r\nSee full release notes here: https://datasette.readthedocs.io/en/latest/changelog.html#v0-25", "repo": {"value": 107914493, "label": "datasette"}, "reactions": null} {"html_url": "https://github.com/simonw/datasette/releases/tag/0.24", "id": 12080036, "node_id": "MDc6UmVsZWFzZTEyMDgwMDM2", "tag_name": "0.24", "target_commitish": "main", "name": "Datasette 0.24", "draft": 0, "author": {"value": 9599, "label": "simonw"}, "prerelease": 0, "created_at": "2018-07-24T04:34:38Z", "published_at": "2018-07-24T16:51:29Z", "body": "See full release notes here: http://datasette.readthedocs.io/en/latest/changelog.html#v0-24\r\n", "repo": {"value": 107914493, "label": "datasette"}, "reactions": null} {"html_url": "https://github.com/simonw/datasette/releases/tag/0.23.2", "id": 11825600, "node_id": "MDc6UmVsZWFzZTExODI1NjAw", "tag_name": "0.23.2", "target_commitish": "main", "name": "Datasette 0.23.2", "draft": 0, "author": {"value": 9599, "label": "simonw"}, "prerelease": 0, "created_at": "2018-07-08T05:28:45Z", "published_at": "2018-07-08T05:41:38Z", "body": "Minor bugfix and documentation release.\r\n\r\n* CSV export now respects `--cors`, fixes #326\r\n* [Installation instructions](https://datasette.readthedocs.io/en/latest/installation.html) including docker image - closes #328\r\n* Fix for row pages for tables with / in, closes #325", "repo": {"value": 107914493, "label": "datasette"}, "reactions": null} {"html_url": "https://github.com/simonw/datasette/releases/tag/0.23.1", "id": 11591352, "node_id": "MDc6UmVsZWFzZTExNTkxMzUy", "tag_name": "0.23.1", "target_commitish": "main", "name": "Datasette 0.23.1", "draft": 0, "author": {"value": 9599, "label": "simonw"}, "prerelease": 0, "created_at": "2018-06-21T15:37:13Z", "published_at": "2018-06-21T16:02:44Z", "body": "Minor bugfix release.\r\n\r\n* Correctly display empty strings in HTML table, closes #314\r\n* Allow \u201c.\u201d in database filenames, closes #302\r\n* 404s ending in slash redirect to remove that slash, closes #309\r\n* Fixed incorrect display of compound primary keys with foreign key references. Closes #319\r\n* Docs + example of canned SQL query using || concatenation. Closes #321\r\n* Correctly display facets with value of 0 - closes #318\r\n* Default \u2018expand labels\u2019 to checked in CSV advanced export\r\n", "repo": {"value": 107914493, "label": "datasette"}, "reactions": null} {"html_url": "https://github.com/simonw/datasette/releases/tag/0.23", "id": 11530498, "node_id": "MDc6UmVsZWFzZTExNTMwNDk4", "tag_name": "0.23", "target_commitish": "main", "name": "Datasette 0.23: CSV, SpatiaLite and more", "draft": 0, "author": {"value": 9599, "label": "simonw"}, "prerelease": 0, "created_at": "2018-06-18T15:11:57Z", "published_at": "2018-06-18T15:28:37Z", "body": "This release features CSV export, improved options for foreign key expansions, new configuration settings and improved support for SpatiaLite.\r\n\r\nSee full release notes here: http://datasette.readthedocs.io/en/latest/changelog.html#v0-23", "repo": {"value": 107914493, "label": "datasette"}, "reactions": null} {"html_url": "https://github.com/simonw/datasette/releases/tag/0.22.1", "id": 11136605, "node_id": "MDc6UmVsZWFzZTExMTM2NjA1", "tag_name": "0.22.1", "target_commitish": "main", "name": "Datasette 0.22.1", "draft": 0, "author": {"value": 9599, "label": "simonw"}, "prerelease": 0, "created_at": "2018-05-23T14:00:01Z", "published_at": "2018-05-23T14:04:17Z", "body": "Bugfix release, plus we now use [versioneer](https://github.com/warner/python-versioneer) for our version numbers.\r\n\r\n- Faceting no longer breaks pagination, fixes #282\r\n- Add ``__version_info__`` derived from `__version__` [Robert Gieseke]\r\n\r\n This might be tuple of more than two values (major and minor\r\n version) if commits have been made after a release.\r\n- Add version number support with Versioneer. [Robert Gieseke]\r\n\r\n Versioneer Licence:\r\n Public Domain (CC0-1.0)\r\n\r\n Closes #273\r\n- Refactor inspect logic [Russ Garrett]", "repo": {"value": 107914493, "label": "datasette"}, "reactions": null} {"html_url": "https://github.com/simonw/datasette/releases/tag/0.22", "id": 11087850, "node_id": "MDc6UmVsZWFzZTExMDg3ODUw", "tag_name": "0.22", "target_commitish": "main", "name": "Datasette 0.22: Datasette Facets", "draft": 0, "author": {"value": 9599, "label": "simonw"}, "prerelease": 0, "created_at": "2018-05-20T23:41:47Z", "published_at": "2018-05-20T23:44:19Z", "body": "The big new feature in this release is [facets](http://datasette.readthedocs.io/en/latest/facets.html). Datasette can now apply faceted browse to any column in any table. It will also suggest possible facets. See the [Datasette Facets](https://simonwillison.net/2018/May/20/datasette-facets/) announcement post for more details.\r\n\r\nIn addition to the work on facets:\r\n\r\n- Added [docs for introspection endpoints](https://datasette.readthedocs.io/en/latest/introspection.html)\r\n\r\n- New `--config` option, added `--help-config`, closes #274\r\n\r\n Removed the `--page_size=` argument to `datasette serve` in favour of:\r\n\r\n datasette serve --config default_page_size:50 mydb.db\r\n\r\n Added new help section:\r\n\r\n $ datasette --help-config\r\n Config options:\r\n default_page_size Default page size for the table view\r\n (default=100)\r\n max_returned_rows Maximum rows that can be returned from a table\r\n or custom query (default=1000)\r\n sql_time_limit_ms Time limit for a SQL query in milliseconds\r\n (default=1000)\r\n default_facet_size Number of values to return for requested facets\r\n (default=30)\r\n facet_time_limit_ms Time limit for calculating a requested facet\r\n (default=200)\r\n facet_suggest_time_limit_ms Time limit for calculating a suggested facet\r\n (default=50)\r\n- Only apply responsive table styles to `.rows-and-column`\r\n\r\n Otherwise they interfere with tables in the description, e.g. on\r\n https://fivethirtyeight.datasettes.com/fivethirtyeight/nba-elo%2Fnbaallelo\r\n\r\n- Refactored views into new `views/` modules, refs #256\r\n- [Documentation for SQLite full-text search](http://datasette.readthedocs.io/en/latest/full_text_search.html) support, closes #253\r\n- `/-/versions` now includes SQLite `fts_versions`, closes #252", "repo": {"value": 107914493, "label": "datasette"}, "reactions": null} {"html_url": "https://github.com/simonw/datasette/releases/tag/0.21", "id": 10868113, "node_id": "MDc6UmVsZWFzZTEwODY4MTEz", "tag_name": "0.21", "target_commitish": "main", "name": "Datasette 0.21: New _shape=, new _size=, search within columns", "draft": 0, "author": {"value": 9599, "label": "simonw"}, "prerelease": 0, "created_at": "2018-05-05T23:15:38Z", "published_at": "2018-05-05T23:21:33Z", "body": "New JSON `_shape=` options, the ability to set table `_size=` and a mechanism for searching within specific columns.\r\n\r\n - Default tests to using a longer timelimit\r\n \r\n Every now and then a test will fail in Travis CI on Python 3.5 because it hit the default 20ms SQL time limit.\r\n \r\n Test fixtures now default to a 200ms time limit, and we only use the 20ms time limit for the specific test that tests query interruption.\r\n\r\n This should make our tests on Python 3.5 in Travis much more stable.\r\n\r\n - Support `_search_COLUMN=text` searches, closes [\\#237](https://github.com/simonw/datasette/issues/237)\r\n\r\n - Show version on `/-/plugins` page, closes [\\#248](https://github.com/simonw/datasette/issues/248)\r\n\r\n - `?_size=max` option, closes [\\#249](https://github.com/simonw/datasette/issues/249)\r\n\r\n - Added `/-/versions` and `/-/versions.json`, closes [\\#244](https://github.com/simonw/datasette/issues/244)\r\n \r\n Sample output:\r\n \r\n {\r\n \"python\": {\r\n \"version\": \"3.6.3\",\r\n \"full\": \"3.6.3 (default, Oct 4 2017, 06:09:38) \\n[GCC 4.2.1 Compatible Apple LLVM 9.0.0 (clang-900.0.37)]\"\r\n },\r\n \"datasette\": {\r\n \"version\": \"0.20\"\r\n },\r\n \"sqlite\": {\r\n \"version\": \"3.23.1\",\r\n \"extensions\": {\r\n \"json1\": null,\r\n \"spatialite\": \"4.3.0a\"\r\n }\r\n }\r\n }\r\n\r\n - Renamed `?_sql_time_limit_ms=` to `?_timelimit`, closes [\\#242](https://github.com/simonw/datasette/issues/242)\r\n\r\n - New `?_shape=array` option + tweaks to `_shape`, closes [\\#245](https://github.com/simonw/datasette/issues/245)\r\n \r\n - Default is now `?_shape=arrays` (renamed from `lists`)\r\n - New `?_shape=array` returns an array of objects as the root object\r\n - Changed `?_shape=object` to return the object as the root\r\n - Updated docs\r\n\r\n - FTS tables now detected by `inspect()`, closes [\\#240](https://github.com/simonw/datasette/issues/240)\r\n\r\n - New `?_size=XXX` querystring parameter for table view, closes [\\#229](https://github.com/simonw/datasette/issues/229)\r\n \r\n Also added documentation for all of the `_special` arguments.\r\n \r\n Plus deleted some duplicate logic implementing `_group_count`.\r\n\r\n - If `max_returned_rows==page_size`, increment `max_returned_rows` - fixes [\\#230](https://github.com/simonw/datasette/issues/230)\r\n\r\n - New `hidden: True` option for table metadata, closes [\\#239](https://github.com/simonw/datasette/issues/239)\r\n\r\n - Hide `idx_*` tables if spatialite detected, closes [\\#228](https://github.com/simonw/datasette/issues/228)\r\n\r\n - Added `class=rows-and-columns` to custom query results table\r\n\r\n - Added CSS class `rows-and-columns` to main table\r\n\r\n - `label_column` option in `metadata.json` - closes [\\#234](https://github.com/simonw/datasette/issues/234)", "repo": {"value": 107914493, "label": "datasette"}, "reactions": null} {"html_url": "https://github.com/simonw/datasette/releases/tag/0.20", "id": 10645022, "node_id": "MDc6UmVsZWFzZTEwNjQ1MDIy", "tag_name": "0.20", "target_commitish": "main", "name": "Datasette 0.20: static assets and templates for plugins", "draft": 0, "author": {"value": 9599, "label": "simonw"}, "prerelease": 0, "created_at": "2018-04-20T14:36:29Z", "published_at": "2018-04-20T14:41:14Z", "body": "Mostly new work on the [Plugins](http://datasette.readthedocs.io/en/latest/plugins.html) mechanism: plugins can now bundle static assets and custom templates, and ``datasette publish`` has a new ``--install=name-of-plugin`` option.\r\n\r\n- Add col-X classes to HTML table on custom query page\r\n- Fixed out-dated template in documentation\r\n- Plugins can now bundle custom templates, #224\r\n- Added /-/metadata /-/plugins /-/inspect, #225\r\n- Documentation for --install option, refs #223\r\n- Datasette publish/package --install option, #223\r\n- Fix for plugins in Python 3.5, #222\r\n- New plugin hooks: extra_css_urls() and extra_js_urls(), #214\r\n- /-/static-plugins/PLUGIN_NAME/ now serves static/ from plugins\r\n-
This line renders the original block:
\r\n {{ super() }}\r\n {% endblock %}\r\n\r\n - `--static` option for datasette serve ([\\#160](https://github.com/simonw/datasette/issues/160))\r\n \r\n You can now tell Datasette to serve static files from a specific location at a specific mountpoint.\r\n \r\n For example:\r\n \r\n datasette serve mydb.db --static extra-css:/tmp/static/css\r\n \r\n Now if you visit this URL:\r\n \r\n http://localhost:8001/extra-css/blah.css\r\n \r\n The following file will be served:\r\n \r\n /tmp/static/css/blah.css\r\n\r\n - Canned query support.\r\n \r\n Named canned queries can now be defined in `metadata.json` like this:\r\n \r\n {\r\n \"databases\": {\r\n \"timezones\": {\r\n \"queries\": {\r\n \"timezone_for_point\": \"select tzid from timezones ...\"\r\n }\r\n }\r\n }\r\n }\r\n \r\n These will be shown in a new \"Queries\" section beneath \"Views\" on the database page.\r\n\r\n - New `datasette skeleton` command for generating `metadata.json` ([\\#164](https://github.com/simonw/datasette/issues/164))\r\n\r\n - `metadata.json` support for per-table/per-database metadata ([\\#165](https://github.com/simonw/datasette/issues/165))\r\n \r\n Also added support for descriptions and HTML descriptions.\r\n \r\n Here's an example metadata.json file illustrating custom per-database and per-table metadata:\r\n \r\n {\r\n \"title\": \"Overall datasette title\",\r\n \"description_html\": \"This is a description with HTML.\",\r\n \"databases\": {\r\n \"db1\": {\r\n \"title\": \"First database\",\r\n \"description\": \"This is a string description & has no HTML\",\r\n \"license_url\": \"http://example.com/\",\r\n \"license\": \"The example license\",\r\n \"queries\": {\r\n \"canned_query\": \"select * from table1 limit 3;\"\r\n },\r\n \"tables\": {\r\n \"table1\": {\r\n \"title\": \"Custom title for table1\",\r\n \"description\": \"Tables can have descriptions too\",\r\n \"source\": \"This has a custom source\",\r\n \"source_url\": \"http://example.com/\"\r\n }\r\n }\r\n }\r\n }\r\n }\r\n\r\n - Renamed `datasette build` command to `datasette inspect` ([\\#130](https://github.com/simonw/datasette/issues/130))\r\n\r\n - Upgrade to Sanic 0.7.0 ([\\#168](https://github.com/simonw/datasette/issues/168))\r\n \r\n