A Flutter plugin to access and query call history log.
Support for Android only as iOS does not provide API for accessing call history
To use this plugin, add call_log
as a dependency in your pubspec.yaml
file.
You may add the following permission to your Android Manifest:
<uses-permission android:name="android.permission.READ_CALL_LOG" />
<uses-permission android:name="android.permission.WRITE_CALL_LOG" />
Ensure that following options are present in your build.gradle:
compileOptions {
......//
coreLibraryDesugaringEnabled true
}
dependencies {
coreLibraryDesugaring 'com.android.tools:desugar_jdk_libs:1.2.2'
}
This plugin is able to handle checking and requesting permission automatically.
Currently implemented query params are dateFrom, dateTo, durationFrom, durationTo, name and number.
String params are queried using LIKE and '%' wildcard on both sides.
You can delete specific call log entries or all call logs:
// Delete a specific call log entry
int deletedCount = await CallLog.deleteCallLog(entry.id);
// Delete all call logs
int deletedCount = await CallLog.deleteAllCallLogs();
The methods return the number of entries deleted (1 for single deletion, total count for bulk deletion).
You can export all call logs to a JSON file:
// Export call logs to Downloads directory with timestamp
Map<String, dynamic> result = await CallLog.exportCallLog();
The export method saves the file to the Downloads directory with a filename in the format call_log_YYYYMMDD_HHMMSS.json
. The method returns a map containing the number of entries exported and the absolute path to the exported file.
This plugin may be used in flutter background engine, via plugins like WorkManager. But please note that it is impossible for plugin to request permission while it is executed in background. You have to manually request permissions READ_CALL_LOG and READ_PHONE_STATE
Unfortuynately iOS doesn't support queries of call log. More information here: https://stackoverflow.com/questions/33753644/is-there-an-ios-api-for-accessing-call-logs
// IMPORT PACKAGE
import 'package:call_log/call_log.dart';
// GET WHOLE CALL LOG
Iterable<CallLogEntry> entries = await CallLog.get();
// QUERY CALL LOG (ALL PARAMS ARE OPTIONAL)
var now = DateTime.now();
int from = now.subtract(Duration(days: 60)).millisecondsSinceEpoch;
int to = now.subtract(Duration(days: 30)).millisecondsSinceEpoch;
Iterable<CallLogEntry> entries = await CallLog.query(
dateFrom: from,
dateTo: to,
durationFrom: 0,
durationTo: 60,
name: 'John Doe',
number: '901700000',
type: CallType.incoming,
);
- query call log using most common fields, using AND as a logical gate
- query call log with full power of native API
- Contributions are welcome!
- If you want to contribute code please create a PR
- If you find a bug or want a feature, please fill an issue