import 'dart:convert'; import 'package:Envelope/components/flash_message.dart'; import 'package:flutter/material.dart'; import 'package:flutter_dotenv/flutter_dotenv.dart'; import 'package:http/http.dart' as http; import 'package:pointycastle/export.dart'; import 'package:sqflite/sqflite.dart'; import '/models/conversation_users.dart'; import '/models/conversations.dart'; import '/models/my_profile.dart'; import '/utils/encryption/aes_helper.dart'; import '/utils/storage/database.dart'; import '/utils/storage/session_cookie.dart'; Future updateConversation(Conversation conversation, { includeUsers = true } ) async { String sessionCookie = await getSessionCookie(); Map conversationJson = await conversation.payloadJson(includeUsers: includeUsers); var x = await http.put( Uri.parse('${dotenv.env["SERVER_URL"]}api/v1/auth/conversations'), headers: { 'Content-Type': 'application/json; charset=UTF-8', 'cookie': sessionCookie, }, body: jsonEncode(conversationJson), ); // TODO: Handle errors here print(x.statusCode); } // TODO: Refactor this function Future updateConversations() async { RSAPrivateKey privKey = await MyProfile.getPrivateKey(); // try { var resp = await http.get( Uri.parse('${dotenv.env["SERVER_URL"]}api/v1/auth/conversations'), headers: { 'cookie': await getSessionCookie(), } ); if (resp.statusCode != 200) { throw Exception(resp.body); } List conversations = []; List conversationsDetailIds = []; List conversationsJson = jsonDecode(resp.body); if (conversationsJson.isEmpty) { return; } for (var i = 0; i < conversationsJson.length; i++) { Conversation conversation = Conversation.fromJson( conversationsJson[i] as Map, privKey, ); conversations.add(conversation); conversationsDetailIds.add(conversation.id); } Map params = {}; params['conversation_detail_ids'] = conversationsDetailIds.join(','); var uri = Uri.parse('${dotenv.env["SERVER_URL"]}api/v1/auth/conversation_details'); uri = uri.replace(queryParameters: params); resp = await http.get( uri, headers: { 'cookie': await getSessionCookie(), } ); if (resp.statusCode != 200) { throw Exception(resp.body); } final db = await getDatabaseConnection(); List conversationsDetailsJson = jsonDecode(resp.body); for (var i = 0; i < conversationsDetailsJson.length; i++) { var conversationDetailJson = conversationsDetailsJson[i] as Map; var conversation = findConversationByDetailId(conversations, conversationDetailJson['id']); conversation.twoUser = AesHelper.aesDecrypt( base64.decode(conversation.symmetricKey), base64.decode(conversationDetailJson['two_user']), ) == 'true'; if (conversation.twoUser) { MyProfile profile = await MyProfile.getProfile(); final db = await getDatabaseConnection(); List> maps = await db.query( 'conversation_users', where: 'conversation_id = ? AND user_id != ?', whereArgs: [ conversation.id, profile.id ], ); if (maps.length != 1) { throw ArgumentError('Invalid user id'); } conversation.name = maps[0]['username']; } else { conversation.name = AesHelper.aesDecrypt( base64.decode(conversation.symmetricKey), base64.decode(conversationDetailJson['name']), ); } await db.insert( 'conversations', conversation.toMap(), conflictAlgorithm: ConflictAlgorithm.replace, ); List usersData = conversationDetailJson['users']; for (var i = 0; i < usersData.length; i++) { ConversationUser conversationUser = ConversationUser.fromJson( usersData[i] as Map, base64.decode(conversation.symmetricKey), ); await db.insert( 'conversation_users', conversationUser.toMap(), conflictAlgorithm: ConflictAlgorithm.replace, ); } } // } catch (SocketException) { // return; // } } Future uploadConversation(Conversation conversation, BuildContext context) async { String sessionCookie = await getSessionCookie(); Map conversationJson = await conversation.payloadJson(); var resp = await http.post( Uri.parse('${dotenv.env["SERVER_URL"]}api/v1/auth/conversations'), headers: { 'Content-Type': 'application/json; charset=UTF-8', 'cookie': sessionCookie, }, body: jsonEncode(conversationJson), ); if (resp.statusCode != 200) { showMessage('Failed to create conversation', context); } }