enx_flutter_plugin 2.3.18 enx_flutter_plugin: ^2.3.18 copied to clipboard
EnableX Flutter Plugin allows developers to implement real-time communication channels such as audio, video, and text chat in their applications on iOS and Android Platforms.
import 'dart:convert';
import 'package:enx_flutter_plugin/base.dart';
import 'package:enx_flutter_plugin/enx_player_widget.dart';
import 'package:flutter/material.dart';
import 'dart:async';
import 'package:flutter/services.dart';
import 'package:enx_flutter_plugin/enx_flutter_plugin.dart';
import 'package:fluttertoast/fluttertoast.dart';
import 'package:http/http.dart' as http;
import 'call_ui.dart';
void main() {
// WidgetsFlutterBinding.ensureInitialized();
runApp(MaterialApp(
title: "Sample App",
debugShowCheckedModeBanner: false,
theme: ThemeData(
brightness: Brightness.light,
primaryColor: Colors.deepPurple),
home: MyApp(),
/* routes: <String, WidgetBuilder>{
'/Conference': (context) => MyConfApp(
token: _State.token,
)
},*/
));
// var serverContext = SecurityContext()
// ..useCertificateChain('/Users/mac/Desktop/Vcloudx/Demo_Apps/enx_flutter_plugin/example/cert/localhost.crt')
// ..usePrivateKey('/Users/mac/Desktop/Vcloudx/Demo_Apps/enx_flutter_plugin/example/cert/localhost.key');
//
// // Create HTTP server
// var server = await HttpServer.bindSecure(
// InternetAddress.anyIPv4,
// 8444, // Specify your desired HTTPS port
// serverContext,
// );
//
// // Start listening for requests
// await for (var request in server) {
// // Handle HTTP request
// if (request.uri.path == '/') {
// // Run Flutter app
// runApp(MaterialApp(
// title: "Sample App",
// debugShowCheckedModeBanner: false,
// theme: ThemeData(
// brightness: Brightness.light,
// primaryColor: Colors.deepPurple),
// home: MyApp(),
// /* routes: <String, WidgetBuilder>{
// '/Conference': (context) => MyConfApp(
// token: _State.token,
// )
// },*/
// ));
// } else {
// // Serve other resources (e.g., assets, APIs)
// // Handle other requests as needed
// }
//
// // Send response
// request.response.write('Hello, HTTPS!');
// await request.response.close();
// }
// HttpRequest.defaultBrowserCredentialsMode = false;
}
class MyApp extends StatefulWidget {
@override
_State createState() => _State();
}
class _State extends State<MyApp> {
/*Your webservice host URL, Keet the defined host when kTry = true */
static const String kBaseURL = "https://meeting-dev4.enablex.io/";
//"https://meeting-staging.enablex.io/";
//https://meeting-demo-qa.enablex.io/
/* To try the app with Enablex hosted service you need to set the kTry = true */
static bool kTry = false;
/*Use enablec portal to create your app and get these following credentials*/
/*Use enablec portal to create your app and get these following credentials*/
static const String kAppId = "5ef5b31690ef80b4300b0bd2";
static const String kAppkey = "uJehyWaAu4uvyTupeJyJuHu6ygyYaGu2yzuq";
bool isPreview=false;
var header = (kTry)
? {
"x-app-id": kAppId,
"x-app-key": kAppkey,
"Content-Type": "application/json"
}
: {"Content-Type": "application/json", "Access-Control-Allow-Origin": "meeting-dev2.enablex.io",
"Access-Control-Allow-Methods": "POST, GET, OPTIONS, PUT, DELETE, HEAD",};
TextEditingController nameController = TextEditingController();
TextEditingController roomIdController = TextEditingController();
static String token = "";
String role = '', roomID = '';
Future<void> createRoomvalidations() async {
if (nameController.text.isEmpty) {
isValidated = false;
Fluttertoast.showToast(
msg: "Please Enter your name",
toastLength: Toast.LENGTH_SHORT,
gravity: ToastGravity.BOTTOM,
backgroundColor: Colors.red,
textColor: Colors.white,
fontSize: 16.0);
} else {
isValidated = true;
}
}
Future<void> joinRoomValidations() async {
// await _handleCameraAndMic();
if (nameController.text.isEmpty) {
Fluttertoast.showToast(
msg: "Please Enter your name",
toastLength: Toast.LENGTH_SHORT,
gravity: ToastGravity.BOTTOM,
backgroundColor: Colors.red,
textColor: Colors.white,
fontSize: 16.0);
isValidated = false;
} else if (roomIdController.text.isEmpty) {
Fluttertoast.showToast(
msg: "Please Enter your roomId",
toastLength: Toast.LENGTH_SHORT,
gravity: ToastGravity.BOTTOM,
backgroundColor: Colors.red,
textColor: Colors.white,
fontSize: 16.0);
isValidated = false;
} else {
isValidated = true;
}
}
Future<String> createRoom() async {
var response = await http.post(
Uri.parse(
kBaseURL + "createRoom"), // replace FQDN with Your Server API URL
headers: header);
print('sckasas');
print(response);
if (response.statusCode == 200) {
Map<String, dynamic> user = jsonDecode(response.body);
Map<String, dynamic> room = user['room'];
setState(() => roomIdController.text = room['room_id'].toString());
print(response.body);
return response.body;
} else {
throw Exception('Failed to load post');
}
}
Future<String> getPin() async {
var response = await http.post(
Uri.parse(
kBaseURL + 'getRoomByPin'), // replace FQDN with Your Server API URL
headers: {"Content-Type": "application/json"},
body: jsonEncode({"pin": roomIdController.text}));
print('sckasas');
print(response.body);
if (response.statusCode == 200) {
Map<String, dynamic> user = jsonDecode(response.body);
// Map<String, dynamic> room = user['room'];
setState(() {
roomID = user['room_id'].toString();
role = user['role'].toString();
createToken();
});
print(response.body);
return response.body;
} else {
throw Exception('Failed to load post');
}
}
Future<String?> createToken() async {
var value = {
'user_ref': "2236",
"roomId": roomID,
"role": role,
"name": nameController.text
};
print(jsonEncode(value));
var response = await http.post(
Uri.parse(
kBaseURL + "createToken"), // replace FQDN with Your Server API URL
headers: header,
body: jsonEncode(value));
print(kBaseURL);
if (response.statusCode == 200) {
print(response.body);
Map<String, dynamic> user = jsonDecode(response.body);
setState(() => token = user['token'].toString());
print('apptoken${token}');
if (token != 'null' && token.isNotEmpty) {
Navigator.push(
context,
MaterialPageRoute(
builder: (context) => CallUi(
token: token,
)),
);
// Navigator.pushNamed(context, '/Conference');
return response.body;
}
} else {
throw Exception('Failed to load post');
}
return null;
}
TextStyle style = TextStyle(fontFamily: 'Montserrat', fontSize: 16.0);
bool isValidated = false;
bool isPrecallTest = true;
@override
void initState() {
super.initState();
}
@override
Widget build(BuildContext context) {
final usernameField = TextField(
obscureText: false,
style: style,
controller: nameController,
decoration: InputDecoration(
contentPadding: EdgeInsets.fromLTRB(20.0, 15.0, 20.0, 15.0),
hintText: "Username",
border:
OutlineInputBorder(borderRadius: BorderRadius.circular(32.0))),
);
final roomIdField = TextField(
obscureText: false,
controller: roomIdController,
style: style,
decoration: InputDecoration(
contentPadding: EdgeInsets.fromLTRB(20.0, 15.0, 20.0, 15.0),
hintText: "Enter pin",
border:
OutlineInputBorder(borderRadius: BorderRadius.circular(32.0))),
);
/* final createRoomButon = Material(
elevation: 5.0,
borderRadius: BorderRadius.circular(30.0),
color: Colors.deepPurple,
child: MaterialButton(
// minWidth: MediaQuery.of(context).size.width / 2,
minWidth: 100,
padding: EdgeInsets.fromLTRB(20.0, 15.0, 20.0, 15.0),
onPressed: () {
createRoomvalidations();
if (isValidated) {
createRoom();
}
},
child: Text("Create Room",
textAlign: TextAlign.center,
style: style.copyWith(
color: Colors.white, fontWeight: FontWeight.normal)),
),
);*/
final joinButon = Material(
elevation: 5.0,
borderRadius: BorderRadius.circular(30.0),
color: Colors.deepPurple,
child: MaterialButton(
minWidth: 100,
// minWidth: MediaQuery.of(context).size.width / 2,
padding: EdgeInsets.fromLTRB(20.0, 15.0, 20.0, 15.0),
onPressed: () {
print('sdckjcs');
joinRoomValidations();
if (isValidated) {
print('ityroriyori');
getPin();
// createRoom();
}
},
child: Text("Join",
textAlign: TextAlign.center,
style: style.copyWith(
color: Colors.white, fontWeight: FontWeight.normal)),
),
);
final precallTestButon = Material(
elevation: 5.0,
borderRadius: BorderRadius.circular(30.0),
color: Colors.deepPurple,
child: MaterialButton(
minWidth: 100,
// minWidth: MediaQuery.of(context).size.width / 2,
padding: EdgeInsets.fromLTRB(20.0, 15.0, 20.0, 15.0),
onPressed: () {
if (isPrecallTest)
isPrecallTest = false;
else
isPrecallTest = true;
Map<String, dynamic> map = {
'testDurationDataThroughput': 2,
'testDurationVideoBandwidth': 30,
'testDurationAudioBandwidth': 30,
'stop': isPrecallTest,
'regionId': ['IN'],
'testNames': ['microphone'],
};
print(map);
Map<String, dynamic> map2 = {
'minWidth': 320,
'minHeight': 180,
'maxWidth': 1280,
'maxHeight': 720
};
// EnxRtc.clientDiagnostics(map);
Map<String, dynamic> map1 = {
'audio': true,
'video': true,
'data': true,
'framerate': 30,
'audioMuted': false,
'videoMuted': false,
'name': 'flutter',
'videoSize': map2
};
EnxRtc.getPreview();
setState(() {
isPreview=true;
});
// _addEnxrtcEventHandlers();
},
child: Text("Precall Test",
textAlign: TextAlign.center,
style: style.copyWith(
color: Colors.white, fontWeight: FontWeight.normal)),
),
);
return Scaffold(
appBar: AppBar(
title: Text('Sample App'),
),
body: Padding(
padding: EdgeInsets.all(10),
child: ListView(
children: <Widget>[
Container(
alignment: Alignment.center,
padding: EdgeInsets.all(10),
child: Text(
'Enablex',
style: TextStyle(
color: Colors.redAccent,
fontWeight: FontWeight.w500,
fontSize: 30),
)),
Container(
alignment: Alignment.center,
padding: EdgeInsets.all(10),
child: Text(
'Welcome !',
style: TextStyle(fontSize: 20),
)),
Container(
padding: EdgeInsets.all(10),
child: usernameField,
),
Container(
padding: EdgeInsets.fromLTRB(10, 10, 10, 0),
child: roomIdField),
Container(
alignment: Alignment.center,
height: 100,
width: 100,
child: Row(
children: <Widget>[
/* Expanded(
flex: 1,
child: Padding(
padding: EdgeInsets.all(10),
child: createRoomButon)),*/
Expanded(
flex: 1,
child: Padding(
padding: EdgeInsets.all(10), child: joinButon)),
Expanded(
flex: 1,
child: Padding(
padding: EdgeInsets.all(10),
child: precallTestButon)),
],
)),
isPreview? Container(
height: 120,
width: 500,
child: EnxPlayerWidget(0, local: true,width: 500, height: 100,mScalingType: ScalingType.SCALE_ASPECT_FILL,),
):Container(height: 120,
width: 120,color: Colors.red,),
],
)));
}
void initEnxRtc() {
// EnxRtc.enxRtc();
}
}