-
Notifications
You must be signed in to change notification settings - Fork 41
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
Slack doesn't finish connecting, endlessly fetching channel names #123
Comments
I think I'm having the same problem, though I believe it has something to do with pagination and rate limiting. The first request works fine, however the next request doesn't update the pagination token and it just retrieves the same response over and over again until finally rate limited. |
+1 |
Which phase of login does this happen in ("Loading Users", "Loading conversations", ...) or could you send the repeated request and response from the logs? It's hard to see how the |
slack: api call: https://.slack.com/api/users.list?token=xoxs-22xx-66xxxxxx&presence=false&limit=100&cursor=dXNlcxxxxxxx%3D There could be hundred to thousands of users in different channels (15-20) I belong to, does it mean the above call will never be completed? Hi @dylex , how can I suppress personal information from the debug logs? |
Ah, yeah, if there are a lot of users on the slack, that can take a long time, since we can only fetch so many at a time and slack rate limits. See #81. There's an experimental workaround on the |
Hi @dylex , Super!! It worked within 5 seconds, I guess it should be part of master branch. |
Hi @dylex , It looks like the lazy_load option is allowing me to get my slack account loaded, though this is just a band aid as the original issue still exists if I don't use the lazy_load option. I think where I said "pagination token" and you said "cursor" we may be referring to the same thing. As with @piyushgarg , I'm looking at an account with thousands of users and at least 100 channels. I'll try to get my logs together tomorrow to show you what I've discovered. This is a company account so I have to go through them and make sure I don't accidentally post any company sensitive data. |
The |
I'm pretty sure I set that to the limit whenever I wrote it, but if they've increased it we should certainly revisit. @hmcclungiii you say it's providing the exact same cursor every time? That definitely sounds like a bug somewhere and it'd be great to see at least one request and response pair, even with only the metadata. (The only reason I haven't merged history in yet is I'm stil seeing an occasional crash, I think when getting activity or a message from a new/unknown user, but haven't been able to track it down beyond some sort of double-free memory corruption.) |
Well, bumping the limit did seem to fix the problem for me, at least. Might easily still be masking the bug tho. |
I started having this as well. I tried everything, but this kept crashing pidgin, spectrum2, and even bitlbee via purple. |
@dylex Hi! Sorry, I lost track of this thread and had to quit using the software for some time. I apologize for the nearly years long delay in responding. It looks like this issue still persists. I'll see what I can do about reproducing it again and getting you some valuable debug info very soon. |
This appears to be a bug on their end. While working on #137, I discovered that While working on #137, I've become blocked by this bug, so I'm planning to switch everything to form data, since this is what the official client uses. Hopefully this will fix both issues in one go. |
The way it works is that you need two tokens from the browser. Currently, getting them is inconvenient, but let's start with the basics, and we can improve later. 1. Get the main token by entering the browser devtools while logged into Slack (normally F12). From there, select "Storage", then "Local Storage", "https://app.slack.com" and "localConfig_v2". From inside this value, fish out the value of the "token" key, which starts with "xoxc-". Make sure to get the whole token, and not the surrounding quotes. Paste this value in some temporary place. 2. Now move from "Local Storage" to "Cookies", and again "https://app.slack.com". Copy the value of the "d" cookie, which starts with "xoxd-". Paste this value after the one from the previous step, with exactly one space in between. 3. Take the two concatenated values, and paste them into the password field of the Slack account. The value should look like this: "xoxc-12345 xoxd-67890" (but much longer obviously). About the implementation: This requires using form based submission, because the JSON based API is broken and does not return the correct data, even with the same parameters (see issue dylex#123). Therefore the way the token is passed, even the single token which already worked, is now changed to form data. Since `slack_api_get` is no longer a valid call when form based submission is used (it requires post), this function has been removed. Signed-off-by: Kristian Amlie <[email protected]>
It looks like there might be something wrong with the parsing or fetching of channel names in this plugin --- according to the log file, it looks like the "login" step fails to complete for one of my 7 slacks due to the process of fetching channel names being re-started over and over again. The first two channel name fetch requests complete as expected and introduce newly-discovered channels; the next several hundred requests just reveal the same two sets of channel names, and no new names are discovered.
This started happening some time yesterday or this morning, during which the slack in question created only one new public channel, called "erdos-scheduler"
I should be noted that receiving messages works as expected during the endless channel-name fetching, but as the "login" step has not completed pidgin does not allow the sending of messages.
Any idea what this could be?
The text was updated successfully, but these errors were encountered: