briar issueshttps://code.briarproject.org/groups/briar/-/issues2021-10-27T14:09:40Zhttps://code.briarproject.org/briar/briar/-/issues/834Optionally sign out when battery is low or power saving mode is enabled2021-10-27T14:09:40ZakwizgranOptionally sign out when battery is low or power saving mode is enabledListen for power manager events (ACTION_BATTERY_LOW, ACTION_POWER_SAVE_MODE_CHANGED) and [manufacturer-specific events](http://stackoverflow.com/a/25103642) and optionally sign out if the battery is low or power saving mode is enabled an...Listen for power manager events (ACTION_BATTERY_LOW, ACTION_POWER_SAVE_MODE_CHANGED) and [manufacturer-specific events](http://stackoverflow.com/a/25103642) and optionally sign out if the battery is low or power saving mode is enabled and the user's not currently interacting with Briar.https://code.briarproject.org/briar/briar/-/issues/833ContactExchangeTaskImpl keeps a reference to KeyAgreementActivity2020-11-21T12:38:56ZakwizgranContactExchangeTaskImpl keeps a reference to KeyAgreementActivityKeyAgreementActivity implements ContactExchangeListener, an interface that ContactExchangeTaskImpl uses to keep the UI informed about its progress. ContactExchangeTaskImpl keeps a reference to the activity via this interface, but the act...KeyAgreementActivity implements ContactExchangeListener, an interface that ContactExchangeTaskImpl uses to keep the UI informed about its progress. ContactExchangeTaskImpl keeps a reference to the activity via this interface, but the activity may be destroyed before the task completes.
The activity's listener methods use runOnUiThreadUnlessDestroyed(), so they should return safely if they're called after the activity's destroyed, but the activity instance will be leaked until the task completes.https://code.briarproject.org/briar/briar/-/issues/827Transition from private conversation back to contact list affects wrong item2020-11-21T12:39:38ZakwizgranTransition from private conversation back to contact list affects wrong itemI ran into a couple of problems while testing the transition between the contact list and the private conversation. Reproducing them requires API 23 as the transition is disabled on older versions.
The first problem occurs when the cont...I ran into a couple of problems while testing the transition between the contact list and the private conversation. Reproducing them requires API 23 as the transition is disabled on older versions.
The first problem occurs when the contact moves to a new position in the list while the private conversation is open. This can happen if you select any contact except the one at the top of the list, send a message, and return to the contact list. The contact will now be at the top of the list. The problem is that the reverse transition moves the avatar from the toolbar to the contact's old position in the list, which is now occupied by a different contact.
The second problem occurs when you remove the contact, which automatically returns you to the contact list. The transition moves the avatar from the toolbar to the contact's old position in the list, which may now be occupied by a different contact or may be empty.https://code.briarproject.org/briar/briar/-/issues/826Online status in group memberlist2020-11-21T12:40:34ZTorsten GroteOnline status in group memberlistThe group member list shows the online status of contacts. As of MR !448, it only shows the online status of contacts, we actually share with to be consistent with the sharing information in the group's action bar.
This can be confusing...The group member list shows the online status of contacts. As of MR !448, it only shows the online status of contacts, we actually share with to be consistent with the sharing information in the group's action bar.
This can be confusing since some group members have online status and others don't.https://code.briarproject.org/briar/briar/-/issues/825Show an error message if no transports are available for adding contacts2020-11-21T12:41:36ZakwizgranShow an error message if no transports are available for adding contactshttps://code.briarproject.org/briar/briar/-/issues/824Transition between key agreement fragments is broken2021-02-04T18:51:56ZakwizgranTransition between key agreement fragments is brokenThe transition from IntroFragment to ShowQrCodeFragment doesn't work as expected: instead of ShowQrCodeFragment sliding in from the right, the screen briefly goes black, then IntroFragment reappears, then ShowQrCodeFragment appears. The ...The transition from IntroFragment to ShowQrCodeFragment doesn't work as expected: instead of ShowQrCodeFragment sliding in from the right, the screen briefly goes black, then IntroFragment reappears, then ShowQrCodeFragment appears. The transition has been disabled as a workaround, but ideally we should fix it.
This may be fixed by the refactoring described on #288, or it may not.https://code.briarproject.org/briar/briar/-/issues/823Combined feed uses a different fragment transition from single blogs2020-11-21T12:43:07ZakwizgranCombined feed uses a different fragment transition from single blogsThe transition from the list of posts to an individual post in the combined feed is different from the corresponding transition in a single blog. In the combined feed, the list disappears and the post slides in from the right. In a singl...The transition from the list of posts to an individual post in the combined feed is different from the corresponding transition in a single blog. In the combined feed, the list disappears and the post slides in from the right. In a single blog, the list fades out and the post fades in and slides in from the right.
This is not an important bug.https://code.briarproject.org/briar/briar/-/issues/819UX design for errors that don't interrupt the user's workflow2020-11-21T12:43:46ZTorsten GroteUX design for errors that don't interrupt the user's workflowThis ticket is for creating the UX design when errors occur that don't interrupt the user's workflow.
Imagine you share a forum with someone or invite two contacts to each other. These operations might fail, but since the invitation scr...This ticket is for creating the UX design when errors occur that don't interrupt the user's workflow.
Imagine you share a forum with someone or invite two contacts to each other. These operations might fail, but since the invitation screen closes anyway, it does not really interrupt your work-flow anymore. Another possible error might happen when a title of the blog or the number of online users is loaded to be shown in the action bar. There will just be the default title maybe "Blog" and the user might not even notice, but it is a bug we might want to know about. Another example is when we fail to store the fact that we already showed you the onboarding and then show it to you again.
So more general, the kinds of errors I imagine to fall in this category are:
* user actions that are not completed, but don't interrupt the workflow because it finishes at this point anyway
* loading of non-essential information
Subticket of #469.https://code.briarproject.org/briar/briar/-/issues/818UX design for errors that interrupt the user's workflow2020-11-21T12:44:25ZTorsten GroteUX design for errors that interrupt the user's workflowThis ticket is for creating the UX design for when errors occur that interrupt the user's workflow and don't have any corrective action.
For example, you open your private conversation with someone, but it just closes again (or shows an...This ticket is for creating the UX design for when errors occur that interrupt the user's workflow and don't have any corrective action.
For example, you open your private conversation with someone, but it just closes again (or shows an error message) because an error occurred while loading it. You open a private group, but when finding out whether it is dissolved an error occurs, so it stays in the disabled state by default. Or you are in a multi-step process and an error prevents you from reaching the next step like when creating a private group fails and you are not getting to the next step of inviting contacts to it.
Errors while loading blog posts, private message, forum posts, contacts, basically anything in lists falls into this category.
Subticket of #469.https://code.briarproject.org/briar/briar/-/issues/817Add a setting to control whether Briar uses a wake lock2023-04-24T12:16:56ZakwizgranAdd a setting to control whether Briar uses a wake lockBriar holds a wake lock while Tor is running. @gdt asked for a setting to disable the wake lock, which would mean messages wouldn't be synced while the device was sleeping, but battery usage would be reduced.
If no other app is holding ...Briar holds a wake lock while Tor is running. @gdt asked for a setting to disable the wake lock, which would mean messages wouldn't be synced while the device was sleeping, but battery usage would be reduced.
If no other app is holding a wake lock, the device typically sleeps a few seconds after the screen turns off. We probably don't want to lose connectivity immediately, and it would be good if we could prepare for sleep so Tor doesn't panic when it wakes up. We might consider holding a wake lock for a few minutes after the screen turns off, then cleanly going offline and releasing the wake lock. Then we can listen for ACTION_SCREEN_ON to reacquire the wake lock and go online.
Alternatively, if we want to be really hardcore about saving battery at the expense of connectivity, we can go offline when the screen turns off. In that case no wake lock would be needed.
Related to #268, #769.https://code.briarproject.org/briar/briar/-/issues/815When Bluetooth can not be enabled QRCode loads forever2020-11-21T12:45:30ZTorsten GroteWhen Bluetooth can not be enabled QRCode loads foreverMy Sony Xperia Pro test phone seems to have an issue with Bluetooth at the moment. It is in a semi active state, but not really enabled. When trying to add contacts (which should work fine over WiFi), the QRcode loads forever without eve...My Sony Xperia Pro test phone seems to have an issue with Bluetooth at the moment. It is in a semi active state, but not really enabled. When trying to add contacts (which should work fine over WiFi), the QRcode loads forever without ever failing or showing up.https://code.briarproject.org/briar/briar/-/issues/811Tester did not understand difference between Forum and Private Group2021-02-27T21:49:14ZTorsten GroteTester did not understand difference between Forum and Private GroupOne of the testers from Cryptorave tried Briar again and wondered what the difference between forums and private groups is. Both seem to be a place where you can add people to talk together and both use the same message layout.One of the testers from Cryptorave tried Briar again and wondered what the difference between forums and private groups is. Both seem to be a place where you can add people to talk together and both use the same message layout.https://code.briarproject.org/briar/briar/-/issues/806Continue to show private group visibility for removed contacts2020-11-21T12:48:43ZakwizgranContinue to show private group visibility for removed contacts@grote raised this issue while we were working on #754 but I forgot to respond at the time.
If a contact is revealed to a private group and the contact is later removed, we should continue to show the relationship as visible, both in th...@grote raised this issue while we were working on #754 but I forgot to respond at the time.
If a contact is revealed to a private group and the contact is later removed, we should continue to show the relationship as visible, both in the former contact's join message and in the membership list.https://code.briarproject.org/briar/briar/-/issues/802Automatic introduction on group creation2020-11-21T12:49:57ZTorsten GroteAutomatic introduction on group creationWhile discussing private groups and how/why revealing works (#801) during a user testing (#788), somebody asked for all contacts they invite to a group to be introduced to each other automatically to ensure that all of them are contacts ...While discussing private groups and how/why revealing works (#801) during a user testing (#788), somebody asked for all contacts they invite to a group to be introduced to each other automatically to ensure that all of them are contacts of each other (and maybe also can automatically reveal themselves to the group).https://code.briarproject.org/briar/briar/-/issues/801Revealing contact relationship is not clear2020-11-21T12:52:17ZTorsten GroteRevealing contact relationship is not clearDuring testing session #788, no one understood what revealing contact relationships means although most users were rather technical and were using other apps extensively. The onboarding dialog didn't help. It was not clear who can revea...During testing session #788, no one understood what revealing contact relationships means although most users were rather technical and were using other apps extensively. The onboarding dialog didn't help. It was not clear who can reveal contacts and why the creator can not do it. It was not clear what this exactly means and why it can be done.
It took some long explanations before everybody had understood this feature. They were all open to p2p apps and appreciated the explanation. They were happy to understand how messages travel through the p2p network, but they also acknowledged that we are trying to explain features without requiring users to understand that.
Some testers doubted that it is possible to understand revealing contacts without knowing about how messages travel. They pointed out how Briar works very differently than other apps they are familiar with and that it needs some getting used to. The user familiar with Retroshare suggested to use a visual representation of the contact relationship within a group as this can help with understanding this concept and also nicely illustrate the p2p approach.
![briar-user-graph](/uploads/a7819e19bc66f94fc0c3ff50d9265eb7/briar-user-graph.png)https://code.briarproject.org/briar/briar/-/issues/800Confusing feature names2022-11-18T17:24:07ZTorsten GroteConfusing feature namesDuring testing session #788, users noted that they found the names of the current features confusing.
# Forum and Private Groups
Users noted that forums seem to resemble what they know as groups from other messengers (WhatsApp, Telegra...During testing session #788, users noted that they found the names of the current features confusing.
# Forum and Private Groups
Users noted that forums seem to resemble what they know as groups from other messengers (WhatsApp, Telegram and Signal) due to them being open in the sense that everybody can invite new members to the forum/group. They suggested to maybe call it "Open Group" and "Private Group".
# Blogs
After understanding somewhat how Blogs work at the moment, the testers agreed that blog is not a good name for this feature. They suggested to call it "Timeline", I guess mainly because they couldn't create additional blogs and because everybody's posts were shown in this list like they know it from Facebook and Twitter.https://code.briarproject.org/briar/briar/-/issues/797Adding additional blogs2021-01-13T12:40:00ZTorsten GroteAdding additional blogsDuring the user testing #788, a user asked: "How can I make a new blog?"
This happened in after a misunderstanding about RSS import (#796) where all entries were imported into the user's personal blog. The user expected it to be possibl...During the user testing #788, a user asked: "How can I make a new blog?"
This happened in after a misunderstanding about RSS import (#796) where all entries were imported into the user's personal blog. The user expected it to be possible to create additional blogs like they could create additional forums and additional groups.https://code.briarproject.org/briar/briar/-/issues/794Message can be sent after group was dissolved2017-12-18T07:40:27ZTorsten GroteMessage can be sent after group was dissolvedDuring a testing session (#788), a user reported that they were able to send a message after a group had been resolved. Another user who had the group open at the same time, did get the dialog informing him that the group had been dissol...During a testing session (#788), a user reported that they were able to send a message after a group had been resolved. Another user who had the group open at the same time, did get the dialog informing him that the group had been dissolved, but the user who was writing a messaging, did not get the dialog and could still send the message.
We would need to try to reproduce this as it is possible that the dissolve notice did not arrive in time and the user could sent the message before the dissolve notice arrived.https://code.briarproject.org/briar/briar/-/issues/792Tester could not find a private group they'd been invited to2020-11-21T12:57:05ZTorsten GroteTester could not find a private group they'd been invited toDuring a testing session (#788), a user was confused about where to find the private group they just had been invited to. They expected to find the group in the contact list screen. The group agreed that this is where they would expect t...During a testing session (#788), a user was confused about where to find the private group they just had been invited to. They expected to find the group in the contact list screen. The group agreed that this is where they would expect to find groups, because they know this from other messengers that have a list of conversation that include private conversations and group conversations in one screen.
The list of contacts could be made available elsewhere.https://code.briarproject.org/briar/briar/-/issues/786Handle whitespace consistently2022-11-18T17:24:07ZakwizgranHandle whitespace consistentlyText with leading or trailing whitespace is treated inconsistently:
* Nicknames: whitespace isn't trimmed, whitespace-only names are allowed
* Private messages: whitespace is trimmed, whitespace-only messages are allowed but become empt...Text with leading or trailing whitespace is treated inconsistently:
* Nicknames: whitespace isn't trimmed, whitespace-only names are allowed
* Private messages: whitespace is trimmed, whitespace-only messages are allowed but become empty after trimming
* Forum names: whitespace isn't trimmed, whitespace-only names are allowed
* Forum invitations: whitespace isn't trimmed, whitespace-only messages are allowed
* Forum posts: whitespace is trimmed, whitespace-only posts aren't allowed
* Private group names: whitespace isn't trimmed, whitespace-only names are allowed
* Private group invitations: whitespace isn't trimmed, whitespace-only messages are allowed
* Private group posts: whitespace is trimmed, whitespace-only posts aren't allowed
* Blog posts: whitespace is trimmed, whitespace-only posts are allowed but become empty after trimming
* Blog comments: whitespace isn't trimmed, whitespace-only comments are allowed
Let's do the following everywhere:
When entering text:
1. Trim leading and trailing whitespace
2. If the trimmed text is empty and the input is optional (for example a blog comment), pass null to the backend
3. If the trimmed text is empty and the input isn't optional (for example a blog post), don't accept the input
4. If the trimmed text is too long, don't accept the input
5. If the trimmed text isn't empty or too long, pass it to the backend
When validating messages (including author names and group names):
1. Reject null if the text isn't optional
2. Reject the text if it's empty or too long
3. Reject the text if it has leading or trailing whitespace