fluffychat/README.md

192 lines
6.8 KiB
Markdown
Raw Normal View History

2020-02-23 09:06:01 +00:00
![](https://i.imgur.com/wi7RlVt.png)
<p align="center">
2021-03-13 07:42:45 +00:00
<a href="https://matrix.to/#/#fluffychat:matrix.org" target="new">Join the community</a> - <a href="https://metalhead.club/@krille" target="new">Follow me on Mastodon</a> - <a href="https://hosted.weblate.org/projects/fluffychat/" target="new">Translate FluffyChat</a> - <a href="https://gitlab.com/ChristianPauly/fluffychat-website" target="new">Translate the website</a> - <a href="https://fluffychat.im" target="new">Website</a> - <a href="https://gitlab.com/famedly/famedlysdk" target="new">Famedly Matrix SDK</a> - <a href="https://famedly.com/kontakt">Server hosting and professional support</a>
2020-02-23 09:06:01 +00:00
</p>
<br>
<br>
2021-11-06 09:34:33 +00:00
FluffyChat is an open source, nonprofit and cute matrix messenger app. The app is easy to use but secure and decentralized.
## Features
- Send all kinds of messages, images and files
- Voice messages
- Location sharing
- Push notifications
- Unlimited private and public group chats
- Public channels with thousands of participants
- Feature rich group moderation including all matrix features
- Discover and join public groups
- Dark mode
- Hides complexity of Matrix IDs behind simple QR codes
- Custom emotes and stickers
- Video calls via sharing links to Jitsi
- Spaces
- Compatible with Element, Nheko, NeoChat and all other Matrix apps
- End to end encryption
- Emoji verification & cross signing
- And much more...
## FluffyChat comes with a dream
Imagine a world where everyone can choose the messenger they like and is still able to chat with all of their friends.
A world where there are no companies spying on you when you send selfies to friends and lovers.
And a world where apps are made for fluffyness and not for profit. ♥
2020-01-03 17:41:50 +00:00
2020-10-10 10:22:08 +00:00
# How to build
2020-01-01 18:10:13 +00:00
2020-01-03 08:28:17 +00:00
1. [Install flutter](https://flutter.dev)
2020-01-01 18:10:13 +00:00
2020-02-23 09:06:01 +00:00
2. Clone the repo:
```
git clone --recurse-submodules https://gitlab.com/famedly/fluffychat
cd fluffychat
2020-02-23 09:06:01 +00:00
```
2020-01-01 18:10:13 +00:00
2020-10-10 10:22:08 +00:00
3. Choose your target platform below and enable support for it.
2020-01-03 08:28:17 +00:00
2021-09-24 14:24:12 +00:00
3.1 If you want, enable Googles Firebase Cloud Messaging:
`git apply ./scripts/enable-android-google-services.patch`
2020-10-10 10:22:08 +00:00
4. Debug with: `flutter run`
2020-02-23 09:12:31 +00:00
2020-10-10 10:22:08 +00:00
### Android
* Install CMake from the SDK Manager
* Install ninja:
2020-02-23 09:12:31 +00:00
```
sudo apt install ninja-build
```
2020-10-10 10:22:08 +00:00
* Build with: `flutter build apk`
### iOS / iPadOS
2021-07-24 17:03:06 +00:00
* Have a Mac with Xcode installed, and set up for Xcode-managed app signing
* If you want automatic app installation to connected devices, make sure you have Apple Configurator installed, with the Automation Tools (`cfgutil`) enabled
* Set a few environment variables
* FLUFFYCHAT_NEW_TEAM: the Apple Developer team that your certificates should live under
* FLUFFYCHAT_NEW_GROUP: the group you want App IDs and such to live under (ie: com.example.fluffychat)
* FLUFFYCHAT_INSTALL_IPA: set to `1` if you want the IPA to be deployed to connected devices after building, otherwise unset
* Run `./scripts/build-ios.sh`
2020-01-03 08:28:17 +00:00
### Web
2020-10-10 10:22:08 +00:00
* Enable web support in Flutter: https://flutter.dev/docs/get-started/web
2020-11-08 19:42:35 +00:00
* Build with:
```bash
./scripts/prepare-web.sh
2021-03-13 07:42:45 +00:00
flutter build web --release
2020-11-08 19:42:35 +00:00
```
2020-12-18 10:43:13 +00:00
* Optionally configure by serving a `config.json` at the same path as fluffychat.
An example can be found at `config.sample.json`. None of these
values have to exist, the ones stated here are the default ones. If you e.g. only want
to change the default homeserver, then only modify the `default_homeserver` key.
2020-10-10 10:22:08 +00:00
### Desktop (Linux, Windows, macOS)
* Enable Desktop support in Flutter: https://flutter.dev/desktop
2020-11-08 19:42:35 +00:00
* Build with one of these:
```bash
2020-10-10 10:22:08 +00:00
flutter build linux --release
flutter build windows --release
flutter build macos --release
```
2020-01-03 08:28:17 +00:00
2020-01-20 08:50:49 +00:00
2021-03-13 07:42:45 +00:00
# How to add translations for your language
2020-01-20 08:50:49 +00:00
2020-06-20 10:09:19 +00:00
You can use Weblate to translate the app to your language:
https://hosted.weblate.org/projects/fluffychat/
2021-01-20 16:27:07 +00:00
If you want to get your translated strings approved, please ask in our
<a href="https://matrix.to/#/#fluffychat:matrix.org" target="new">support room</a>!
2020-06-20 10:09:19 +00:00
2020-01-20 08:50:49 +00:00
1. Replace the non-translated string in the codebase:
```
Text("Hello world"),
```
with a method call:
```
2020-05-07 05:52:40 +00:00
Text(L10n.of(context).helloWorld),
2020-01-20 08:50:49 +00:00
```
and add the following import if missing:
2020-01-20 08:50:49 +00:00
```
import 'package:flutter_gen/gen_l10n/l10n.dart';
2020-01-20 08:50:49 +00:00
```
2. Add the string to `/lib/l10n/l10n_en.arb`:
2020-01-20 08:50:49 +00:00
(The following example need to be sorounded by the usual json `{}` and after the `@@locale` key)
Example A:
2020-01-20 08:50:49 +00:00
```
"helloWorld": "Hello World!",
"@helloWorld": {
"description": "The conventional newborn programmer greeting"
}
2020-01-20 08:50:49 +00:00
```
Example B:
```
"hello": "Hello {userName}",
"@hello": {
"description": "A message with a single parameter",
"placeholders": {
"userName": {
"type": “String”,
“example”: “Bob”
}
}
}
```
2020-02-23 09:06:01 +00:00
3. For testing just run a regular build without extras
2020-02-23 09:06:01 +00:00
# Android push notifications without FCM
Fluffychat has the ability to receive push notifications on android without FCM via the
[UnifiedPush](https://github.com/UnifiedPush) project, e.g. using gotify as push backend. As the project is still pretty new
there might still be some bugs, overall it seems to be working, though.
While UnifiedPush also supports p2p push via [NoProvider2Push](https://github.com/NoProvider2Push/android)
here the gotify setup will be outlined. Adapt re-write proxies accordingly, if you want to use a different push provider.
For self-hosted push with gotify you have to install and configure [gotify-server](https://github.com/gotify/server)
with [UnifiedPush](https://github.com/UnifiedPush/contrib/blob/main/providers/gotify.md) support.
2021-10-27 19:03:33 +00:00
Install the `Gotify-UP` app from fdroid. Next log into your gotify account and push notifications should work!
## Matrix-specific re-write proxy
Until [MSC2970](https://github.com/matrix-org/matrix-doc/pull/2970) is figured out we unfortunately
need another simple re-write proxy. By default the one at https://matrix.gateway.unifiedpush.org
2021-10-27 19:03:33 +00:00
is used, however you can easily self-host it. For that, please look at the [UnifiedPush Common-Proxies](https://github.com/UnifiedPush/common-proxies)
repository.
2020-02-23 09:06:01 +00:00
# Special thanks to
* <a href="https://github.com/fabiyamada">Fabiyamada</a> is a graphics designer from Brasil and has made the fluffychat logo and the banner. Big thanks for her great designs.
* <a href="https://github.com/advocatux">Advocatux</a> has made the Spanish translation with great love and care. He always stands by my side and supports my work with great commitment.
* Thanks to MTRNord and Sorunome for developing.
* Thanks to Mark for all his support and the chat background.
* Also thanks to all translators and testers! With your help, fluffychat is now available in more than 12 languages.
2021-01-20 18:53:19 +00:00
* <a href="https://github.com/googlefonts/noto-emoji/">Noto Emoji Font</a> for the awesome emojis.
* The Matrix Foundation for making and maintaining the [emoji translations](https://github.com/matrix-org/matrix-doc/blob/main/data-definitions/sas-emoji.json) used for emoji verification, licensed Apache 2.0