|  | Commit message (Collapse) | Author | Age | Lines | 
|---|
| | |  | 
| | 
| 
| 
| 
| | >Login error: Failed to read thrift: facebook-api.c:1815
>fb_api_cb_publish_pt: assertion 'FALSE' failed | 
| | 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| | The contact list is fetched in pages of 500, but non-friends need to
be filtered out, so you could end up in a situation where the last
page of results is all non-friends. The "contacts" signal was emitted
for each page of results, and has a flag that says if it's complete,
which lets login continue.
So when the last page of the contact list is empty (all non-friends)
the contacts signal isn't emitted, and login gets stuck forever.
This commit changes it so that the signal is emitted with an empty
'users' GSList when it's complete (and when it's an initial fetch,
not when when parsing deltas, which doesn't use the 'users' GSList)
Thanks to dcxk for finding this and helping debug it. | 
| | 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| | Since there are some issues I can't reproduce, let's do this experiment
properly and figure out if this really matters.
Value 1 is slightly newer. Value 2 is newer with the current set of
fields. Value 3 is what purple-facebook uses.
Adding 4 makes it http only, adding 8 makes it mqtt only. Some values
are redundant.
I suggest trying 1, 2, 3, 7 and 11. | 
| | |  | 
| | 
| 
| 
| 
| 
| 
| 
| 
| | This reverts commit 310de485e9597df35e94cd4020f8b23121cb3904.
Turns out it wasn't harmless, and it breaks mac OS. Instead of adding
platform checks here, this flag is now included in the cygwin-specific
parts of the bitlbee pkg-config file, as of bitlbee commit b9c10a1a
(version string 3.5.1+20170529+develop+18-gb9c10a1a-git) | 
| | 
| 
| 
| 
| 
| 
| 
| 
| 
| | Quoting https://cygwin.com/ml/cygwin/2013-07/msg00421.html
>despite popular misconception, this flag is harmless on non-PE targets
This also depends on changes on the bitlbee side to be able to link to
bitlbee itself, see bitlbee commit 54b2a367 (version string
3.5.1+20170513+develop+16-g54b2a367-git) | 
| | 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| | Fixes "Failed to parse thread information" errors when joining channels.
Facebook rolled a hotfix update today and they are requiring the same
user agent for HTTP requests too. As far as I can see the main affected
request is ThreadQuery.
Hopefully this also solves issues some a tiny minority of people were
still having with sync sequence ids. | 
| | 
| 
| 
| | Last commit was broken | 
| | 
| 
| 
| 
| | Since it's used for different things and parameters are all wrong with
the newer query hash, but the seq id query doesn't use parameters. | 
| | 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| | Looks like this is what they use to discontinue older versions.
An empty user agent is treated as too old.
This fixes following error when sending messages:
    This app version no longer supports messaging. To continue to send
    and receive messages, please update your app to a newer version or
    use the mobile web version of Facebook. | 
| | 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| | This hash represents a graphql query cached in the server. We were using
an old version of the hash that broke for some reason, possibly related
to the fact that fb messenger versions older than 5 are being
discontinued. For reference, the oldest parts of the plugin were written
when 4 was the latest version, most parts are updated to 33 or 38, and
the newest parts are based on 100 or so.
Thanks EionRobb for coming up with this fix so quickly. | 
| | 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| | If glib is built with --enable-debug=yes, it will have G_ENABLE_DEBUG
set internally
This flag changes the g_marshal_value_peek_object() macro to use
g_value_get_object(), which performs sanity checks, instead of doing a
direct offset access.
The definition of our error signal was wrong, using a marshaller with
a GObject in the first parameter but setting the type of the GValue to
G_TYPE_ERROR. Since we have no marshaller for G_TYPE_ERROR, and that all
of those are functionally equivalent (and in fact use the exact same
code in non-debug builds), I went with POINTER for both sides.
The actual crash happened because of a g_return_val_if_fail() in the
sanity checks which made it return NULL after throwing a warning like
this:
    g_value_get_object: assertion 'G_VALUE_HOLDS_OBJECT (value)' failed
This was reported by a gentoo user who had the debug use flag. Thanks! | 
| | |  | 
| | |  | 
| | 
| 
| 
| | The server expects the tid parameter to be just the tid now. | 
| | 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| | Looks like the mercury topics were deprecated and instead we get these:
* deltaThreadName
* deltaParticipantsAddedToGroupThread
* deltaParticipantLeftGroupThread
Also slightly modified the handlers on the bitlbee side to add users
directly without requiring a thread fetch, and to show a kick message | 
| | |  | 
| | 
| 
| 
| 
| 
| | Those URLs seem to be generated when the Android share feature is used.
Fixes #97 | 
| | |  | 
| | 
| 
| 
| 
| 
| | Because apparently that's a thing that happens (incoming delta with
added item saying "friendship_status": "CAN_REQUEST" instead of
"ARE_FRIENDS") | 
| | 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| | This has a number of benefits:
- Most of the time the contact sync reply will be empty
- We can do contact sync more frequently (It's 5 mins now, was 30)
- Figuring out what contacts were added or removed is much simpler and
  less likely to get things wrong.
- Non-friends are no longer accidentally removed because there's no need
  to compare contact lists
- On accounts with lots of friends this gets rid of one source of CPU
  usage spikes
- Less load for facebook's servers (lol) | 
| | |  | 
| | 
| 
| 
| | And add the FetchContactsDeltaQuery one. | 
| | |  | 
| | 
| 
| 
| 
| 
| | This replaces a subset of "Failed to parse thread information" (the ones
that aren't really a problem parsing) with "You have been removed from
this chat" appearing in the relevant chat window. | 
| | |  | 
| | 
| 
| 
| 
| 
| | Those are created by the "Marketplace" feature:
http://newsroom.fb.com/news/2016/10/introducing-marketplace | 
| | 
| 
| 
| | Shot in the dark to fix checkpoint issues, but had to be done anyway. | 
| | 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| | Fixes #89 (No matches for $.represented_profile.id)
Previously, in 4efa397, hugePictureUrl was made optional. Now someone
complains about represented_profile being missing, replaced with a null.
To be honest I'm worried about what kind of bug might be breaking things
so subtly on the server side, but well, it's not my job.
This will result in some friends with missing represented_profile not
being included in the contact list, because we're missing rather
essential information. But better than not being able to log in. | 
| | 
| 
| 
| 
| | Now it returns true if url1 is contained inside url2, or the other way
around. This helps when a message body is compared with a url. | 
| | 
| 
| 
| | See bitlbee/bitlbee@d28fe1c. | 
| | 
| 
| 
| 
| 
| 
| 
| 
| | I'm still not sure about the origin of these errors (I suspect it's a
race condition between servers), but it's going to be fixed properly in
the future when the sync protocol is updated and doing HTTP requests to
get the attachment URL is no longer required (newer orca versions only
do HTTP requests to get the url of file attachments, everything else is
included in the MQTT stream) | 
| | 
| 
| 
| 
| 
| 
| 
| | Facebook seems to randomly send null in this field sometimes. It's not
very important so it can be made optional.
This includes moving the checksum code (which was previously duplicated)
to a separate function so that there's a single null check. | 
| | 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| | Mostly fixes bug #76
This is crappy and error prone, just like the rest of the duplicate
message handling code. It works, but it's going to get some echoes now
and then, particularly in quick moving groupchats.
I'm pretty sure this is a bug in the server, but the official clients
have much more elaborate deduplication built-in, so they won't notice. | 
| | 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| | Normally, bitlbee's ssl_handshake calls the callback with an error
status and calls ssl_disconnect().
In this plugin fb_mqtt_error(), calls fb_mqtt_close(), which called
ssl_disconnect() on priv->ssl.
This fix prevents that double ssl_disconnect() by setting priv->ssl to
null, so that fb_mqtt_close() cleans everything except that.
Fixes #82 | 
| | |  | 
| | 
| 
| 
| 
| 
| 
| 
| 
| 
| | The set `mark_read` now accepts `available` in addition to `true` and
`false`. When `mark_read` is set to `available` it will only mark
messages read when the user is not marked as away/invisible.
The set `mark_read_reply` was added, when this is set to `true` any
unread messages will be marked as read when the user replies them
(assuming they where received by bitlbee). | 
| | 
| 
| 
| 
| 
| | This fixes contact list fetching for accounts with more than 500
friends, which only got the first page of results. The previous method,
using graph_api_write_id, stopped working at some point. | 
| | 
| 
| 
| 
| | This is mainly for sanity and consistency as the bee_user should be
zeroed. | 
| | 
| 
| 
| 
| 
| 
| | There is a report of the 'oh' parameter missing from some of the icon
images, which is used as the checksum. The solution is to simply use
the URL itself as the checksum in the *rare* case the 'oh' parameter
is missing. | 
| | |  | 
| | |  | 
| | 
| 
| 
| | It happens that < and > are special characters for gtk-doc. | 
| | 
| 
| 
| 
| 
| | This fixes an improper GError propagation, which not is only incorrect,
but also has no effect. This ends up leading to the unsupported XMA
message being ignored without any notice to the user. | 
| | 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| | Sometimes Facebook will sent a batch of duplicated messages over the
MQTT stream. There are occasions where Facebook will send duplicated
messages which are not sequential, however, it does not occur at the
rete of the sequential duplication. This is likely due to the fact that
the plugin is using an older revision of the Messenger protocol.
For now, we should attempt to ignore sequential duplicates from being
from being display. This fix is not bullet proof, but it is simple, and
should cut down on the duplicated message spam.
The proper fix is likely going to be to update the plugin to use a more
recent Messenger protocol revision. | 
| | |  | 
| | 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| | Often times, the MQTT stream is disconnected by Facebook for whatever
reason. The only thing I can think of is some sort of load balancing on
Facebook's end. It has also been reported that when a user logs out on
the Facebook website, their MQTT connections are killed. Whenever the
connection is killed by Facebook, the user is able to reconnect right
after.
In order to make for a quieter experience, the plugin should attempt
to silently reconnect before notifying the user of an error. This is
done by relying on the sequence identifier and the message queue to
ensure everything remains synchronized for when the connection returns. | 
| | 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| | This ensures a message is sent successfully before attempting to send
another message. As a result, messages are sent in their proper order,
instead of the order in which they arrive. This also introduces a check
for the successful sending of a message, rather than silently failing.
The queued sending also ensures messages are not lost when the state of
visibility is being switched. This also allows the plugin to silently
reconnect when a connection failure occurs. | 
| | 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| | The plugin is required to read Thrift data for the presence states of
contacts. The data which is being read has some optional fields, which
are rarely not supplied. This has led to this bug being undiscovered
for quite some time.
Not only was the plugin not properly accounting for optional fields,
but also did not account for field scoping. This is not really an issue
until a Thrift list is being read, which will cause the identifier to
grow with each field read, rather than reset. The field identifier is
only relevant to its local scope, nothing more. More importantly, the
identifier must be reset with each iteration of a list. |