issue_comments
24 rows where author_association = "OWNER" and "created_at" is on date 2022-02-02 sorted by updated_at descending
This data as json, CSV (advanced)
Suggested facets: issue_url, created_at (date)
user 1
- simonw 24
id | html_url | issue_url | node_id | user | created_at | updated_at ▲ | author_association | body | reactions | issue | performed_via_github_app |
---|---|---|---|---|---|---|---|---|---|---|---|
1028461220 | https://github.com/simonw/datasette/issues/1534#issuecomment-1028461220 | https://api.github.com/repos/simonw/datasette/issues/1534 | IC_kwDOBm6k_c49TRKk | simonw 9599 | 2022-02-02T23:39:33Z | 2022-02-02T23:39:33Z | OWNER | I've decided not to do this, because of the risk that Cloudflare could cache the JSON version for an HTML page or vice-versa. |
{ "total_count": 0, "+1": 0, "-1": 0, "laugh": 0, "hooray": 0, "confused": 0, "heart": 0, "rocket": 0, "eyes": 0 } |
Maybe return JSON from HTML pages if `Accept: application/json` is sent 1065432388 | |
1028420821 | https://github.com/simonw/datasette/pull/1626#issuecomment-1028420821 | https://api.github.com/repos/simonw/datasette/issues/1626 | IC_kwDOBm6k_c49THTV | simonw 9599 | 2022-02-02T22:32:26Z | 2022-02-02T22:33:31Z | OWNER | That broke on a macOS test: https://github.com/simonw/datasette/runs/5044036993?check_suite_focus=true I'm going to remove macOS and Ubuntu and just try Windows purely to see what happens there. |
{ "total_count": 0, "+1": 0, "-1": 0, "laugh": 0, "hooray": 0, "confused": 0, "heart": 0, "rocket": 0, "eyes": 0 } |
Try test suite against macOS and Windows 1122451096 | |
1028414871 | https://github.com/simonw/datasette/pull/1616#issuecomment-1028414871 | https://api.github.com/repos/simonw/datasette/issues/1616 | IC_kwDOBm6k_c49TF2X | simonw 9599 | 2022-02-02T22:23:45Z | 2022-02-02T22:23:45Z | OWNER | First stable Black release! |
{ "total_count": 0, "+1": 0, "-1": 0, "laugh": 0, "hooray": 0, "confused": 0, "heart": 0, "rocket": 0, "eyes": 0 } |
Bump black from 21.12b0 to 22.1.0 1119413338 | |
1028397935 | https://github.com/simonw/datasette/issues/1623#issuecomment-1028397935 | https://api.github.com/repos/simonw/datasette/issues/1623 | IC_kwDOBm6k_c49TBtv | simonw 9599 | 2022-02-02T21:59:43Z | 2022-02-02T21:59:43Z | OWNER | { "total_count": 0, "+1": 0, "-1": 0, "laugh": 0, "hooray": 0, "confused": 0, "heart": 0, "rocket": 0, "eyes": 0 } |
/-/patterns returns link: alternate JSON header to 404 1122416919 | ||
1028396866 | https://github.com/simonw/datasette/issues/1624#issuecomment-1028396866 | https://api.github.com/repos/simonw/datasette/issues/1624 | IC_kwDOBm6k_c49TBdC | simonw 9599 | 2022-02-02T21:58:06Z | 2022-02-02T21:58:06Z | OWNER | It looks like this is because Another thing I should address with the refactor project in: - #878 |
{ "total_count": 0, "+1": 0, "-1": 0, "laugh": 0, "hooray": 0, "confused": 0, "heart": 0, "rocket": 0, "eyes": 0 } |
Index page `/` has no CORS headers 1122427321 | |
1028393259 | https://github.com/simonw/datasette/issues/1620#issuecomment-1028393259 | https://api.github.com/repos/simonw/datasette/issues/1620 | IC_kwDOBm6k_c49TAkr | simonw 9599 | 2022-02-02T21:53:02Z | 2022-02-02T21:53:02Z | OWNER | I ran the following on https://www.google.com/ in the console to demonstrate that these work as intended:
|
{ "total_count": 0, "+1": 0, "-1": 0, "laugh": 0, "hooray": 0, "confused": 0, "heart": 0, "rocket": 0, "eyes": 0 } |
Link: rel="alternate" to JSON for queries too 1121618041 | |
1028389953 | https://github.com/simonw/datasette/issues/1623#issuecomment-1028389953 | https://api.github.com/repos/simonw/datasette/issues/1623 | IC_kwDOBm6k_c49S_xB | simonw 9599 | 2022-02-02T21:48:34Z | 2022-02-02T21:48:34Z | OWNER | A few other pages do that too, including: - https://latest.datasette.io/-/messages - https://latest.datasette.io/-/allow-debug |
{ "total_count": 0, "+1": 0, "-1": 0, "laugh": 0, "hooray": 0, "confused": 0, "heart": 0, "rocket": 0, "eyes": 0 } |
/-/patterns returns link: alternate JSON header to 404 1122416919 | |
1028385067 | https://github.com/simonw/datasette/issues/1620#issuecomment-1028385067 | https://api.github.com/repos/simonw/datasette/issues/1620 | IC_kwDOBm6k_c49S-kr | simonw 9599 | 2022-02-02T21:42:23Z | 2022-02-02T21:42:23Z | OWNER |
|
{ "total_count": 0, "+1": 0, "-1": 0, "laugh": 0, "hooray": 0, "confused": 0, "heart": 0, "rocket": 0, "eyes": 0 } |
Link: rel="alternate" to JSON for queries too 1121618041 | |
1028374330 | https://github.com/simonw/datasette/issues/1620#issuecomment-1028374330 | https://api.github.com/repos/simonw/datasette/issues/1620 | IC_kwDOBm6k_c49S786 | simonw 9599 | 2022-02-02T21:28:16Z | 2022-02-02T21:28:16Z | OWNER | I just realized I can refactor this to make it much simpler. |
{ "total_count": 0, "+1": 0, "-1": 0, "laugh": 0, "hooray": 0, "confused": 0, "heart": 0, "rocket": 0, "eyes": 0 } |
Link: rel="alternate" to JSON for queries too 1121618041 | |
1027672617 | https://github.com/simonw/datasette/issues/1533#issuecomment-1027672617 | https://api.github.com/repos/simonw/datasette/issues/1533 | IC_kwDOBm6k_c49QQop | simonw 9599 | 2022-02-02T07:56:51Z | 2022-02-02T07:56:51Z | OWNER | Demos - these pages both have And you can hit them with % curl -I 'https://latest.datasette.io/fixtures/sortable/a,a' HTTP/1.1 200 OK link: https://latest.datasette.io/fixtures/sortable/a,a.json; rel="alternate"; type="application/json+datasette" cache-control: max-age=5 referrer-policy: no-referrer access-control-allow-origin: * access-control-allow-headers: Authorization access-control-expose-headers: Link content-type: text/html; charset=utf-8 x-databases: _memory, _internal, fixtures, extra_database Date: Wed, 02 Feb 2022 07:56:24 GMT Server: Google Frontend Transfer-Encoding: chunked ``` |
{ "total_count": 0, "+1": 0, "-1": 0, "laugh": 0, "hooray": 0, "confused": 0, "heart": 0, "rocket": 0, "eyes": 0 } |
Add `Link: rel="alternate"` header pointing to JSON for a table/query 1065431383 | |
1027669851 | https://github.com/simonw/datasette/issues/1533#issuecomment-1027669851 | https://api.github.com/repos/simonw/datasette/issues/1533 | IC_kwDOBm6k_c49QP9b | simonw 9599 | 2022-02-02T07:51:57Z | 2022-02-02T07:51:57Z | OWNER | Documentation: https://docs.datasette.io/en/latest/json_api.html#discovering-the-json-for-a-page https://docs.datasette.io/en/latest/json_api.html top |
{ "total_count": 0, "+1": 0, "-1": 0, "laugh": 0, "hooray": 0, "confused": 0, "heart": 0, "rocket": 0, "eyes": 0 } |
Add `Link: rel="alternate"` header pointing to JSON for a table/query 1065431383 | |
1027659890 | https://github.com/simonw/datasette/issues/1615#issuecomment-1027659890 | https://api.github.com/repos/simonw/datasette/issues/1615 | IC_kwDOBm6k_c49QNhy | simonw 9599 | 2022-02-02T07:34:17Z | 2022-02-02T07:34:17Z | OWNER | I've been thinking about this a bunch too. If I build anything along these lines it will be as part of the Datasette Cloud hosted service I'm working on, maybe as a free tier. |
{ "total_count": 0, "+1": 0, "-1": 0, "laugh": 0, "hooray": 0, "confused": 0, "heart": 0, "rocket": 0, "eyes": 0 } |
Potential simplified publishing mechanism 1117132741 | |
1027659018 | https://github.com/simonw/datasette/issues/1618#issuecomment-1027659018 | https://api.github.com/repos/simonw/datasette/issues/1618 | IC_kwDOBm6k_c49QNUK | simonw 9599 | 2022-02-02T07:32:47Z | 2022-02-02T07:32:47Z | OWNER | I was hoping that
``` |
{ "total_count": 0, "+1": 0, "-1": 0, "laugh": 0, "hooray": 0, "confused": 0, "heart": 0, "rocket": 0, "eyes": 0 } |
Reconsider policy on blocking queries containing the string "pragma" 1121121305 | |
1027656518 | https://github.com/simonw/datasette/issues/1618#issuecomment-1027656518 | https://api.github.com/repos/simonw/datasette/issues/1618 | IC_kwDOBm6k_c49QMtG | simonw 9599 | 2022-02-02T07:28:14Z | 2022-02-02T07:31:30Z | OWNER | I also need to consider if supposedly harmless side-effect free pragma functions could be used to work around the Datasette permissions system. My hunch is that wouldn't be a problem, because if you're allowing arbitrary SQL queries you're already letting people ignore the permissions system. One example: ``` sqlite-utils fixtures.db 'pragma database_list' -t seq name file
``` Though it looks like I already allow-listed that one in #761: https://latest.datasette.io/_memory?sql=select+*+from+pragma_database_list%28%29 |
{ "total_count": 0, "+1": 0, "-1": 0, "laugh": 0, "hooray": 0, "confused": 0, "heart": 0, "rocket": 0, "eyes": 0 } |
Reconsider policy on blocking queries containing the string "pragma" 1121121305 | |
1027656000 | https://github.com/simonw/datasette/issues/1618#issuecomment-1027656000 | https://api.github.com/repos/simonw/datasette/issues/1618 | IC_kwDOBm6k_c49QMlA | simonw 9599 | 2022-02-02T07:27:14Z | 2022-02-02T07:27:14Z | OWNER | I also just realized that
| name | |---------------------------| | analysis_limit | | application_id | | auto_vacuum | | automatic_index | | busy_timeout | | cache_size | | cache_spill | | case_sensitive_like | | cell_size_check | | checkpoint_fullfsync | | collation_list | | compile_options | | count_changes | | data_version | | database_list | | default_cache_size | | defer_foreign_keys | | empty_result_callbacks | | encoding | | foreign_key_check | | foreign_key_list | | foreign_keys | | freelist_count | | full_column_names | | fullfsync | | function_list | | hard_heap_limit | | ignore_check_constraints | | incremental_vacuum | | index_info | | index_list | | index_xinfo | | integrity_check | | journal_mode | | journal_size_limit | | legacy_alter_table | | lock_proxy_file | | locking_mode | | max_page_count | | mmap_size | | module_list | | optimize | | page_count | | page_size | | pragma_list | | query_only | | quick_check | | read_uncommitted | | recursive_triggers | | reverse_unordered_selects | | schema_version | | secure_delete | | short_column_names | | shrink_memory | | soft_heap_limit | | synchronous | | table_info | | table_list | | table_xinfo | | temp_store | | temp_store_directory | | threads | | trusted_schema | | user_version | | wal_autocheckpoint | | wal_checkpoint | | writable_schema | So I could use that list to create a much more specific regular expression, which would then allow the word "pragma" to be used more freely while still protecting against any known pragma function being called. |
{ "total_count": 0, "+1": 0, "-1": 0, "laugh": 0, "hooray": 0, "confused": 0, "heart": 0, "rocket": 0, "eyes": 0 } |
Reconsider policy on blocking queries containing the string "pragma" 1121121305 | |
1027654979 | https://github.com/simonw/datasette/issues/1618#issuecomment-1027654979 | https://api.github.com/repos/simonw/datasette/issues/1618 | IC_kwDOBm6k_c49QMVD | simonw 9599 | 2022-02-02T07:25:22Z | 2022-02-02T07:25:22Z | OWNER | But... I just noticed something I had missed in the docs for https://www.sqlite.org/pragma.html#pragfunc
So it's possible I'm being overly paranoid here after all: what I want to block here is people running things like So maybe I should allow all pragma functions. I previously allowed an allow-list of them in: - #761 |
{ "total_count": 0, "+1": 0, "-1": 0, "laugh": 0, "hooray": 0, "confused": 0, "heart": 0, "rocket": 0, "eyes": 0 } |
Reconsider policy on blocking queries containing the string "pragma" 1121121305 | |
1027653005 | https://github.com/simonw/datasette/issues/1618#issuecomment-1027653005 | https://api.github.com/repos/simonw/datasette/issues/1618 | IC_kwDOBm6k_c49QL2N | simonw 9599 | 2022-02-02T07:22:13Z | 2022-02-02T07:22:13Z | OWNER | There's a workaround for this at the moment, which is to use parameterized SQL queries. For example, this: So the SQL query is The reason behind the quite aggressive pragma filtering is that SQLite allows you to execute pragmas using function calls, like this one:
I'm open to relaxing the regex a bit, but I need to be very confident that it's safe to do so. |
{ "total_count": 0, "+1": 0, "-1": 0, "laugh": 0, "hooray": 0, "confused": 0, "heart": 0, "rocket": 0, "eyes": 0 } |
Reconsider policy on blocking queries containing the string "pragma" 1121121305 | |
1027648180 | https://github.com/simonw/datasette/issues/1586#issuecomment-1027648180 | https://api.github.com/repos/simonw/datasette/issues/1586 | IC_kwDOBm6k_c49QKq0 | simonw 9599 | 2022-02-02T07:13:31Z | 2022-02-02T07:13:31Z | OWNER | Running it as part of But there's no reason for that expectation to exist, and I doubt anyone is relying on that. |
{ "total_count": 0, "+1": 0, "-1": 0, "laugh": 0, "hooray": 0, "confused": 0, "heart": 0, "rocket": 0, "eyes": 0 } |
run analyze on all databases as part of start up or publishing 1096536240 | |
1027647257 | https://github.com/simonw/datasette/issues/1619#issuecomment-1027647257 | https://api.github.com/repos/simonw/datasette/issues/1619 | IC_kwDOBm6k_c49QKcZ | simonw 9599 | 2022-02-02T07:11:43Z | 2022-02-02T07:11:43Z | OWNER | Weirdly the bug does NOT exhibit itself on this demo: https://datasette-apache-proxy-demo.datasette.io/prefix/fixtures/no_primary_key/1 - which correctly links to https://datasette-apache-proxy-demo.datasette.io/prefix/fixtures/no_primary_key/1.json |
{ "total_count": 0, "+1": 0, "-1": 0, "laugh": 0, "hooray": 0, "confused": 0, "heart": 0, "rocket": 0, "eyes": 0 } |
JSON link on row page is 404 if base_url setting is used 1121583414 | |
1027646659 | https://github.com/simonw/datasette/issues/1619#issuecomment-1027646659 | https://api.github.com/repos/simonw/datasette/issues/1619 | IC_kwDOBm6k_c49QKTD | simonw 9599 | 2022-02-02T07:10:37Z | 2022-02-02T07:10:37Z | OWNER | It's not just the table with slashes in the name. Same thing on http://127.0.0.1:3344/foo/bar/fixtures/attraction_characteristic/1 - the |
{ "total_count": 0, "+1": 0, "-1": 0, "laugh": 0, "hooray": 0, "confused": 0, "heart": 0, "rocket": 0, "eyes": 0 } |
JSON link on row page is 404 if base_url setting is used 1121583414 | |
1027635925 | https://github.com/simonw/datasette/issues/1576#issuecomment-1027635925 | https://api.github.com/repos/simonw/datasette/issues/1576 | IC_kwDOBm6k_c49QHrV | simonw 9599 | 2022-02-02T06:47:20Z | 2022-02-02T06:47:20Z | OWNER | Here's what I was hacking around with when I uncovered this problem: ```diff diff --git a/datasette/views/table.py b/datasette/views/table.py index 77fb285..8c57d08 100644 --- a/datasette/views/table.py +++ b/datasette/views/table.py @@ -1,3 +1,4 @@ +import asyncio import urllib import itertools import json @@ -615,44 +616,37 @@ class TableView(RowTableShared): if request.args.get("_timelimit"): extra_args["custom_time_limit"] = int(request.args.get("_timelimit"))
|
{ "total_count": 0, "+1": 0, "-1": 0, "laugh": 0, "hooray": 0, "confused": 0, "heart": 0, "rocket": 0, "eyes": 0 } |
Traces should include SQL executed by subtasks created with `asyncio.gather` 1087181951 | |
1027635175 | https://github.com/simonw/datasette/issues/1611#issuecomment-1027635175 | https://api.github.com/repos/simonw/datasette/issues/1611 | IC_kwDOBm6k_c49QHfn | simonw 9599 | 2022-02-02T06:45:47Z | 2022-02-02T06:45:47Z | OWNER | Prototype, not sure that this actually works yet:
|
{ "total_count": 0, "+1": 0, "-1": 0, "laugh": 0, "hooray": 0, "confused": 0, "heart": 0, "rocket": 0, "eyes": 0 } |
Avoid ever running count(*) against SpatiaLite KNN table 1113384383 | |
1027634490 | https://github.com/simonw/datasette/issues/1607#issuecomment-1027634490 | https://api.github.com/repos/simonw/datasette/issues/1607 | IC_kwDOBm6k_c49QHU6 | simonw 9599 | 2022-02-02T06:44:30Z | 2022-02-02T06:44:30Z | OWNER | Prototype:
|
{ "total_count": 0, "+1": 0, "-1": 0, "laugh": 0, "hooray": 0, "confused": 0, "heart": 0, "rocket": 0, "eyes": 0 } |
More detailed information about installed SpatiaLite version 1109783030 | |
1027633686 | https://github.com/simonw/datasette/issues/1533#issuecomment-1027633686 | https://api.github.com/repos/simonw/datasette/issues/1533 | IC_kwDOBm6k_c49QHIW | simonw 9599 | 2022-02-02T06:42:53Z | 2022-02-02T06:42:53Z | OWNER | I'm going to apply the hack, then fix it again in: - #1518 |
{ "total_count": 0, "+1": 0, "-1": 0, "laugh": 0, "hooray": 0, "confused": 0, "heart": 0, "rocket": 0, "eyes": 0 } |
Add `Link: rel="alternate"` header pointing to JSON for a table/query 1065431383 |
Advanced export
JSON shape: default, array, newline-delimited, object
CREATE TABLE [issue_comments] ( [html_url] TEXT, [issue_url] TEXT, [id] INTEGER PRIMARY KEY, [node_id] TEXT, [user] INTEGER REFERENCES [users]([id]), [created_at] TEXT, [updated_at] TEXT, [author_association] TEXT, [body] TEXT, [reactions] TEXT, [issue] INTEGER REFERENCES [issues]([id]) , [performed_via_github_app] TEXT); CREATE INDEX [idx_issue_comments_issue] ON [issue_comments] ([issue]); CREATE INDEX [idx_issue_comments_user] ON [issue_comments] ([user]);
issue 14