Go to file
Daniel Calviño Sánchez 331bf49f73 Fix processing of participant list on reconnections
When the HPB is used the signaling messages can be received even when
the local participant is not currently in the call (for example, when
starting the call timed out without other participant joining, or when
reconnecting due to the publisher connection failing). Therefore if the
local participant is not in the call it should not try to establish a
connection with the other participants and disconnect them instead.

Moreover, if the connection is tried to be established when not
in the call the HPB will prevent that, and the PeerConnectionWrapper
will stay in a limbo state waiting for an offer to be sent. If the local
participant then joins the call the PeerConnectionWrapper will already
exist for the other participants, so no new connections will be created,
but those previous connections will never be finally established.

Additionally, as the signaling messages can be received before the join
call response the participant list could be received while the call
state is "RECONNECTING" or "PUBLISHER_FAILED". In those cases, as long
as the local participant is already in the call, the participant list
should be processed as if the call state was already "JOINED" (otherwise
the connections were not established either).

For simplicity the participant list is now ignored only when the call
state is "LEAVING"; this means that the participant list would be also
processed in the "CONNECTION_TIMEOUT" state, but the signaling message
should not be received anyway in that case.

Signed-off-by: Daniel Calviño Sánchez <danxuliu@gmail.com>
2022-12-23 11:00:05 +00:00
.devcontainer
.github Merge pull request #2641 from nextcloud/dependabot/github_actions/cirrus-actions/rebase-1.8 2022-12-20 08:48:12 +01:00
.idea
.tx
app Fix processing of participant list on reconnections 2022-12-23 11:00:05 +00:00
buildSrc
contribute
docs
drawable_resources
fastlane
gradle/wrapper
scripts remove unused legacy scripts 2022-12-15 08:33:11 +01:00
.drone.yml
.editorconfig
.gitignore
build.gradle
CHANGELOG.md Added 15.0.3 2022-12-19 09:35:06 +01:00
CODE_OF_CONDUCT.md
CONTRIBUTING.md
detekt.yml
gradle.properties
gradlew
gradlew.bat
LICENCE
README.md
SECURITY.md
settings.gradle
SETUP.md
spotbugs-filter.xml exclude dagger module generated classes and align with files-client excludes 2022-12-15 08:33:10 +01:00

Nextcloud Talk for Android 💬

Build Status Codacy Badge Releases

Download from Google Play Get it on F-Droid

Please note that Notifications won't work with the F-Droid version due to missing Google Play Services.

Conversation list Participant search Voice call Voice recording Markdown view Settings

Video & audio calls through Nextcloud on Android

Nextcloud Talk is a fully on-premises audio/video and chat communication service. It features web and mobile apps and is designed to offer the highest degree of security while being easy to use.

Nextcloud Talk lowers the barrier for communication and lets your team connect any time, any where, on any device, with each other, customers or partners.

Why is this so awesome?

Because it is self hosted!!! Audio/video calls and text chat typically require a central server. Some projects go commendably far in trying to ensure they can't see the data, so nobody, not government, advertising company or somebody who broke in the servers, can follow conversations. But the servers still have to mediate every call and text message, allowing them to map out who talks to who and at what time. This 'metadata' is as useful, if not more, to track people, than the full content, especially for mass surveillance purposes. Even if the data is not stored by the chat server, the hosting provider or a hacker could simply gather the data.

By hosting your own server, all meta data stays on your server and thus under your control!

If you have suggestions or problems, please open an issue or contribute directly :)

How to contribute 🚀

If you want to contribute to Nextcloud, you are very welcome:

Contribution Guidelines 📜

GPLv3. All contributions to this repository are considered to be licensed under the GNU GPLv3 or any later version.

Please read the Code of Conduct. This document offers some guidance to ensure Nextcloud participants can cooperate effectively in a positive and inspiring atmosphere, and to explain how together we can strengthen and support each other.

Please review the guidelines for contributing to this repository.

More information how to contribute: https://nextcloud.com/contribute/

Start contributing 🛠️

Make sure you read SETUP.md and CONTRIBUTING.md before you start working on this project. But basically: fork this repository and contribute back using pull requests to the master branch. Easy starting points are also reviewing pull requests and working on starter issues.

Testing 🧪

So you would like to contribute by testing? Awesome, we appreciate that very much.

To report a bug for the alpha or beta version, just create an issue on github like you would for the stable version and provide the version number. Please remember that Google Services are necessary to receive push notifications.

Beta versions (Release Candidates) 📦

via Google Play

Sign up at Google Play Beta channel to get Release Candidates via Google Play.

via github

You can also get the Release Candidates at github releases.

Alpha versions

via Google Play

To become an alpha tester you have to be signed up for the Google Play Beta channel and additionally you have to join the Alpha testing Google Group. After that you will receive the alpha versions via the Play Store (initially, this might take some minutes after signing up). However, in the Play Store the app will still be named "Nextcloud Talk (Beta)" even if you are an alpha tester, but you will receive the alpha versions. If a beta was released that is newer than the alpha version, you will get the beta in the alpha channel.

via Download page

In addition to google play, the alpha and beta apps can also be obtained from the Nextcloud Download page Please make sure to remember that these versions might contain bugs and you don't use them in production.

Support ⛑️

If you need assistance or want to ask a question about the Talk Android app, you are welcome to ask for community help in our forums. If you have found a bug, feel free to open a new issue on GitHub. Keep in mind, that this repository only manages the Nextcloud Talk for Android app. If you find bugs or have problems with the server/backend, you should ask the Nextcloud server team for help!

Notifications

If you have problems to receive talk notifications on your android phone, please have a look at this checklist.

Credits 📜

Ringtones 🔔

Remarks 📜

Google Play and the Google Play logo are trademarks of Google Inc.