Last active
February 28, 2017 14:27
-
-
Save sclark39/e719efcd40449fc174fee7e1b3be1f25 to your computer and use it in GitHub Desktop.
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
/* | |
Copyright 2010-2016 Amazon.com, Inc. or its affiliates. All Rights Reserved. | |
Licensed under the Apache License, Version 2.0 (the "License"). | |
You may not use this file except in compliance with the License. | |
A copy of the License is located at | |
http://aws.amazon.com/apache2.0 | |
or in the "license" file accompanying this file. This file is distributed | |
on an "AS IS" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either | |
express or implied. See the License for the specific language governing | |
permissions and limitations under the License. | |
*/ | |
#import <Foundation/Foundation.h> | |
#import <AWSAPIGateway/AWSAPIGateway.h> | |
NS_ASSUME_NONNULL_BEGIN | |
/** | |
The service client object. | |
*/ | |
@interface WOMAPIGatewayClient: AWSAPIGatewayClient | |
/** | |
Returns the singleton service client. If the singleton object does not exist, the SDK instantiates the default service client with `defaultServiceConfiguration` from `[AWSServiceManager defaultServiceManager]`. The reference to this object is maintained by the SDK, and you do not need to retain it manually. | |
If you want to enable AWS Signature, set the default service configuration in `- application:didFinishLaunchingWithOptions:` | |
*Swift* | |
func application(application: UIApplication, didFinishLaunchingWithOptions launchOptions: [NSObject: AnyObject]?) -> Bool { | |
let credentialProvider = AWSCognitoCredentialsProvider(regionType: .USEast1, identityPoolId: "YourIdentityPoolId") | |
let configuration = AWSServiceConfiguration(region: .USEast1, credentialsProvider: credentialProvider) | |
AWSServiceManager.defaultServiceManager().defaultServiceConfiguration = configuration | |
return true | |
} | |
*Objective-C* | |
- (BOOL)application:(UIApplication *)application didFinishLaunchingWithOptions:(NSDictionary *)launchOptions { | |
AWSCognitoCredentialsProvider *credentialsProvider = [[AWSCognitoCredentialsProvider alloc] initWithRegionType:AWSRegionUSEast1 | |
identityPoolId:@"YourIdentityPoolId"]; | |
AWSServiceConfiguration *configuration = [[AWSServiceConfiguration alloc] initWithRegion:AWSRegionUSEast1 | |
credentialsProvider:credentialsProvider]; | |
[AWSServiceManager defaultServiceManager].defaultServiceConfiguration = configuration; | |
return YES; | |
} | |
Then call the following to get the default service client: | |
*Swift* | |
let serviceClient = WOMAPIGatewayClient.defaultClient() | |
*Objective-C* | |
WOMAPIGatewayClient *serviceClient = [WOMAPIGatewayClient defaultClient]; | |
Alternatively, this configuration could also be set in the `info.plist` file of your app under `AWS` dictionary with a configuration dictionary by name `WOMAPIGatewayClient`. | |
@return The default service client. | |
*/ | |
+ (instancetype)defaultClient; | |
/** | |
Creates a service client with the given service configuration and registers it for the key. | |
If you want to enable AWS Signature, set the default service configuration in `- application:didFinishLaunchingWithOptions:` | |
*Swift* | |
func application(application: UIApplication, didFinishLaunchingWithOptions launchOptions: [NSObject: AnyObject]?) -> Bool { | |
let credentialProvider = AWSCognitoCredentialsProvider(regionType: .USEast1, identityPoolId: "YourIdentityPoolId") | |
let configuration = AWSServiceConfiguration(region: .USWest2, credentialsProvider: credentialProvider) | |
WOMAPIGatewayClient.registerClientWithConfiguration(configuration, forKey: "USWest2WOMAPIGatewayClient") | |
return true | |
} | |
*Objective-C* | |
- (BOOL)application:(UIApplication *)application didFinishLaunchingWithOptions:(NSDictionary *)launchOptions { | |
AWSCognitoCredentialsProvider *credentialsProvider = [[AWSCognitoCredentialsProvider alloc] initWithRegionType:AWSRegionUSEast1 | |
identityPoolId:@"YourIdentityPoolId"]; | |
AWSServiceConfiguration *configuration = [[AWSServiceConfiguration alloc] initWithRegion:AWSRegionUSWest2 | |
credentialsProvider:credentialsProvider]; | |
[WOMAPIGatewayClient registerClientWithConfiguration:configuration forKey:@"USWest2WOMAPIGatewayClient"]; | |
return YES; | |
} | |
Then call the following to get the service client: | |
*Swift* | |
let serviceClient = WOMAPIGatewayClient(forKey: "USWest2WOMAPIGatewayClient") | |
*Objective-C* | |
WOMAPIGatewayClient *serviceClient = [WOMAPIGatewayClient clientForKey:@"USWest2WOMAPIGatewayClient"]; | |
@warning After calling this method, do not modify the configuration object. It may cause unspecified behaviors. | |
@param configuration A service configuration object. | |
@param key A string to identify the service client. | |
*/ | |
+ (void)registerClientWithConfiguration:(AWSServiceConfiguration *)configuration forKey:(NSString *)key; | |
/** | |
Retrieves the service client associated with the key. You need to call `+ registerClientWithConfiguration:forKey:` before invoking this method or alternatively, set the configuration in your application's `info.plist` file. If `+ registerClientWithConfiguration:forKey:` has not been called in advance or if a configuration is not present in the `info.plist` file of the app, this method returns `nil`. | |
For example, set the default service configuration in `- application:didFinishLaunchingWithOptions:` | |
*Swift* | |
func application(application: UIApplication, didFinishLaunchingWithOptions launchOptions: [NSObject: AnyObject]?) -> Bool { | |
let credentialProvider = AWSCognitoCredentialsProvider(regionType: .USEast1, identityPoolId: "YourIdentityPoolId") | |
let configuration = AWSServiceConfiguration(region: .USWest2, credentialsProvider: credentialProvider) | |
WOMAPIGatewayClient.registerClientWithConfiguration(configuration, forKey: "USWest2WOMAPIGatewayClient") | |
return true | |
} | |
*Objective-C* | |
- (BOOL)application:(UIApplication *)application didFinishLaunchingWithOptions:(NSDictionary *)launchOptions { | |
AWSCognitoCredentialsProvider *credentialsProvider = [[AWSCognitoCredentialsProvider alloc] initWithRegionType:AWSRegionUSEast1 | |
identityPoolId:@"YourIdentityPoolId"]; | |
AWSServiceConfiguration *configuration = [[AWSServiceConfiguration alloc] initWithRegion:AWSRegionUSWest2 | |
credentialsProvider:credentialsProvider]; | |
[WOMAPIGatewayClient registerClientWithConfiguration:configuration forKey:@"USWest2WOMAPIGatewayClient"]; | |
return YES; | |
} | |
Then call the following to get the service client: | |
*Swift* | |
let serviceClient = WOMAPIGatewayClient(forKey: "USWest2WOMAPIGatewayClient") | |
*Objective-C* | |
WOMAPIGatewayClient *serviceClient = [WOMAPIGatewayClient clientForKey:@"USWest2WOMAPIGatewayClient"]; | |
@param key A string to identify the service client. | |
@return An instance of the service client. | |
*/ | |
+ (instancetype)clientForKey:(NSString *)key; | |
/** | |
Removes the service client associated with the key and release it. | |
@warning Before calling this method, make sure no method is running on this client. | |
@param key A string to identify the service client. | |
*/ | |
+ (void)removeClientForKey:(NSString *)key; | |
- (AWSTask *)invokeHTTPRequest:(NSString *)HTTPMethod | |
URLString:(NSString *)URLString | |
pathParameters:(NSDictionary * _Nullable)pathParameters | |
queryParameters:(NSDictionary *)queryParameters | |
headerParameters:(NSDictionary *)headerParameters | |
body:(NSDictionary * _Nullable)body; | |
@end | |
NS_ASSUME_NONNULL_END |
Sign up for free
to join this conversation on GitHub.
Already have an account?
Sign in to comment