This framework's main responsibility to download and upload data from an HTTP endpoint, parse, deserialize the data when it is possible and return with the data object.
The logic behind this approach is to create all the web service related calls and parsing logic in runtime to avoid the code duplication. Each method implementation is generated by the client, based on the plist file which belongs to the category extension.
This version of the library supports iOS 7.1 and above. It's working with the NSURLSession
approach. Supporting the upload, download and data tasks. For the upload and download there is support to use progress block as optional.
- HTTP BASIC authentication
- Support to modify the network request, for example adding token key
- Clear authentication provider interface to add application specific approach
- JSON top level deserialization with the
NCJSONSerializer
- Serialization interface,
NCSerializer
Nemo Connect requires iOS 7.1 or above. This framework is designed to use ARC.
CocoaPods is a dependency manager, which automates and simplifies the process of using 3rd-party libraries in your projects. To add NemoConnect via CocoaPods, add the following line to your Podfile
.
pod "NemoConnect", "~> 1.0"
We are using special indicators, identifiers to substitute a variable in our method signature into our network request object. The parameter indicator is a special string. We can use parameter indicators in request path, body and header. If the parameter signature in request/path parameter than you have to use % character as prefix.
Parameters must always be NSObject
. Primitive types like int
, float
, BOOL
are not approved! If you want to pass through just one of your objects property then you can reach that property in this way.
%OBJECT_INDICATOR_NUMBER[PROPERTY_NAME]
- request
- path
- method
- body
- header
- serialization
- serializator
- serializedObject
Required parameter. All the request parameters like path, method, body will be sorted under it.
Always string value. You can add new request paths in here or you can substitute parameter indicators and this is the point where you can send the GET parameters to your HTTP endpoint.
Optional parameter but always in string. Approved values are REST supported HTTP method names (GET
, POST
, DELETE
, PUT
) The default parameters is GET
.
Optional parameter. You can only pass NSData
as a body object. Every request it is only 1 NSData
object is supported in the parameter list.
Optional parameter almost the same as the Body parameter. The only different between this one is only approve dictionaries.
Required only when your network requests response needs to be deserialized. You have to set the serializer class name and the serialized object name.
Name of the serializer class. This class must conforms to NCSerializer
protocol. With the framework we can use the NCJSONSerializer
as a top level object mapper.
String value, required for deserialization. The target model class name.
***
Below are some examples how to create an network request.
The first example shows how to download an image and how to setup the request. The second example will be another network request to request a JSON object with BASIC authentication. In the third example you will see a deserialization example.
-
First, you need to import the framework into you project and import the header file.
#import <Nemo Connect/NemoConnect.h>
-
Then you have to create an web service instance and setup correctly with the designated initializers.
NSURL *apiURL = [NSURL URLWithString:@"http://HTTP_ENDPOINT"]; self.webService = [[NCWebService alloc] initWithBaseURL:apiURL processingQueue:self.workingQueue]; [self.webService setServiceName:@"Image"];
-
The next step will be really important. You have to create a category header file (just the header, the implementation part is not needed anymore) on top of the web service, named like this:
NCWebService+Image.h
-
And add your signatures there, like this:
- (NSOperation *)downloadImageWithName:(NSString *)imageName completionBlock:(NCWebServiceCallbackBlock)completionBlock progressBlock:(NCNetworkDownloaderProgressBlock)progressBlock;
-
Then you have to create a plist file and name it the same as you did in the header file, just the extension will be .plist of course. So:
NCWebService+Image.plist
-
Fill the plist file as your web service required. More details about the right configuration us up in this page, under the Configuration section.
-
Then, you have to just invoke this signature from you model manager implementation and you are done.
[self.webService downloadImageWithName:imageName completionBlock:completionBlock progressBlock:progressBlock];
In this example you have to create the required category header file and plist file pair as you did it in the download example.
-
First step is to setup a web service instance, create an authentication provider instance.
// create an authentication provider NCBasicAuthentication *authenticationProvider = [[NCBasicAuthentication alloc] initWithUsername:@“USERNAME" password:@“PASSWORD”]; // setup web service NSURL *apiURL = [NSURL URLWithString:@“http://HTTP_ENDPOINT"]; self.webService = [[NCWebService alloc] initWithBaseURL:apiURL processingQueue:self.workingQueue authenticationProvider:authenticationProvider]; [self.webService setServiceName:@"PharmacySearch"];
-
The next step is to create the right method signature and plist file for our network request.
- (void)searchWithZIPCode:(NSString *)zipCode completionBlock:(NCWebServiceCallbackBlock)completionBlock;
As you can see we are passing one parameter in here cross through the request path as a GET parameter. We marked this parameter indicator %0 - that means the first parameter from the signature.
-
Invoke your signature
[self.webService searchWithZIPCode:zipCode completionBlock:^(id data, NSError *const error, NSHTTPURLResponse httpURLResponse) { }];
Repeat the first steps, create the category header and the plist file. Then setup your web service instance as well.
-
Create your method signature in the header file
- (NSOperation *)getUsersListWithCompletionBlock:(NCWebServiceCallbackBlock)completionBlock;
-
Setup the configuration file
-
Do not forget to create your blue-print object for the deserialization, in this example is the
NDAUser
data model object. -
Invoke
[self.webService getUsersListWithCompletionBlock:^(id data, NSError *const error, NSHTTPURLResponse *httpURLResponse) { NSLog(@"%@", data); // this data object will be an NDAUser data object }];
Nemo Connect is released under the MIT license. See LICENSE file for details.