- telephony 패키지를 flutter_sms_inbox로 교체 - 플랫폼별 SMS 스캔 로직 구현: * Web: mock data 사용 * Android: flutter_sms_inbox로 실제 SMS 스캔 * iOS: SMS 기능 비활성화 - iOS에서 SMS 스캔 버튼 숨김 처리 - PlatformHelper 유틸리티 추가로 웹 환경 오류 해결 - Android 네이티브 MethodChannel 코드 제거
51 lines
1.5 KiB
Dart
51 lines
1.5 KiB
Dart
import 'package:flutter/foundation.dart' show kIsWeb;
|
|
import 'package:flutter/services.dart';
|
|
import 'package:permission_handler/permission_handler.dart' as permission;
|
|
import '../utils/platform_helper.dart';
|
|
|
|
class SMSService {
|
|
static const platform = MethodChannel('com.submanager/sms');
|
|
|
|
static Future<bool> requestSMSPermission() async {
|
|
// 웹이나 iOS에서는 SMS 권한 불필요
|
|
if (kIsWeb || PlatformHelper.isIOS) return true;
|
|
|
|
// Android에서만 권한 요청
|
|
if (PlatformHelper.isAndroid) {
|
|
final status = await permission.Permission.sms.request();
|
|
return status.isGranted;
|
|
}
|
|
|
|
return false;
|
|
}
|
|
|
|
static Future<bool> hasSMSPermission() async {
|
|
// 웹이나 iOS에서는 항상 true 반환 (권한 불필요)
|
|
if (kIsWeb || PlatformHelper.isIOS) return true;
|
|
|
|
// Android에서만 실제 권한 확인
|
|
if (PlatformHelper.isAndroid) {
|
|
final status = await permission.Permission.sms.status;
|
|
return status.isGranted;
|
|
}
|
|
|
|
return false;
|
|
}
|
|
|
|
static Future<List<Map<String, dynamic>>> scanSubscriptions() async {
|
|
if (kIsWeb) return [];
|
|
|
|
try {
|
|
if (!await hasSMSPermission()) {
|
|
throw Exception('SMS 권한이 없습니다.');
|
|
}
|
|
|
|
final List<dynamic> result =
|
|
await platform.invokeMethod('scanSubscriptions');
|
|
return result.map((item) => item as Map<String, dynamic>).toList();
|
|
} on PlatformException catch (e) {
|
|
throw Exception('SMS 스캔 중 오류 발생: ${e.message}');
|
|
}
|
|
}
|
|
}
|