lilia
9a63703340
Close the socket/keepalive when going offline
...
// FREEBIE
2015-09-30 14:22:07 -07:00
lilia
c1b9f3235f
Save all errors
...
But clean up objects created by the Error constructor, as they contain
non-serializable properties, like functions.
// FREEBIE
2015-09-30 14:22:07 -07:00
lilia
37ff3cf5a8
Change http logging
...
Printing method + url again makes it easier to match requests to
responses when scanning logs.
// FREEBIE
2015-09-30 14:21:52 -07:00
lilia
0f8aff12c5
Refactor contact rendering in message detail view
...
DRY
// FREEBIE
2015-09-30 14:21:52 -07:00
lilia
b8536679b3
Stop keepalive when socket closes
...
// FREEBIE
2015-09-30 14:21:10 -07:00
lilia
04c5f83485
Un-nest libtextsecure errors
...
Fix inconsistency in error format, where we sometimes get an unexpected
Error object and sometimes get a wrapper object containing an Error.
Also start saving network errors.
// FREEBIE
2015-09-30 12:44:11 -07:00
lilia
1879e73c76
Allow one more retry if we get a 409
...
Handle cases where we get a 409 (missing/extra devices), handle it, then
get a 410 (stale devices by registration id).
// FREEBIE
2015-09-28 14:10:50 -07:00
lilia
8453424ebd
Fix stuck pending messages state
...
Refactor outgoing message error handling to use the same success and
error handlers. This creates a somewhat strange pattern, where we call
send and pass in the promise that resolves when sending is complete, but
there's enough variety in the libtextsecure syntax for different message
sending routines that it belongs at the conversation level and only the
post-processing stuff is really shared by all messages.
// FREEBIE
2015-09-28 13:33:26 -07:00
lilia
f9ce27f2c8
Refactor index.js
...
There is no in-window navigation in the chrome app environment, so nix
the first if-clause here. Also make it programmatically reloadable and
fix indentation.
// FREEBIE
2015-09-25 17:57:23 -07:00
lilia
2bdd0106e7
Add comments
...
// FREEBIE
2015-09-25 11:10:25 -07:00
lilia
eb1cfe9b70
Move notification listeners to background
...
Otherwise they will be re-registered by the frontend page.
// FREEBIE
2015-09-25 11:10:14 -07:00
lilia
3bf9e36ead
Move function declarations out of storage.onready
2015-09-24 10:39:56 -07:00
lilia
c8e51563a0
Refactor initial sync codepath to application layer
...
To reduce dependence on the message sending module, AccountManager
should send no sync requests itself.
2015-09-24 10:38:58 -07:00
lilia
6123c419d0
Remove refreshGroup
...
1. This is nonstandard behavior, not supported by any other clients. It
may help sometimes but will also cause bugs (see 2)
2. iOS doesn't handle group updates with missing fields. all fields must
be populated, and libtextsecure doesn't have any knowledge of the group
name or avatar, so these updates will clobber group state on iOS.
// FREEBIE
2015-09-23 16:45:09 -07:00
lilia
94e1c2d123
Remove check for .humanError property
...
This property is no longer used by any of our errors.
// FREEBIE
2015-09-23 16:45:09 -07:00
lilia
6547538458
Use foreach instead of a loop
...
This syntax makes plain that the function is not used anywhere else,
and increases linearity/readability.
// FREEBIE
2015-09-23 16:45:08 -07:00
lilia
acaf7b8de2
Refactor relay consistency check
...
Check the device list for relay consitency and throw an exception before
attempting to encrypt to any of the mismatched devices.
// FREEBIE
2015-09-23 16:45:08 -07:00
lilia
bafc61600c
Refactor sendMessageToDevices
...
Leverage map and Promise.all for more concise and linear code flow.
2015-09-23 16:45:07 -07:00
lilia
9ff95c7e61
DRY up group update sending
...
// FREEBIE
2015-09-23 16:45:07 -07:00
lilia
f00d118c93
More logging
...
// FREEBIE
2015-09-23 16:30:30 -07:00
lilia
f6b35ffbfc
Log error stack traces
...
// FREEBIE
2015-09-23 16:30:30 -07:00
lilia
213dbdefd2
Reorder functions
...
// FREEBIE
2015-09-23 16:30:30 -07:00
lilia
62c90e3925
Don't save/log websocket error
...
It's a generic error Event and doesn't actually contain anything useful.
// FREEBIE
2015-09-23 16:30:30 -07:00
lilia
289b82d1dc
Expose messageReceiver.close
...
// FREEBIE
2015-09-23 16:30:29 -07:00
lilia
1d370857fc
Remove unused callback arguments
...
Unused since d0fd3e94
afaict.
// FREEBIE
2015-09-23 16:07:21 -07:00
lilia
2204ef863d
Fix event name
...
We successfully retry after a websocket connection closes, but this typo
prevented us from retrying if the websocket simply never opened.
// FREEBIE
2015-09-23 16:07:20 -07:00
lilia
d1191c509c
Log outgoing errors individually
...
// FREEBIE
2015-09-21 11:48:57 -07:00
lilia
ada3d999e0
Log outgoing errors
...
// FREEBIE
2015-09-21 11:02:33 -07:00
lilia
ce49d14d85
Fix leave group bug
...
This one's been around since forever, but only manifests when someone
leaves the group and comes back. In that case we fail to reinit their
numberRegistrationId object, which causes a npe when we try to send
send them group messages.
Affected parties must ask their fickle friends to leave/join again.
// FREEBIE
2015-09-21 11:00:12 -07:00
lilia
4a482243d0
Simplify event arguments
...
// FREEBIE
2015-09-21 10:32:35 -07:00
lilia
c8a76ab38e
Fix websocket event handler name
...
// FREEBIE
2015-09-21 10:32:35 -07:00
lilia
21667d9181
Log when we start waiting for an online event
...
// FREEBIE
2015-09-21 10:32:35 -07:00
lilia
823f570955
Add more websocket debug logging
...
// FREEBIE
2015-09-21 10:32:34 -07:00
lilia
f70e844cef
Include url in http response logging
...
Otherwise it's impossible to tell which is which, especially when
sending group messages.
// FREEBIE
2015-09-21 10:32:34 -07:00
lilia
d8803ee31f
Mark leave group messages as sent
...
// FREEBIE
2015-09-21 10:32:33 -07:00
lilia
b1d3829651
Update minimal window dimensions
...
Some day we'll probably lower these minimums but first we'd need a more
responsive design.
Fixes #310
// FREEBIE
2015-09-18 13:13:31 -07:00
lilia
960754ef04
Restyle compose button
...
Move it to a tool bar at the top of the conversation list. This is also
where a search bar will live someday.
Fixes #357
// FREEBIE
2015-09-18 13:08:52 -07:00
lilia
2243c09fea
MessageReceiver is an event target
...
Rather than asking for a global target, the message receiver implements
the EventTarget interface itself. It does not expose the dispatchEvent
method, however. This ensures that events can only be triggered from
within the internal MessageReceiver class, which means we no longer need
to namespace them.
// FREEBIE
2015-09-18 09:30:12 -07:00
lilia
a925027cd2
Refactor MessageReceiver for storage/server independence
...
Let the libtextsecure consumer pass in their own server url, username,
password, and signaling key, as with libtextsecure-java.
Also brings reconnect logic up into the MessageReceiver class, which
is the only place it should apply.
2015-09-17 16:52:32 -07:00
lilia
e59a5792d5
Don't hardcode the attachment host
2015-09-17 16:02:22 -07:00
lilia
184e37383c
Don't auto-populate the relay field
...
According to server api docs, relay is optional when it is the same as
our own server.
// FREEBIE
2015-09-17 16:02:22 -07:00
lilia
7d9cf0c167
Pass the signaling key into decryptWebSocketMessage
...
De-couple this file from dependency on storage.
2015-09-17 16:02:22 -07:00
lilia
c167fc964d
Revert "Remove global updateInbox method"
...
This reverts commit 1c70293bba
.
This broke tests by blocking the database deletion during test
setup.
2015-09-17 15:42:13 -07:00
lilia
310f40fcad
Contact sync should update existing contacts
...
// FREEBIE
2015-09-17 14:26:25 -07:00
lilia
7f4ef6e9e7
Remove double-check of unread count
...
This same condition is already enforced in the markRead method.
// FREEBIE
2015-09-17 13:46:58 -07:00
lilia
1c70293bba
Remove global updateInbox method
...
This operation now needs to be done exactly once, at startup, so we
don't need to expose a global method for it.
// FREEBIE
2015-09-17 13:44:44 -07:00
lilia
6364cda7cb
Create requires an object
...
// FREEBIE
2015-09-17 11:42:59 -07:00
lilia
78d7296f84
Fix tests
...
// FREEBIE
2015-09-17 11:40:42 -07:00
lilia
b617240338
Stop calling updateInbox all the time
...
Now that the inbox collection keeps itself in sync, we don't have the
data duplication that was forcing us to reload constantly.
// FREEBIE
2015-09-17 10:57:17 -07:00
lilia
537f0ceef0
Log all http requests at start and end
...
// FREEBIE
2015-09-17 10:57:17 -07:00