Skip to content

cafebazaar/BazaarUpdater

Repository files navigation

BazaarUpdater Android SDK

gif

GitHub License Download

BazaarUpdater is an Android library that simplifies checking for updates and managing the update process for your application on Bazaar.

Setup

To get started with BazaarUpdater, you need to add the JitPack repository to your project and include the library dependency.

Adding JitPack Repository

Kotlin DSL

repositories {
    maven { url = uri("https://jitpack.io") }
}

groovy

repositories {
    maven { url 'https://jitpack.io' }
}

Adding Dependency

Kotlin DSL

dependencies {
    implementation("com.github.cafebazaar:bazaarUpdater:1.1.0")
}

groovy

dependencies {
    implementation 'com.github.cafebazaar:bazaarUpdater:1.1.0'
}

Usage

Checking for Updates

To check if there are any updates available for your application on Bazaar, use the following code:

BazaarUpdater.getLastUpdateState(context = context) { result ->
    when(result) {
        UpdateResult.AlreadyUpdated -> {
            // Handle the case where the app is already updated
        }
        is UpdateResult.Error -> {
            // Handle the error case
            val errorMessage = result.getError()?.message
        }
        is UpdateResult.NeedUpdate -> {
            // Handle the case where an update is needed
            val targetVersion = result.getTargetVersionCode()
        }
    }
}
Java Usage
BazaarUpdater.getLastUpdateState(context, result -> {
    if (result.isAlreadyUpdated()) {
        // Handle the case where the app is already updated
    } else if (result.isUpdateNeeded()) {
        // Handle the case where an update is needed
        long targetVersion = result.getTargetVersionCode();
    } else {
        // Handle the error case
        String errorMessage = result.getError().getMessage();
    }
});

Update Result States

1. AlreadyUpdated: Indicates that your application is up-to-date.
2. Error: Indicates an error occurred. Use result.message to get the error message.
3. NeedUpdate: Indicates that a new update is available. Use result.getTargetVersionCode() to get the version code of the update.

Updating the Application

To update your application when a new version is available on Bazaar, simply call:

BazaarUpdater.updateApplication(context = context)

Auto Update

This feature allows you to enable automatic updates for your apps in Bazaar. Once enabled, Bazaar will check for application updates daily. If an update is available and Bazaar is the update owner of your app, it will automatically download and install the update.

⚠️ Note: This feature requires Bazaar version 26.2.0 or higher.

⚠️ Package Name : Ensure the package name (also known as the application ID in Android) in your source code exactly matches the one used in the already published app. This is typically defined in your app's AndroidManifest.xml file.

⚠️ Signature : The app must be signed with the same key as the published version. Make sure you’re using the correct keystore and alias that were used for the original app.

Checking for Auto Update

To check whether Auto Update is enabled for your application in Bazaar, use the following code:

BazaarAutoUpdater.getLastAutoUpdateState(context = this) { result ->
    when (result) {
        is AutoUpdateResult.Error -> {
            // Handle the error case
            val errorMessage = result.getError()?.message
        }
        is AutoUpdateResult.Result -> {
            val isEnabled = result.isEnable()
        }
    }
}
Java Usage
BazaarAutoUpdater.getLastAutoUpdateState(context, result -> {
    if (result.getError() != null) {
        // Handle the error case
        String errorMessage = result.getError().getMessage();
    } else {
        Boolean isEnabled = result.isEnable();
    }
});

Enable Auto Update

To enable Auto Update for your application, simply call the following method:

BazaarAutoUpdater.enableAutoUpdate(context = context)

Contributing

Contributions are welcome! If you have suggestions or improvements, please open an issue or submit a pull request.

License

This project is licensed under the Apache License 2.0 - see the LICENSE file for details.



Made with 💚 in Bazaar Hackathon 1403