v_chat_sdk 0.2.2 v_chat_sdk: ^0.2.2 copied to clipboard
official sdk for vchat to impement chat system into new or exist flutter app
V_Chat_SDK Micro service #
Quick Review
Android
#
IOS
#
Don't forget to see the example attached to github here V_CHAT_SDK Example
Try the example apk
Example APK
Content
- About V_CHAT_SDK
- About Micro Service
- Features
- Requirements
- How V_CHAT_SDK works
- Android installation
- Ios installation
- public apis
- Support new language Or override
- How to get Backend code
- Common questions
About V_CHAT_SDK #
- this package which written in pure dart help you to add chat functionality
- unlimited text/image/video/record message and notifications
- to any existing or new flutter mobile project with any **back-end** service you use
- **V_CHAT_SDK** is easy way to integrate advanced real time message chat with 6 public api only π
- **V_CHAT_SDK** use **Node js** as backend service and **Firebase** for (push notifications only) message data base is **Mongo DB**
About Micro Service #
- 1- less load on your main server since chat has high traffic
- 2- They enable scale. Scalability is about more than the ability to handle more volume. Itβs also about the effort involved. Microservices make it easier to identify scaling bottlenecks and then resolve those bottlenecks at a per-microservice level.
- 3- They are relatively easy to build and maintain. Their single-purpose design means they can be built and maintained by smaller teams. Each team can be cross-functional while also specialise in a subset of the microservices in a solution.
Featurs #
Name | Android | Ios |
---|---|---|
online/offline | π | π |
textMessage/typing... | π | π |
voiceRecord/recording... | π | π |
saned video/file/images | π | π |
cache all media | π | π |
message notification | π | π |
mute/un mute notification | π | π |
block/un block users | π | π |
message status/read/unread | π | π |
smooth performance | π | π |
Requirements #
login system in your app and vps server for host node js you can buy it from any provider like digital ocean or hostinger
How V_CHAT_SDK works #
vchat connected with your backend service HOW!
when you register new user in your system you should call this public api
await VChatController.instance.register(VChatRegisterDto(
name: name,
password: password,
email: email,
userImage: null,
));
- i just need basic information like unique id and password and your image to identify user in rooms view
- email must be unique email is string you can pass phone number or any thing
- this api will save the user also in your node js data base to use it later in chats
- so when you want to start new chat just send me the peer email because its unique in vchat and your system so i can identify the user same as login
- v chat use access token and save it local it save login sections
- so by this way the two systems are in sync
- there are also other public api like change name or password will discussed later
- all chats and messages and files images videos saved on node js service
Android installation #
in android/app/src/main/AndroidManifest.xml add this permissions.
<uses-permission android:name="android.permission.INTERNET" />
<uses-permission android:name="android.permission.RECORD_AUDIO" />
<uses-permission android:name="android.permission.WRITE_EXTERNAL_STORAGE"/>
<uses-permission android:name="android.permission.READ_EXTERNAL_STORAGE"/>
then add in application
android:requestLegacyExternalStorage="true"
android:usesCleartextTraffic="true"
Example
<application
android:icon="@mipmap/ic_launcher"
android:label="v_chat_sdk_example"
android:requestLegacyExternalStorage="true"
android:usesCleartextTraffic="true">
(optional recommended) add fcm high notification priority
<meta-data
android:name="com.google.firebase.messaging.default_notification_channel_id"
android:value="high_importance_channel" />
under
<meta-data
android:name="flutterEmbedding"
android:value="2" />
finished with AndroidManifest
open android/build.gradle
update ext.kotlin_version to
this required by audioplayers package
ext.kotlin_version = '1.4.32'
this required by video_player
under
repositories {
add this
maven {
url 'https://google.bintray.com/exoplayer/'
}
maven { url 'https://plugins.gradle.org/m2/' }
}
under dependencies {
update all to
classpath 'com.android.tools.build:gradle:4.1.3'
classpath 'com.google.gms:google-services:4.3.5'
classpath "org.jetbrains.kotlin:kotlin-gradle-plugin:$kotlin_version"
then open android/app/build.gradle
compileSdkVersion 31
under
defaultConfig {
add or update
minSdkVersion 18
targetSdkVersion 31
multiDexEnabled true
Ios installation #
update and uncomment Podfile min version to 10.0 =>platform :ios, '10.0'
add this permissions on the ios/Runner/Info.plist
And see the example attached to the package if you face problem
<key>NSCameraUsageDescription</key>
<string>to allow user to take photo and video for his ads and upload it to server</string>
<key>NSMicrophoneUsageDescription</key>
<string>to allow user to take video with voice for more info and add it to his ads and upload it to server</string>
<key>NSPhotoLibraryAddUsageDescription</key>
<string>vchatsdk would like to save photos from the app chat to your gallery</string>
<key>NSPhotoLibraryUsageDescription</key>
<string>to allow user to select photo for his ads and upload it to server</string>
<key>UIBackgroundModes</key>
<array>
<string>fetch</string>
<string>remote-notification</string>
</array>
<key>NSAppTransportSecurity</key>
<dict>
<key>NSAllowsArbitraryLoads</key>
<true/>
</dict>
public apis and installion #
1- install #
first you need to await v chat init in main.dart
final GlobalKey<NavigatorState> navigatorKey = GlobalKey<NavigatorState>();
WidgetsFlutterBinding.ensureInitialized();
await VChatController.instance.init(
baseUrl: Uri.parse("http://10.0.2.2:3000"),
appName: "test_v_chat",
isUseFirebase: true,
lightTheme: vChatLightTheme,
darkTheme: vChatDarkTheme,
enableLogger: true,
navigatorKey: navigatorKey,
maxMediaUploadSize: 50 * 1000 * 1000, //~ 50 mb
);
- baseUrl => your node js server ip
- appName => to save files in internal storage with this folder name internalStorage/documents/{appName}
- isUseFirebase => set to true if firebase supported in your country and your project connected to firebase project
- lightTheme => overrideTheCustomTheme for light
- darkTheme => overrideTheCustomTheme for dark
- enableLogger => if true vchat will print the warning in console in release mode it will disable automatically
- navigatorKey => add this key also in MaterialApp
- maxMediaUploadSize => optional to set max files in chat
MaterialApp(
debugShowCheckedModeBanner: false,
navigatorKey: navigatorKey,
builder: BotToastInit(),
navigatorObservers: [BotToastNavigatorObserver()],
home: SplashScreen(),
);
don't forget to enable BotToast in MaterialApp and add it in your pubspec.yaml
2- Register #
First register on your system (your backend) then register in vChat
try{
await VChatController.instance.register(
VChatRegisterDto(
name: name,
userImage: imagePath == null ? null : File(imagePath!),
email: email,
password: password,
),
);
} on VChatSdkException catch(err){
// handle vchat exception here
rethrow;
}
if your system allow users to register without image pass it null
it will user the default image you can change it in backend public/profile/default_user_image.png
name => user full name
Email => can be phone number or any unique id not validation on it
Note this function throw this exceptions
1- User already in v chat data base
2- No internet connection
2- Login #
try {
await VChatController.instance
.login(VChatLoginDto(email: email, password: password));
} on VChatSdkException catch (err) {
//handle v chat login exception
rethrow;
}
Note this function throw this exceptions
1- User not in v chat data base Or wrong password
2- No internet connection
3- set user online #
make sure to use this function only if user already authorized in vchat system and your system
other will throw "You must login or register to v chat first delete the app and login again !"
wrap it with if condition
if(isAuth){
// make sure to auth
VChatController.instance.bindChatControllers();
}
call this method in home page because it will make the user online and start notifications service
4- create Single Chat #
this method will show alert dialog if there is no rooms and ask for first message
if there chat will open the change page direct
try {
await VChatController.instance
.createSingleChat(ctx: context, peerEmail: widget.user.email);
} on VChatSdkException catch (err) {
//handle create chat exceptions
rethrow;
}
peerEmail => is the unique identifier that you pass to vchat when register
this function throw
1- you cant start chat if you start chat your self
2- Exception if peer Email Not in v chat Data base ! so first you must (migrate all users only if already in production and need to add chat) new project all will be fine
3- No internet connection
4- change user name #
when user change his name then you need to update his name in v chat also to change his name in rooms
try {
await VChatController.instance.updateUserName(name: "new name");
} on VChatSdkException catch (err) {
//handle Errors
}
5- change user password #
try {
await VChatController.instance.updateUserPassword(newPassword: "new",oldPassword: "old");
} on VChatSdkException catch (err) {
//handle Errors
}
6- change user image #
try {
await VChatController.instance.updateUserImage( imagePath: file.path!);
} on VChatSdkException catch (err) {
//handle Errors
}
7- stop/enable notifiactions #
await VChatController.instance.stopAllNotification();
await VChatController.instance.enableAllNotification();
8- logOut #
await VChatController.instance.logOut();
Support new language Or override . #
to support new language create new class and extend VChatLookupString
and override all
class ArEg extends VChatLookupString {
@override
String areYouSure() => "ΩΩ Ψ§ΩΨͺ ΩΨͺΨ§ΩΨ―Ψ";
@override
String cancel() => "Ψ§ΩΨΊΨ§Ψ‘";
@override
String chatHasBeenClosed() => "Ψ§ΩΨͺΩΨͺ Ψ§ΩΩ
ΨΨ§Ψ―Ψ«Ω !";
then in main.dart after vchat.init define the new language
VChatController.instance.setLocaleMessages(languageCode: "ar", countryCode: "EG", lookupMessages: ArEg());
by default english Us and arabic Eg supported you can override it with the same way
when you change app language vchat will automatic change but you must put the countryCode
How to get Backend code #
you can get it from
Envato
iam available for freelance work on this project integration or modifications
contact me on hatemragap5@gmail.com
Skype live:.cid.607250433850e3a6
Backend Installation #
create new ubuntu server and connect it as root
copy un zip source/v_chat_sdk_backend/dist/src and replace firebase-adminsdk.json by your file
to get this file create or open existing firebase account
and navigate to project setting then service accounts
then generate new private key select Node.js
rename this file to firebase-adminsdk.json it should with same name and in same folder
then your project is ready now to upload ...
install node js on ubuntu you can do by your way we need node v 14.17.1
login as root using ssl the run the following
sudo apt update
sudo apt install nodejs
sudo apt install npm
install nvm to update node js
sudo apt install curl
curl https://raw.githubusercontent.com/creationix/nvm/master/install.sh | bash
source ~/.profile
nvm install 14.17.1
make sure you install node js v 14.17.1 by run node -v
now install mongo db and start it
wget -qO - https://www.mongodb.org/static/pgp/server-5.0.asc | sudo apt-key add -
sudo apt-get install gnupg
wget -qO - https://www.mongodb.org/static/pgp/server-5.0.asc | sudo apt-key add -
echo "deb [ arch=amd64,arm64 ] https://repo.mongodb.org/apt/ubuntu focal/mongodb-org/5.0 multiverse" | sudo tee /etc/apt/sources.list.d/mongodb-org-5.0.list
sudo apt-get update
sudo apt-get install -y mongodb-org
sudo systemctl start mongod
make sure mongo db run
sudo systemctl status mongodb
install pm2 to run the server
npm i -g pm2
upload the source file to server (recommended to use FileZilla)
after un zip the file
open terminal here and run
1- run sudo npm i
2- node app.js
if it say server run on port 3000 and mongo db connected then all installation has been done
now we need to run pm2 exit the process by
CTRL+C from keyboard
then pm2 start app.js
All Done now !
if any problem contact me