app_upgrader 0.1.1 copy "app_upgrader: ^0.1.1" to clipboard
app_upgrader: ^0.1.1 copied to clipboard

a Flutter package designed to handle application upgrades seamlessly.

logo

Introduction #

App Upgrader is a Flutter package for managing application upgrades. new_version and in_app_update are used. Thanks to the developers of these packages.

🌟 Why Choose App Upgrader? #

  • Staged Rollouts Compatibility: You won't have the problems that other upgrade packages have when they release App updates with staged rollouts!
  • Local Testing Support: Local testing and logging, which is not available in other update packages, is possible with this package.
  • Version History:: An application that has not been updated for a long time does not update itself only according to the priority of the latest version. If there are force updates in intermediate versions in the version list you have installed, it is forced to force update(scenarios was inspired by bugragny. Thank you for your contributions!)

App Upgrader is your go-to solution for a hassle-free app update experience.

🚀 Key Highlight: Smart Update Types #

force

  • Force Update: When critical updates are necessary, App Upgrader ensures that users must update the app to continue its use. It's crucial for fixing security vulnerabilities or major bugs.
  • Flexible Update:: For less critical updates, App Upgrader allows users the choice to update at their convenience, enhancing user experience while still ensuring app freshness.
  • None:: This update type is designed for situations where no immediate action is required from the user.

🔥🔥🔥 Basic Usage 🔥🔥🔥 #

Here's a quick example to get you started with App Upgrader:

return MaterialApp(
  //..
  home: AppUpgrader(
      bundleId: 'com.example.app',
      versionInfoFetcher: MyVersionInfoFetcher(),
      child: const MyHomePage(title: 'App Upgrader Prod App')),
);

Usage with go_router #

Integrating with navigation frameworks like go_router is straightforward:

GlobalKey<NavigatorState> navigatorKey = GlobalKey();

return MaterialApp.router(
  routerConfig: routerConfig,
  key: routerConfig.configuration.navigatorKey,
  title: 'App Upgrader App go_router',
  theme: ThemeData(
    colorScheme: ColorScheme.fromSeed(seedColor: Colors.deepPurple),
    useMaterial3: true,
  ),
  builder: (context, child) {
    return AppUpgrader(
      navigatorKey: routerConfig.routerDelegate.navigatorKey,
      bundleId: 'com.example.app',
      versionInfoFetcher: MyVersionInfoFetcher(),
      child: child ?? Containter(),
    );
  },
);

Documentation #

  • child: child is the widget located directly below AppUpgrader in the widget hierarchy. It's typically the root widget of your application, like MaterialApp or CupertinoApp.
AppUpgrader(
  child: MyApp(),
  // ...
)
  • navigatorKey: Used to integrate with MaterialApp.router for advanced navigation management.
GlobalKey<NavigatorState> navigatorKey = GlobalKey();
  • versionInfoFetcher: Defines an interface for fetching version information. Implement this class to customize how version information is fetched, for instance, from Firebase Remote Config or a custom backend. To use AppUpgrader, you need to provide version information from a service such as Firebase Remote Config or a custom backend service. This should include JSON data for both Android and iOS platforms under keys like android_version_info and ios_version_info.

Example JSON for Android (android_version_info):

{
  // key should be build number of Android App
  "210": {"update_type": "forceUpdate"},
  "205": {"update_type": "none"},
  // ... other versions ...
}

Example JSON for iOS (ios_version_info):

{
  // key should be version of iOS App
  "4.8.8": {"update_type": "forceUpdate"},
  "4.8.7": {"update_type": "none"},
  // ... other versions ...
}
class MyVersionInfoFetcher implements VersionInfoFetcher {
  late final FirebaseRemoteConfig firebaseRemoteConfig;

  @override
  Future<Map<String, dynamic>> fetchVersionInfo() {
    // Implement fetching logic here.
    // you can use your own service or firebase.
    // for example we use firebase remote config
    await firebaseRemoteConfig.fetchAndActivate();
    return jsonDecode(firebaseRemoteConfig.getString(
    Platform.isAndroid ? 'android_version_info' : 'ios_version_info'));
  }
}
  • bundleId: The unique identifier for your app, essential for fetching version information from app stores.
bundleId: 'com.example.myapp',
  • logger: An abstract class for logging purposes throughout the AppUpgrade process. Useful for logging and testing, especially in local environments.
import 'package:app_upgrader/app_upgrader.dart';
import 'package:alice/alice.dart';

class MyAppUpgradeLogger implements AppUpgradeLogger {
  static Alice alice;
  @override
  void log(String message) {
    alice = Alice(navigatorKey: rootNavigatorKey, showNotification: false);
    alice.addLog(AliceLog(
      message: message,
      timestamp: DateTime.now(),
      level: DiagnosticLevel.info));
  }
}
  • showCustomUpdateDialog: A callback function that allows you to display a custom dialog for app updates. It is triggered when an update is detected, and you can tailor the dialog based on the type of update.
   showCustomUpdateDialog: (updateType, currentVersion, storeVersion) {
     // Different behavior based on update type
     switch (updateType) {
       case UpdateType.forceUpdate:
         // Force update: user must update the app
         showDialog(
           context: context,
           barrierDismissible: false, // User must take action
           builder: (BuildContext context) {
             return AlertDialog(
               title: Text('Mandatory Update'),
               content: Text(
                 'Version $storeVersion is available and is a mandatory update.'
               ),
               actions: <Widget>[
                 TextButton(
                   child: Text('Update Now'),
                   onPressed: () {
                     // Add your update action here
                   },
                 ),
               ],
             );
           },
         );
         break;
       case UpdateType.flexible:
         // Flexible update: user can choose to update now or later
         showDialog(
           context: context,
           barrierDismissible: true, // User can dismiss the dialog
           builder: (BuildContext context) {
             return AlertDialog(
               title: Text('New Update Available'),
               content: Text(
                 'Version $storeVersion is available. Would you like to update?'
               ),
               actions: <Widget>[
                 TextButton(
                   child: Text('Later'),
                   onPressed: () => Navigator.of(context).pop(),
                 ),
                 TextButton(
                   child: Text('Update Now'),
                   onPressed: () {
                     // Add your update action here
                   },
                 ),
               ],
             );
           },
         );
         break;
       default:
         // No update or another update type
         break;
     }
   }

  • localizationMessages: App Upgrader uses platform localization by default and localizationMessages is an optional parameter used to localize the text in the app update dialogs. By providing a LocalizationMessages instance, you can display messages in your desired language. This feature is particularly useful for applications targeting a global audience or specific regions.

Basic Usage with Default Localization:

  localizationMessages: LocalizationMessages(code: 'en'), // English localization

Custom Localization Example: Suppose you want to provide custom messages in French. You would extend the LocalizationMessages class and implement the message logic based on the AppUpgraderMessage key.

class CustomFrenchMessages extends LocalizationMessages {
  @override
  String message({required AppUpgraderMessage messageKey, BuildContext? context}) {
    switch (messageKey) {
      case AppUpgraderMessage.title:
        return 'Mise à jour disponible'; // Custom title in French
      case AppUpgraderMessage.body:
        return 'Une nouvelle version est disponible.'; // Custom body message
      // ... handle other cases
      default:
        return super.message(messageKey: messageKey, context: context);
    }
  }
}

  localizationMessages: CustomFrenchMessages(), // Your custom French localization
)
  • isLocalTest: A flag to enable testing behaviors in local development. Set it to true for testing update processes without the need for publishing a new version.
isLocalTest: true,

Contributing #

Contributions to App Upgrader are welcome! Whether it's submitting bug reports, feature requests, or contributing to the code, we appreciate your effort to make App Upgrader better.

License #

App Upgrader is released under the BSD 3-Clause.


Happy Coding!

16
likes
140
points
51
downloads

Publisher

unverified uploader

Weekly Downloads

a Flutter package designed to handle application upgrades seamlessly.

Homepage

Documentation

API reference

License

BSD-3-Clause (license)

Dependencies

collection, flutter, html, http, in_app_update, package_info_plus, url_launcher

More

Packages that depend on app_upgrader