-
-
Notifications
You must be signed in to change notification settings - Fork 192
New issue
Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.
By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.
Already on GitHub? Sign in to your account
PostgREST Dart Client - new payload in _getStreamData on 'UPDATE' missing column #627
Comments
The bug I am experiencing is this... I open a stream for the This correctly includes the Then, another value gets emitted on the stream for the table. This time, the I have no evidence that the update affects the stream's second emitted value. But it's odd that the incorrect value on the stream happens after the update has an exception. |
One piece of information is the resume column is a text column and quite long. Perhaps the server is deciding not to send the column to avoid bandwidth use. |
This is the {
"data": {
"columns": [
{
"name": "id",
"type": "varchar"
},
{
"name": "resume",
"type": "text"
},
{
"name": "embedding",
"type": "vector"
},
{
"name": "minsalaryperday",
"type": "int4"
},
{
"name": "minsalaryperyear",
"type": "int4"
},
{
"name": "locationtext",
"type": "varchar"
},
{
"name": "location",
"type": "geography"
},
{
"name": "preferredworktypes",
"type": "_text"
},
{
"name": "preferredcommutetypes",
"type": "_text"
}
],
"commit_timestamp": "2023-09-16T04:25:21.598Z",
"errors": null,
"old_record": {
"id": "c315090a-0cca-4f07-adfa-78c6fe433f2a"
},
"record": {
"embedding": null,
"id": "c315090a-0cca-4f07-adfa-78c6fe433f2a",
"location": "",
"locationtext": "Melbourne",
"minsalaryperday": 156,
"minsalaryperyear": 1003,
"preferredcommutetypes": [
"nonMandated"
],
"preferredworktypes": [
"permanent"
]
},
"schema": "public",
"table": "profiles",
"type": "UPDATE"
},
"ids": [
109688006,
12391632,
13182892
]
} |
And when I explicitly update the resume column, it does send the resume column: {
"data": {
"columns": [
{
"name": "id",
"type": "varchar"
},
{
"name": "resume",
"type": "text"
},
{
"name": "embedding",
"type": "vector"
},
{
"name": "minsalaryperday",
"type": "int4"
},
{
"name": "minsalaryperyear",
"type": "int4"
},
{
"name": "locationtext",
"type": "varchar"
},
{
"name": "location",
"type": "geography"
},
{
"name": "preferredworktypes",
"type": "_text"
},
{
"name": "preferredcommutetypes",
"type": "_text"
}
],
"commit_timestamp": "2023-09-16T04:31:13.660Z",
"errors": null,
"old_record": {
"id": "c315090a-0cca-4f07-adfa-78c6fe433f2a"
},
"record": {
"embedding": null,
"id": "c315090a-0cca-4f07-adfa-78c6fe433f2a",
"location": "",
"locationtext": "Melbourne",
"minsalaryperday": 156,
"minsalaryperyear": 1003,
"preferredcommutetypes": [
"hybrid"
],
"preferredworktypes": [
"contract"
],
"resume": "dfsdfsdf"
},
"schema": "public",
"table": "profiles",
"type": "UPDATE"
},
"ids": [
109688006,
12391632,
13182892
]
} Now that I understand more about this, I'm left wondering why Supabase sends the full record at all... Why doesn't Supabase only send the updated columns? Perhaps I might want to know what the full record is, but I can calculate that myself. I'm really only interested in the changed values and streaming the rest eats bandwidth. |
Lastly, I made a change in a couple of libraries to listen to incoming data from Supabase. You can see the changes here: Is it worth cleaning this up and submitting it as a PR? main...MelbourneDeveloper:supabase-flutter:main Here is the example usage: supabase.client.from(table).stream(
primaryKey: ['id'],
onTrigger: (
type, [
payload,
ref,
]) {
final json = jsonEncode(payload);
// ignore: avoid_print
print(json);
},
).eq(column, value); This is the JSON output that gets printed to the console. It's very useful for debugging what is coming in from Supabase |
It's a bit hard to follow your issue, because you are mentioning many different aspects. Please delete anything related to the http package when you already know now that it's not the reason. So what exactly is your issue now? When updating a column other than the |
As I said, the resume column is missing in the second payload. The quotas documentation might explain the issue. Let me confirm that.
Lastly, I added a feature in my fork.
main...MelbourneDeveloper:supabase-flutter:main
Take a look at that because I can clean that up for a PR. Let me know if you want me to rename it or change it.
…________________________________
From: Vinzent ***@***.***>
Sent: Saturday, September 16, 2023 11:34:48 PM
To: supabase/supabase-flutter ***@***.***>
Cc: Christian Findlay ***@***.***>; Author ***@***.***>
Subject: Re: [supabase/supabase-flutter] PostgREST Dart Client - new payload in _getStreamData on 'UPDATE' missing column (Issue #627)
It's a bit hard to follow your issue, because you are mentioning many different aspects. Please delete anything related to the http package when you already know now that it's not the reason.
So what exactly is your issue now? When updating a column other than the resume column in a row, the resume column is missing in the payload. But when updating the resume column, it is present in the payload?
Have you read the quotas documentation<https://supabase.com/docs/guides/realtime/quotas>?
—
Reply to this email directly, view it on GitHub<#627 (comment)>, or unsubscribe<https://github.com/notifications/unsubscribe-auth/AD7MRS5NIZXVBEOT4K2T2A3X2WTHRANCNFSM6AAAAAA42QODTA>.
You are receiving this because you authored the thread.Message ID: ***@***.***>
|
The other bug mentioned in the first comment is that the |
I suspect that the issue may be quota-related. The payload removes the However, the documentation says I will see the error in the backend logs and the client-side websocket logs. I don't see anything in the server-side logs: I don't see anything on the client-side web socket logs when I write up to print all the incoming payloads. This is a log of all the incoming payloads. I don't see any errors here: |
@Vinzent03 please see the edited issue at the top |
@w3b6x9 Are you the correct person to be tagged for the above comment ? Will fix the format exception issue. |
@MelbourneDeveloper For your issue 1 about the missing column, would you be able to open an issue in the walrus repo providing (if possible) your table schema and how long your For issue 2, @Vinzent03 has created an amazing fix for it, which we plan to ship in the next 24 hours. Lastly about the question of whether to finalize the exposing raw web socket messages PR or not, let's discuss anything about it in the PR itself 👍 |
Description of Issue
Issue One - Missing Column (resume)
Supabase seems to limit one of the columns in the payload of incoming websocket calls. This is probably just a quote issue, however, I'm not seeing any error logs on the back-end or through the websocket client.
If I send an UPDATE (PATCH) to the server for the
resume
column, the record appears in the payload via the websocket, and the record column (quite large) is in the payload. If I send an UPDATE for a different column, a similar payload appears, but theresume
column is missing, perhaps because of a quota issue.The problem is that I don't see anything in the back-end logs, and I don't see anything in the websocket payload
Server logs
Incoming Websocket Payloads
You can see here that it has removed the
resume
column.I am logging the incoming websocket payloads - possibly only the non-errors. But, I don't see anything about quota errors:
So, the question is how one would see incoming websocket errors... I believe this may be a necessary enhancement for the library. Please read on.
Issue 2 - Unnecessary Exception
This is probably unrelated, but it's the reason I original started investigating.
The endpoint returns 204 with an empty body, but the code tries to parse the response.
This is a problem with the
_parseResponse
method. It is trying to decode an empty body. This gets caught and handled, but it breaks the execution flow of the debugging experience, and this led me to log the bug. I would recommend fixing this one. It is a slight performance hit at least.Pull Request Draft - Allow Websocket Payload Logging
This is only a rough draft PR, and far from perfect. The aim here is to add a callback so consumers can see all incoming websocket data. The aim here would be to see the incoming error so the consumer can tell when data has been removed due to quotas or any other reason.
If Supabase is sending a quote error, the would be that we the error here. Please review and let me know what needs to be done to bring this up to the standard for the codebase.
Historical Information
This bug started out because I noticed and exception. It then evolved because it got a lot more complicated. This is here for a historical log of what happened.
Edit: this was the problem when I first logged it, but it is not the actual problem. The bug is that when I listen to a stream on the table, the first emitted value is correct, but the second emitted value (after updating the record) is missing a column from the table. See this comment
Edit: I just revered to http: ^0.13.6 and the problem is still occurring. This seems to have nothing to do with the
http
package.I just upgraded to http ^1.1.0. It looks like it's not compatible with the PostgREST SDK V1.5.0
The endpoint returns 204 with an empty body, but the code tries to parse the response.
The problem is happening in
_parseResponse
. You can see that the body is an empty string here.It was a query for a table with an
eq
on the ID column. The method isPATCH
. The content length here is actually 0, so it should be hitting a different code path, I would say.The text was updated successfully, but these errors were encountered: