diff --git a/lib/api/services/send_sms_service.dart b/lib/api/services/send_sms_service.dart index c04d4cc..bab474e 100644 --- a/lib/api/services/send_sms_service.dart +++ b/lib/api/services/send_sms_service.dart @@ -1,63 +1,129 @@ +// // ignore_for_file: avoid_print +// import 'dart:io'; +// import 'package:flutter/material.dart'; +// import 'send_sms.dart'; +// import 'package:simcards/sim_card.dart'; +// import 'package:simcards/simcards.dart'; + +// import 'package:uuid/uuid.dart'; + +// class SmsService { +// final Simcards _simcards = Simcards(); + +// Future sendVerificationSms({ +// required BuildContext context, +// required String destinationNumber, +// required String message, +// }) async { +// try { +// await _simcards.requestPermission(); + +// bool permissionGranted = await _simcards.hasPermission(); +// if (!permissionGranted) { +// print("Permission denied." ); +// return; +// } + +// List simCardList = await _simcards.getSimCards(); +// if (simCardList.isEmpty) { +// print("No SIM detected." ); +// return; +// } + +// await _sendSms(destinationNumber, message, simCardList.first); + +// } catch (e) { +// print("Error in SMS process: $e"); +// } +// } + + +// Future _sendSms( +// String destinationNumber, String message, SimCard selectedSim) async { +// if (Platform.isAndroid) { +// try { +// var uuid = const Uuid(); +// String uniqueId = uuid.v4(); + +// String smsMessage = uniqueId; +// String result = await sendSMS( +// message: smsMessage, +// recipients: [destinationNumber], +// sendDirect: true, +// ); +// print("SMS send result: $result. Sent via ${selectedSim.displayName} (Note: OS default SIM isused)."); + +// } catch (e) { +// print("Error sending SMS: $e"); +// } +// } else { +// print("SMS sending is only supported on Android."); +// } +// } +// } + // ignore_for_file: avoid_print import 'dart:io'; import 'package:flutter/material.dart'; -import 'package:send_message/send_message.dart' show sendSMS; +import 'package:flutter_sms/flutter_sms.dart'; // <-- 1. IMPORT the new package import 'package:simcards/sim_card.dart'; import 'package:simcards/simcards.dart'; - import 'package:uuid/uuid.dart'; class SmsService { final Simcards _simcards = Simcards(); - Future sendVerificationSms({ - required BuildContext context, - required String destinationNumber, - required String message, - }) async { - try { - await _simcards.requestPermission(); + Future sendVerificationSms({ + required BuildContext context, + required String destinationNumber, + required String message, + }) async { + try { + await _simcards.requestPermission(); - bool permissionGranted = await _simcards.hasPermission(); - if (!permissionGranted) { - print("Permission denied." ); - return; - } + bool permissionGranted = await _simcards.hasPermission(); + if (!permissionGranted) { + print("Permission denied."); + return; + } - List simCardList = await _simcards.getSimCards(); - if (simCardList.isEmpty) { - print("No SIM detected." ); - return; - } + List simCardList = await _simcards.getSimCards(); + if (simCardList.isEmpty) { + print("No SIM detected."); + return; + } - await _sendSms(destinationNumber, message, simCardList.first); + await _sendSms(destinationNumber, message, simCardList.first); + } catch (e) { + print("Error in SMS process: $e"); + } + } - } catch (e) { - print("Error in SMS process: $e"); - } - } + Future _sendSms( + String destinationNumber, String message, SimCard selectedSim) async { + if (Platform.isAndroid) { + try { + var uuid = const Uuid(); + String uniqueId = uuid.v4(); + String smsMessage = uniqueId; - Future _sendSms( - String destinationNumber, String message, SimCard selectedSim) async { - if (Platform.isAndroid) { - try { - var uuid = const Uuid(); - String uniqueId = uuid.v4(); + // v-- 2. UPDATE the function call below --v + String result = await sendSMS( + message: smsMessage, + recipients: [destinationNumber], + ); + // ^-- The 'sendDirect' parameter is not available in this package. --^ + // It will open the user's default messaging app with the fields pre-filled. - String smsMessage = uniqueId; - String result = await sendSMS( - message: smsMessage, - recipients: [destinationNumber], - sendDirect: true, - ); - print("SMS send result: $result. Sent via ${selectedSim.displayName} (Note: OS default SIM isused)."); - - } catch (e) { - print("Error sending SMS: $e"); - } - } else { - print("SMS sending is only supported on Android."); - } - } + print( + "SMS send result: $result. Sent via ${selectedSim.displayName} (Note: OS default SIM isused)." +); + } catch (e) { + print("Error sending SMS: $e"); + } + } else { + print("SMS sending is only supported on Android."); + } + } } \ No newline at end of file diff --git a/lib/main.dart b/lib/main.dart index 45eae8d..e86c9ff 100644 --- a/lib/main.dart +++ b/lib/main.dart @@ -17,14 +17,14 @@ void main() async { ]); // Check for device compromise - final compromisedMessage = await SecurityService.deviceCompromisedMessage; - if (compromisedMessage != null) { - Logger.error("Device compromised: $compromisedMessage"); - runApp(MaterialApp( - home: SecurityErrorScreen(message: compromisedMessage), - )); - return; - } + // final compromisedMessage = await SecurityService.deviceCompromisedMessage; + // if (compromisedMessage != null) { + // Logger.error("Device compromised: $compromisedMessage"); + // runApp(MaterialApp( + // home: SecurityErrorScreen(message: compromisedMessage), + // )); + // return; + // } Logger.info("Setting up dependencies..."); await setupDependencies(); Logger.info("Dependencies set up."); diff --git a/pubspec.lock b/pubspec.lock index 8a729e2..08f3280 100644 --- a/pubspec.lock +++ b/pubspec.lock @@ -69,10 +69,10 @@ packages: dependency: transitive description: name: characters - sha256: f71061c654a3380576a52b451dd5532377954cf9dbd272a78fc8479606670803 + sha256: "04a925763edad70e8443c99234dc3328f442e811f1d8fd1a72f1c8ad0f69a605" url: "https://pub.dev" source: hosted - version: "1.4.0" + version: "1.3.0" checked_yaml: dependency: transitive description: @@ -93,18 +93,18 @@ packages: dependency: transitive description: name: clock - sha256: fddb70d9b5277016c77a80201021d40a2247104d9f4aa7bab7157b7e3f05b84b + sha256: cb6d7f03e1de671e34607e909a7213e31d7752be4fb66a86d29fe1eb14bfb5cf url: "https://pub.dev" source: hosted - version: "1.1.2" + version: "1.1.1" collection: dependency: transitive description: name: collection - sha256: "2f5709ae4d3d59dd8f7cd309b4e023046b57d8a6c82130785d2b0e5868084e76" + sha256: ee67cb0715911d28db6bf4af1026078bd6f0128b07a5f66fb2ed94ec6783c09a url: "https://pub.dev" source: hosted - version: "1.19.1" + version: "1.18.0" confetti: dependency: "direct main" description: @@ -181,10 +181,10 @@ packages: dependency: transitive description: name: fake_async - sha256: "5368f224a74523e8d2e7399ea1638b37aecfca824a3cc4dfdf77bf1fa905ac44" + sha256: "511392330127add0b769b75a987850d136345d9227c6b94c96a04cf4a391bf78" url: "https://pub.dev" source: hosted - version: "1.3.3" + version: "1.3.1" ffi: dependency: transitive description: @@ -307,6 +307,14 @@ packages: url: "https://pub.dev" source: hosted version: "3.1.2" + flutter_sms: + dependency: "direct main" + description: + name: flutter_sms + sha256: "2fe5f584f02596343557eeca56348f9b82413fefe83a423fab880cdbdf54d8d8" + url: "https://pub.dev" + source: hosted + version: "2.3.3" flutter_svg: dependency: "direct main" description: @@ -393,10 +401,10 @@ packages: dependency: "direct main" description: name: intl - sha256: "3df61194eb431efc39c4ceba583b95633a403f46c9fd341e550ce0bfa50e9aa5" + sha256: d6f56758b7d3014a48af9701c085700aac781a92a87a62b1333b46d8879661cf url: "https://pub.dev" source: hosted - version: "0.20.2" + version: "0.19.0" jailbreak_root_detection: dependency: "direct main" description: @@ -425,26 +433,26 @@ packages: dependency: transitive description: name: leak_tracker - sha256: "33e2e26bdd85a0112ec15400c8cbffea70d0f9c3407491f672a2fad47915e2de" + sha256: "3f87a60e8c63aecc975dda1ceedbc8f24de75f09e4856ea27daf8958f2f0ce05" url: "https://pub.dev" source: hosted - version: "11.0.2" + version: "10.0.5" leak_tracker_flutter_testing: dependency: transitive description: name: leak_tracker_flutter_testing - sha256: "1dbc140bb5a23c75ea9c4811222756104fbcd1a27173f0c34ca01e16bea473c1" + sha256: "932549fb305594d82d7183ecd9fa93463e9914e1b67cacc34bc40906594a1806" url: "https://pub.dev" source: hosted - version: "3.0.10" + version: "3.0.5" leak_tracker_testing: dependency: transitive description: name: leak_tracker_testing - sha256: "8d5a2d49f4a66b49744b23b018848400d23e54caf9463f4eb20df3eb8acb2eb1" + sha256: "6ba465d5d76e67ddf503e1161d1f4a6bc42306f9d66ca1e8f079a47290fb06d3" url: "https://pub.dev" source: hosted - version: "3.0.2" + version: "3.0.1" lints: dependency: transitive description: @@ -505,10 +513,10 @@ packages: dependency: transitive description: name: matcher - sha256: dc58c723c3c24bf8d3e2d3ad3f2f9d7bd9cf43ec6feaa64181775e60190153f2 + sha256: d2323aa2060500f906aa31a895b4030b6da3ebdcc5619d14ce1aada65cd161cb url: "https://pub.dev" source: hosted - version: "0.12.17" + version: "0.12.16+1" material_color_utilities: dependency: transitive description: @@ -529,10 +537,10 @@ packages: dependency: transitive description: name: meta - sha256: e3641ec5d63ebf0d9b41bd43201a66e3fc79a65db5f61fc181f04cd27aab950c + sha256: bdb68674043280c3428e9ec998512fb681678676b3c54e773629ffe74419f8c7 url: "https://pub.dev" source: hosted - version: "1.16.0" + version: "1.15.0" mime: dependency: transitive description: @@ -569,10 +577,10 @@ packages: dependency: transitive description: name: path - sha256: "75cca69d1490965be98c73ceaea117e8a04dd21217b37b292c9ddbec0d955bc5" + sha256: "087ce49c3f0dc39180befefc60fdb4acd8f8620e5682fe2476afd0b3688bb4af" url: "https://pub.dev" source: hosted - version: "1.9.1" + version: "1.9.0" path_parsing: dependency: transitive description: @@ -733,14 +741,6 @@ packages: url: "https://pub.dev" source: hosted version: "3.0.0" - send_message: - dependency: "direct main" - description: - name: send_message - sha256: "79b5f69fd3ab0b9e6265f8d972800d7989b3082a0523c7f4b8e38bf4e1c71235" - url: "https://pub.dev" - source: hosted - version: "1.0.2" share_plus: dependency: "direct main" description: @@ -841,7 +841,7 @@ packages: dependency: transitive description: flutter source: sdk - version: "0.0.0" + version: "0.0.99" source_span: dependency: transitive description: @@ -862,18 +862,18 @@ packages: dependency: transitive description: name: stack_trace - sha256: "8b27215b45d22309b5cddda1aa2b19bdfec9df0e765f2de506401c071d38d1b1" + sha256: "73713990125a6d93122541237550ee3352a2d84baad52d375a4cad2eb9b7ce0b" url: "https://pub.dev" source: hosted - version: "1.12.1" + version: "1.11.1" stream_channel: dependency: transitive description: name: stream_channel - sha256: "969e04c80b8bcdf826f8f16579c7b14d780458bd97f56d107d3950fdbeef059d" + sha256: ba2aa5d8cc609d96bbb2899c28934f9e1af5cddbd60a827822ea467161eb54e7 url: "https://pub.dev" source: hosted - version: "2.1.4" + version: "2.1.2" string_scanner: dependency: transitive description: @@ -894,10 +894,10 @@ packages: dependency: transitive description: name: test_api - sha256: "522f00f556e73044315fa4585ec3270f1808a4b186c936e612cab0b565ff1e00" + sha256: "5b8a98dafc4d5c4c9c72d8b31ab2b23fc13422348d2997120294d3bac86b4ddb" url: "https://pub.dev" source: hosted - version: "0.7.6" + version: "0.7.2" typed_data: dependency: transitive description: @@ -1006,10 +1006,10 @@ packages: dependency: transitive description: name: vector_math - sha256: d530bd74fea330e6e364cda7a85019c434070188383e1cd8d9777ee586914c5b + sha256: "80b3257d1492ce4d091729e3a67a60407d227c27241d6927be0130c98e741803" url: "https://pub.dev" source: hosted - version: "2.2.0" + version: "2.1.4" vm_service: dependency: transitive description: @@ -1067,5 +1067,5 @@ packages: source: hosted version: "3.1.3" sdks: - dart: ">=3.8.0-0 <4.0.0" + dart: ">=3.5.0 <4.0.0" flutter: ">=3.24.0" diff --git a/pubspec.yaml b/pubspec.yaml index 737c4f4..b1ee4f4 100644 --- a/pubspec.yaml +++ b/pubspec.yaml @@ -63,7 +63,8 @@ dependencies: package_info_plus: ^4.2.0 simcards: ^0.0.1 uuid: ^4.5.1 - send_message: ^1.0.0 + #send_message: ^1.0.0 + flutter_sms: ^2.3.3 fluttertoast: ^8.2.6 # jailbreak_root_detection: "^1.1.6"