This project is an implementation of the flutter_chat_types, flutter_chat_ui packages based on a backend created with Supabase.
Actively maintained, community-driven Supabase BaaS for chat applications with an optional chat UI.
Have you ever wanted to implement a chat in your application? Do you think it's difficult and complex?
Try this, thanks to the magnificent Supabase platform and the Flutter Chat UI package, you can achieve it in just a few minutes and effortlessly.
Flyer Chat is a platform for creating in-app chat experiences using Flutter. This repository contains Supabase BaaS implementation for Flutter. We are also working on our more advanced SaaS and self-hosted solutions.
-
Free, open-source and community-driven. We offer no paid plugins and strive to create an easy-to-use, almost drop-in chat experience for any application. Contributions are more than welcome! Please read our Contributing Guide.
-
Chat UI agnostic. You can choose the chat UI you prefer. But if you don't have one, we provide our own free and open-source Flutter Chat UI, which can be used to create a working chat in minutes.
-
Easy to use. Returns streams of data for messages, rooms and users. Supabase Security Rules control access to the data. Check our documentation for the info.
The example project that you find in the package repository allows you to have a cross-platform chat app in just a few minutes.
Dart >=2.19.0
and Flutter >=3.0.0
, Supabase project.
- Install Supabase CLI: Official documentation
- Open your bash
- Login with Supabase:
supabase login
- Create new project (For example
demo-chat
):
supabase projects create demo-chat
- Select your organization
- Select an region
- Insert a secure password for new Postgres database (Save this in a secure location)
- Obtain your
REFERENCE ID
(After command select your project, for exampledemo-chat
):
supabase projects list
- Obtain your
anon
key (After command select your project, for exampledemo-chat
):
supabase projects api-keys
- Edit
example project
fileexample/lib/supabase_options.dart
, insert your project{{your_project_reference_id}}
and{{supabase_anon_key}}
Inside the example project (example/utils
) there is a script, running the latter will automatically configure the Supabase project, creating tables, security rules, buckets and everything that is necessary for the example project to function.
In order to run the script you need to be aware of the following information about your Supabase project:
host
: Project hostport
: Database portdatabase
: Database nameuser
: Database userpassword
: Database password
This information, except the password which is provided only during the creation of the database (if necessary, you can use the password reset function of your database to obtain it), can be found very easily from the Dashboard of your Supabase project:
Below are the commands for running the scripts (During execution you will be asked for the password for your database user):
Required
psql
installed -> Official documentation
cd ./example/utils/
./prepare.sh -h "your-postgres-host" -p your-postgres-port -d "your-postgres-database-name" -U "your-postgres-user"
cd .\example\utils\
.\prepare.ps1 -hostname "your-postgres-host" -port your-postgres-port -database "your-postgres-database-name" -user "your-postgres-user"
after running the database preparation script. you need to change the database schema exposure setting by adding the chats
schema (from the supabase dashboard):
Optional (Only for test): Disable email verification and save the configuration (To speed up testing and allow user registration in just one click, it is advisable to disable mailbox verification):
Read our documentation or see the example project. To run the example project you need to have your own Supabase project and then follow Add Supabase to your Flutter app, override example/lib/supabase_options.dart
, don't commit it though 😉
After all of this is done you will need to register a couple of users and the example app will automatically suggest email and password on the register screen, default password is Qawsed1-
. To set up Supabase Security Rules so users can see only the data they should see, continue with our documentation.
This package implements some purely logical widgets (Without implementation of a specific UI). These wedgets make it easy to implement some chat-related logic without any effort.
This widget should be placed in the widget tree as soon as possible, this is because this component is responsible for checking and updating the status of the user who logged into the app. When the app is in the foreground other users are notified of the online status, vice versa when the app is closed.
@override
Widget build(BuildContext context) =>
MaterialApp(
...
home: const UserOnlineStateObserver(
child: RoomsPage(),
),
);
This server widget to get the status of a specific user. It can be used, for example, to animate a user's avatar with an LED to indicate their online/offline status.
@override
Widget build(BuildContext context) {
return UserOnlineStatusWidget(
uid: user.id,
builder: (status) {
//Use status == UserOnlineStatus.online to animate your avatar
},
);
}
The preparation script automatically configures the security rules on the database tables and storage buckets, below is a summary of the rules that are applied:
INSERT
: Nobody, this table is populate by trigger on auth.users.SELECT
: All users authenticated.UPDATE
: Only the user himself.DELETE
: Nobody.
INSERT
: All users authenticated.SELECT
: All users who are members of the chat room.UPDATE
: All users who are members of the chat room.DELETE
: All users who are members of the chat room.
INSERT
: All users who are members of the chat room.SELECT
: All users who are members of the chat room.UPDATE
: All users who are members of the chat room.DELETE
: All users who are members of the chat room.
INSERT
: All users who are members of the chat room.SELECT
: All users who are members of the chat room.UPDATE
: All users who are members of the chat room.DELETE
: All users who are members of the chat room.
INSERT
: Only the user himself.SELECT
: All users authenticated.UPDATE
: Only the user himself.DELETE
: Only the user himself.
Please read our Contributing Guide before submitting a pull request to the project.
Flyer Chat has adopted the Contributor Covenant as its Code of Conduct, and we expect project participants to adhere to it. Please read the full text so that you can understand what actions will and will not be tolerated.
Licensed under the Apache License, Version 2.0
Below are the features implemented for each platform:
Feature | Web | Android | iOS | Windows | macOS | Linux |
---|---|---|---|---|---|---|
Signup | ✅ | ✅ | 🟡 | ✅ | 🟡 | 🟡 |
SignIn | ✅ | ✅ | 🟡 | ✅ | 🟡 | 🟡 |
Rooms list screen | ✅ | ✅ | 🟡 | ✅ | 🟡 | 🟡 |
Create direct room | ✅ | ✅ | 🟡 | ✅ | 🟡 | 🟡 |
Create group room | 🚧 | 🚧 | 🚧 | 🚧 | 🚧 | 🚧 |
Create channel room | 🚧 | 🚧 | 🚧 | 🚧 | 🚧 | 🚧 |
Chat screen | ✅ | ✅ | 🟡 | ✅ | 🟡 | 🟡 |
Search room | ✅ | ✅ | 🟡 | ✅ | 🟡 | 🟡 |
Search message | 🚧 | 🚧 | 🚧 | 🚧 | 🚧 | 🚧 |
Search user | ✅ | ✅ | 🟡 | ✅ | 🟡 | 🟡 |
Upload image | ✅ | ✅ | 🟡 | ✅ | 🟡 | 🟡 |
Preview image message | ✅ | ✅ | 🟡 | ✅ | 🟡 | 🟡 |
Upload file | ✅ | ✅ | 🟡 | ✅ | 🟡 | 🟡 |
Download file | ✅ | ✅ | 🟡 | ✅ | 🟡 | 🟡 |
Users online status | ✅ | ✅ | 🟡 | ✅ | 🟡 | 🟡 |
Chat messages pagination | ✅ | ✅ | 🟡 | ✅ | 🟡 | 🟡 |
Users pagination | ✅ | ✅ | 🟡 | ✅ | 🟡 | 🟡 |
Users typing status | ✅ | ✅ | 🟡 | ✅ | 🟡 | 🟡 |
- ✅ Tested
- 🟡 Supported but not tested
- 🚧 Planned
Below are some activities to complete to have a more complete and optimized project also for use cases in larger projects.
- Add the missing triggers
- Error handling
- Chat room groups
- Chat room channels
- Sending audio messages
- Improve documentation