Checking Network Availability in Adobe AIR

Here's a module that detects whether your Adobe AIR app is connected to the internet.

Net = function() {
    var url       = false; // assigned during init()
    var connected = false; // automatically updated
    var handlerEventComplete = function(e) {
        connected = true;
    };
    var handlerIoError = function(e) {
        connected = false;
    };
    var checkConnection = function() {
        var r = new air.URLRequest(url);
        r.useCache = false; // force a new fetch
        var l = new air.URLLoader();
        l.addEventListener(air.Event.COMPLETE, handlerEventComplete);
        l.addEventListener(air.IOErrorEvent.IO_ERROR, handlerIoError);
        l.load(r); // execute request
    };
    var start = function() {
        air.NativeApplication.nativeApplication.removeEventListener(air.Event.NETWORK_CHANGE, checkConnection);
        air.NativeApplication.nativeApplication.addEventListener(air.Event.NETWORK_CHANGE, checkConnection);
        checkConnection(); // 1st call must be manual, because an event may have already occurred
    };
    return {
        init        : function(u) {
            url = (typeof u == "string") ? u : false;
            start();
        },
        isConnected : function() {
            return connected;
        }
    };
}();

When you're ready to start checking the network connection, you can call Net.init("http://your.web.site/") — I usually use the URL for my app's version.xml file, which the Updater uses. If you just need to know whether you're connected, not necessarily whether a particular resource is available, then Google or some other reliable address should be fine.

The module is event-driven, rather than relying on polling. If you want to change the resource it checks for, simply call Net.init() with the new URL. Note also that this method does not require Adobe's servicemonitor framework, which it would if it polled the address using URLMonitor or ServiceMonitor.

Enjoy!

Tags




blog comments powered by Disqus
search blog
random posts
  • Flex-Cookbook-Real-world-developing-Applications
  • Designing-Interfaces-Jenifer-Tidwell
categories & tags
about hb stone

I'm a Front-End Engineer at Yahoo! working on the Mail and Messenger teams. I blog about web design and development topics including accessibility, usability, performance, and developing HTML / CSS / JavaScript applications on Appcelerator Titanium and Adobe AIR.

If you're a web developer, you might enjoy Jelo, my JavaScript library.

@hbstone follows:
@hbstone tweets:
  • JavaScript-Good-Parts-Douglas-Crockford
  • CSS-Definitive-Guide-Eric-Meyer
copyright

All original work on this site is covered by a Creative Commons Attribution 3.0 license unless otherwise specified.

You may share or use any code or images from this site in any manner, for free, so long as reasonable effort has been made to give credit where due.

The views expressed in the posts and comments on this blog do not necessarily reflect the views of Yahoo!