workmanager 0.8.0  workmanager: ^0.8.0 copied to clipboard
workmanager: ^0.8.0 copied to clipboard
Flutter Workmanager. This plugin allows you to schedule background work on Android and iOS.
0.8.0 #
Major Architecture Changes #
- BREAKING: Migrate to federated plugin architecture for better platform extensibility
- BREAKING: Platform-specific implementations moved to separate packages
- Create workmanager_platform_interfacefor shared platform interface
- Create workmanager_androidpackage with Android WorkManager implementation
- Create workmanager_applepackage with iOS BGTaskScheduler implementation
- Foundation for future macOS support using NSBackgroundActivityScheduler
Breaking Changes #
- BREAKING: Enum values changed from snake_case to camelCase:
- NetworkTypevalues:- not_required→- notRequired,- not_roaming→- notRoaming,- metered→- metered(unchanged)
- OutOfQuotaPolicyvalues:- run_as_non_expedited_work_request→- runAsNonExpeditedWorkRequest,- drop_work_request→- dropWorkRequest
 
- BREAKING: Removed JSON serialization for inputData - now uses native Map transfer for better performance and type safety
New Features #
- Android: Added isScheduledByUniqueNamemethod to check if a periodic task is scheduled by its unique name (Android only)
- Added comprehensive integration tests for better reliability
Bug Fixes #
- iOS: Fixed initialDelaySecondsparameter handling - was previously ignored
- Android: Fixed NullPointerException when isInDebugModewas not properly initialized
- Fixed inputData type handling across platforms - now properly supports all primitive types and lists
- iOS: Fixed compilation errors with Map handling
- iOS: Fixed swapped constraints bug for requiresNetworkConnectivity and requiresExternalPower by @thegriffen (from PR #562)
- Android: Fixed v2 embedding import in BackgroundWorker by @jogapps (from PR #595)
Improvements #
- Updated to Flutter 3.32 and flutter_lints 6.0.0
- Android: Updated target SDK to 35
- Improved CI/CD with Android emulator caching for faster builds
- Better error handling and type safety throughout the codebase
- iOS: Add Privacy Manifest for App Store compliance by @navaronbracke (from PR #555)
- iOS: Replace print statements with proper os_log for better logging
- iOS: printScheduledTasks now returns String instead of void by @yarith28 (from PR #585)
- Android: Fix documentation formatting and typo in BackgroundWorker by @jogapps (from PR #595)
0.7.0 #
- BREAKING: Minimum Dart SDK bumped to 3.2.0
- BREAKING: Minimum Flutter SDK bumped to 3.16.0
- BREAKING: Minimum iOS deployment target bumped to 13.0
- Android: Update to Android Gradle Plugin 8.10.1
- Android: Update to Gradle 8.11.1
- Android: Update Kotlin to 2.1.0
- Android: Update compile SDK to 35
- Android: Update target SDK to 35
- Android: Update NDK to 27.0.12077973
- Android: Update Java compatibility to version 17
- iOS: Update Swift version to 5.0
- Dev dependencies: Update to latest versions (flutter_lints 5.0.0, mockito 5.4.4, etc.)
- CI: Modernize GitHub Actions workflows with latest action versions
- CI: Add Flutter caching for faster builds
- CI: Update test environments (iPhone 15, Android API 34)
- Fix win32 dependency compatibility issues for Dart 3.8+
0.6.0 #
- Android: Removed jetifier
- Android: Removed V1 plugin APIs - this is now a Android V2 plugin only
0.5.2 #
- Android: Bump to workmanager 2.8.1
- Android: Move to Android Gradle Plugin 8.x
- Android: Migrate away from ResolvableFuture (#399).
0.5.1 #
- Call DartPluginRegistrant.ensureInitialized when isolate is starting
- Documentation and example update to fix (#374) WorkManager not working when App is obfuscated or using Flutter 3.1+
0.5.0 #
- Android: Remove jetifier from example
- Restore compatibility with Flutter 3.0.0, thank you @Cwiesen and @sunalwaysknows
- Replaces pedanticchecks withflutter_lints
- Ability to specify custom tasks (and custom background work) for iOS was added. Thank you @tuyen-vuduc
0.5.0-dev.8 #
- iOS: Add implementations for cancelCall and cancelByUniqueName
- Android: Bump to workmanager 2.7.1 to support Android 12
- Android: Add support for expedited background work (a OutOfQuotaPolicyneeds to be specified)
0.5.0-dev.7 #
- Android: Use Numbertype for specifying the callback handler key & convert to Long
- Android: Bump WorkManager dependency to 2.6.0
- iOS: Restore correct NetworkType parser which did not set requiresNetworkConnectivitycorrectly.
0.5.0-dev.6 #
- Resolves issues on iOS which prevented native calls from being parsed correctly.
0.5.0-dev.5 #
- Resolve a null pointer error in BackgroundWorker
0.5.0-dev.4 #
- Replace _noDuration variable with Duration.zerodirectly (#283)
0.5.0-dev.3 #
- Documentation for BGTaskScheduler added
- Throw standard errors when scheduling a task on iOS failed
0.5.0-dev.2 #
- iOS: Modern-style task processing using BGTaskScheduler is now supported. Please see the updated instructions in IOS_SETUP.md.
0.5.0-dev.1 #
- Android: Load Flutter environment asynchronously in the Worker task
0.4.1 #
- Bumps Android dependencies (Kotlin, AGP, workmanager 2.5.0)
- Android: Remove jcenter reference
- Android: Build using compile/target SDK 30.
0.4.0 #
- The package now supports null-safety
0.3.0 #
- BREAKING CHANGE: The Dart side is now instantiated using the factory pattern for easier mocking & testing.
0.2.4 #
- Restore iOS compatibility for Flutter 1.20
- Migrate the iOS project using Xcode 12
0.2.3 #
- Define iOS module so that host apps without use_frameworks! setting can consume the iOS module
- wrap engine.destroy() call in isInitialized #182
0.2.2 #
- Android:
- Fix crash when FlutterEngine would be destroyed twice
 
0.2.0 #
- Android:
- Adding support for the Android v2 embedding.
 See more details in the Android setup guide.
 
- Adding support for the 
0.1.5 #
- Android:
- The result was not correctly mapped to a RETRY when returning false from a background task
 
0.1.4 #
- Android:
- Using Backoff Policy in conjunction with device idle constraint is an illegal action.
 Backoff policy is now nullable in the Android code. See issue #107.
 
- Using Backoff Policy in conjunction with device idle constraint is an illegal action.
0.1.3 #
- iOS & Android:
- Result of BackgroundTaskHandlernow correctly returns to background method channel
 
- Result of 
- iOS:
- Invoking iOSPerformFetchmethod now no longer crashes
- The iOS example app now  implements setPluginRegistrantCallbackas described in our docs, making it possible to access other plugins during a backround fetch
- Dart debug logging is now visible again in Xcode's console
 
- Invoking 
0.1.2 #
- Android:
- Added support for inputData
 
0.1.1 #
- iOS:
- Added support for Flutter 1.9.1
 
0.1.0 #
- First API stable release
- Android:
- Improved debug notification with result message first
- Updated Installation README
 
- iOS:
- 🐞 Improved debug notification delivery when the app is in the background.
- Updated Installation README
 
0.0.15 #
- iOS: 🐞 Make sure all the implementers plugins are available in the background isolate by registering them first.
 This requires the user to provide us with the generated registry in theAppDelegate
- iOS: 📝 specified minimum deployment target of iOS 10 (with Swift 4.2)
0.0.14 #
- iOS performBackgroundFetch now actually works.
0.0.13 #
- [‼️ BREAKING change] You will need to clear the preferences or re-install the App if you had registered jobs already on Android.
- Android:
- Thanks to @vanlooverenkoen
- 🐞 cancelling all task would have failed before this version
- 📝 Update documentation to be a bit more clear about the minimum frequency a periodic can be scheduled
 
- Better debug notification support:
- Emoji's to quickly see if a task ran successful
- Elapsed time
- Collapsing notifications
 
- General Internal API renames to improve readability
 
- Thanks to @vanlooverenkoen
- iOS
- ⬆️ Separate UserDefaults for the plugin
- 🐞 Memory leak resources cleanup
- 🐞 Result mapping Dart -> Swift was wrong
- Better debug notification support:
- Emoji's to quickly see if a task ran successful
- Elapsed time
- Collapsing notifications
 
 
0.0.12 #
- 🐞 expose setPluginRegistrantCallbackto the old rusty Java people
0.0.11 #
- Better README and docs
- Everything now refers to the top level callback as the callbackDispatcher
- Some typo's
- Link to Medium blog post
 
- Adds unit tests to the project since the many issues with enum parsing
- Fixes an issue with the parsing of the NetworkType
 
- Fixes an issue with the parsing of the 
- Project restructure to a srcfolder
0.0.10 #
- I should test a little better before publishing to pub.flutter-io.cn.
- Fixes all enum parsing issues with ExistingWorkPolicyandBackoffPolicy
 
- Fixes all enum parsing issues with 
0.0.9 #
- A bugfix were parsing the BackOffPolicywas still wrong.
0.0.7 #
- This version is the first version to support iOS with the help of the Background Fetch API.
- Only recurring tasks can be scheduled by iOS.
- If you want to respond to iOS background triggers you should add the extra case Workmanager.iOSBackgroundTaskto your switch case.
 
- [‼️ BREAKING change]
- Workmanager.defaultCallbackDispatcherbecomes- Workmanager.executeTask
 
- This version was used as referenced in the Medium blogpost
0.0.6+2 #
- Fixes a bug in which you could not use other plugins inside a EchoCallbackFunction.- 
Fixes #6 
- 
Fixes #4 
- 
[‼️ BREAKING change] A user should extend a custom Applicationand register it in itsAndroidManifest.xmlclass App : FlutterApplication(), PluginRegistry.PluginRegistrantCallback { override fun onCreate() { super.onCreate() WorkmanagerPlugin.setPluginRegistrantCallback(this) } override fun registerWith(reg: PluginRegistry?) { GeneratedPluginRegistrant.registerWith(reg) } }<manifest xmlns:android="http://schemas.android.com/apk/res/android" xmlns:tools="http://schemas.android.com/tools" package="dev.fluttercommunity.workmanager_example"> <!-- io.flutter.app.FlutterApplication is an android.app.Application that calls FlutterMain.startInitialization(this); in its onCreate method. In most cases you can leave this as-is, but you if you want to provide additional functionality it is fine to subclass or reimplement FlutterApplication and put your custom class here. --> <application android:name=".App" <!-- Replace io.flutter.app.FlutterApplication with .App --> android:icon="@mipmap/ic_launcher" android:label="workmanager_example" tools:replace="android:name"> <activity android:name=".MainActivity" android:configChanges="orientation|keyboardHidden|keyboard|screenSize|locale|layoutDirection|fontScale|screenLayout|density|uiMode" android:hardwareAccelerated="true" android:launchMode="singleTop" android:theme="@style/LaunchTheme" android:windowSoftInputMode="adjustResize"> <!-- This keeps the window background of the activity showing until Flutter renders its first frame. It can be removed if there is no splash screen (such as the default splash screen defined in @style/LaunchTheme). --> <meta-data android:name="io.flutter.app.android.SplashScreenUntilFirstFrame" android:value="true" /> <intent-filter> <action android:name="android.intent.action.MAIN" /> <category android:name="android.intent.category.LAUNCHER" /> </intent-filter> </activity> </application> </manifest>
 
- 
0.0.6+1 #
- This version is the first version to support iOS with the help of the Background Fetch API.
- Only recurring tasks can be scheduled by iOS.
- If you want to respond to iOS background triggers you should add the extra case Workmanager.iOSBackgroundTaskto your switch case.
 
- [‼️ BREAKING change]
- Workmanager.defaultCallbackDispatcherbecomes- Workmanager.executeTask
 
0.0.6 #
- Expose a WorkManagerHelper to the native.
- This makes it easier if you also have some native code that wants to schedule the Echo Worker
 
0.0.5 #
- The description was too big so you lose points for that too...
0.0.4 #
- Provide a better description so package scores higher on Pub
0.0.3 #
- Add Dart documentation
0.0.2 #
- Remove the need to register a custom Application on Android side. (Everything still works in testing)
0.0.1 #
- Initial Release:
- Schedule One off task
- Schedule Periodic task
- Fixed delay
 
- Initial delay
- Constraints
- Support for 1 network type
- requires battery not low
- requires charging
- requires device idle
- requires storage not low
 
- back off policy