/UpdateNotification

In-App Update Notifications & Changelog

Primary LanguageSwiftMIT LicenseMIT

UpdateNotification

Display a notification about pending app updates. Once a new update is available, a prompt will appear that sends the user to the specified website to download the update. Update info is stored in a JSON file on a web server that can be specified.

Full documentation: http://melvin-gundlach.de/Documentation/UpdateNotification/

Example Integration

Initialization

let feedUrl = URL(string: "http://www.melvin-gundlach.de/apps/app-feeds/Denon-Volume.json")!
let updateNotification = UpdateNotification(feedUrl: feedUrl)

Update Check

let updateAvailable = updateNotification.checkForUpdates()

To check if the latest update is newer than the currently installed app, first the version numbers are compared. If they are the same, the build numbers are compared. If both are the same (or the local installation is newer than the latest in the feed), the function returns false.

Show New Version View

Open a new window containing info about the latest update, if there is at least one item in the feed.

updateNotification.showNewVersionView()

Show Changelog

Open a new window displaying the full changelog.

updateNotification.showChangelogWindow()

Feed Management

let feedUrl = URL(string: "https://website.url/app/feed.json")!
let manager = UpdateFeedManager(feedUrl: feedUrl)

Even when creating a new feed, a feed URL is required. In that case, it doesn't need to be a working link though.

Create

manager.create(website: URL(string: "https://website.url/app")!)

Edit

manager.load()

let item = Item(version: "1.1.0",
                build: "1",
                date: Date(),
                title: "First Update",
                text: "Add customization options.",
                minOSVersion: OperatingSystemVersion(majorVersion: 10, minorVersion: 15, patchVersion: 0),
                infoUrl: URL(string: "https://website.url/app/version101")!,
                downloadUrl: URL(string: "https://website.url/app/version101/download")!)

manager.add(item: item)

The Info URL should direct the user to a URL were more info about the update can be found. The Download URL should lead to a place to download the new version or can even be a direct link to the file.

Clear

manager.clearItems()

Write / Save

This example saves the JSON file to the Downloads folder.

var path = try! FileManager.default.url(for: .downloadsDirectory,
                                        in: .userDomainMask,
                                        appropriateFor: nil,
                                        create: false)
path.appendPathComponent("feed.json")
manager.write(to: path)

It is important for the path to contain the actual filename.

After writing the feed to disk, you have to upload it to your server at the path defined in your app.

JSON Feed Format

You can also just create and manage the feed without using the provided functions.

{
    "url": "https://website.url/app",
    "items": [
        {
            "version": "1.1.0",
            "build": 2,
            "date": "",
            "title": "First Update",
            "text": "Add customization options.",
            "minOSVersion": {
                "majorVersion": 10,
                "minorVersion": 15,
                "patchVersion": 0
            },
            "infoUrl": "https://website.url/app/version101",
            "downloadUrl": "https://website.url/app/version101/download"
        },
        {
            "version": "1.0.0",
            "build": 1,
            "date": "",
            "title": "Initial Release",
            "text": "This is the first iteration.",
            "minOSVersion": {
                "majorVersion": 10,
                "minorVersion": 15,
                "patchVersion": 0
            },
            "infoUrl": "https://website.url/app/version100",
            "downloadUrl": "https://website.url/app/version100/download"
        },
    ]
}