GitXplorerGitXplorer
A

NPReachability

public
170 stars
16 forks
0 issues

Commits

List of commits on branch master.
Unverified
54e8f747709bf64ea1ac002ca00778967180b206

Modify the Readme

AAbizern committed 11 years ago
Unverified
29cde56bf70982aca7b0d41cb36c8b9e88493d9e

Add note about the current maintainer

AAbizern committed 11 years ago
Unverified
e8b268f1ff1111bcdd17fab324c8c09ee0296dfb

Update the Readme with links to the example project.

AAbizern committed 11 years ago
Unverified
61df1bcd1ae4589968492539d6d03dc8e4cb83f4

Put guard arount WWAN SCNetworkStatusFlag

AAbizern committed 11 years ago
Unverified
d457d460d06ed0bd91e9a1929982e43c8d11e317

Update spec file to point to version 0.2.0

AAbizern committed 11 years ago
Unverified
9734c9e4e063f1b8759ba617a3a68a75de5e2ae3

Add a convenient reachabilityFlagsAsString method

AAbizern committed 11 years ago

README

The README file for this repository.

DEPRECATED

I don't use this library, as you can probably tell by how long it's been since it's been updated. I've marked it as deprecated on CocoaPods and will be removing it in 2018. If anybody would like to take over the pod let me know and I'll try and get it done.

NPReachability

NPReachability is an evolution of Apple's Reachability class that provides information about the network status. It has a slightly simpler interface; more concerned with the changes to the network status rather than monitoring a particular URL.

As well as supporting the original's Notification based monitoring, this class supports both KVO and Blocks, so you can choose whichever way of handling changes as your application requires.

This class is written as a singleton, so be sure to reference it as

NPReachability *reachability = [NPReachability sharedInstance];

Make sure you maintain a strong reference to at least one object of this class or else ARC will clean it up underneach you.

Block support

Handlers are declared as

typedef void (^ReachabilityHandler)(NPReachability *curReach);

This takes the NPReachability object as a parameter. As originally written this class passed the SCNetworkReachabilityFlags as a parameter, but you can get that and more by messaging the object directly

You add blocks to be executed when the network status changes by using:

- (id)addHandler:(ReachabilityHandler)handler;

This returns an opaque object which you should use to remove the handler at the appropriate time (in a dealloc, say) with:

- (void)removeHandler:(id)opaqueObject;

KVO support

Two properties can observed for changes to the network status:

@property (nonatomic, readonly, getter=isCurrentlyReachable) BOOL currentlyReachable;
@property (nonatomic, readonly) SCNetworkReachabilityFlags currentReachabilityFlags;

NSNotification

When the network status changes a NPReachabilityChangedNotification is sent with the NPReachability instance as the notification object.

Dependencies

  • Xcode 5.0+ for ARC support, automatic synthesis and compatibility libraries. This might work for Xcode 4.2+, but I haven't been able to test it.
  • The SystemConfiguration Framework should be added to your project.

Usage

Git

Add the project as a submodule to your project's repository and add the NPReachability.h and NPReachability.m files to your project.

CocoaPods

This is also available as a CocoaPod. If you're a Podder, then you already know what to do to add this to your project.

Direct files

Just add the NPReachability.h and NPReachability.m files to your project. But I think any of the previous two methods are preferable to this.

Example

Apple provided the Reachability Sample Code to demonstrate the use of their Reachability class. To see how to use this Class instead have a look at NPReachability-Example which shows the same project using NPReachability instead.

And finally...

Please use and improve! Patches accepted, or create an issue.

I'd love it if you could send me a note as to which app you're using it with!