This version of the SDK is deprecated, and will not be supported in the future. Please use the new version located at: http://github.com/yammer/ios-yammer-sdk
The Yammer API opens Yammer networks to third-party application developers. This sample application provides iOS developers with the code necessary to integrate Yammer functionality into mobile apps. It demonstrates a step-by-step process that does the following:
- Allows users to login to the Yammer network using the iOS Safari browser
- Obtains an authToken and stores it to the iOS keychain
- Uses that authToken to make all subsequent calls to the Yammer API
In order to provide this functionality, some setup must be done.
Step 1) Create a Yammer application here: https://www.yammer.com/client_applications
Step 2) As part of the application setup in step 1, set the Redirect URI to a custom URI scheme. This must be unique to your iOS app. Here's an example: comabccorpyammer1://our.custom.uri
Make sure the scheme name (in this case "comabccorpyammer1") is unique to your company and iOS app.
Step 3) During the login process, users will be directed to the mobile Safari web browser. In order for the browser to be able to switch back to your iOS app, the custom URL Scheme from step 2 must be registered in the iOS application. Here's how you do that:
In the XCode Project Navigator, expand the Supporting Files group and open your application's plist file. Add a new row by going to the menu and clicking Editor > Add Item. Select URL Types. Expand the URL Types key, expand Item 0, and add a new item: “URL schemes”. Fill in (for example) “comabccorpyammer1” for Item 0 of “URL schemes”. Under URL Types, add Item 1 and set that value to URL Identifier (example "our.custom.uri"). Here is a sample screenshot of that setting:
Step 4) Assuming you are going to include YMConstants.m in your app, open YMConstants.m and change YAMMER_AUTH_REDIRECT_URI to point to the Redirect URI from step 2 above.
You will also need to change YAMMER_APP_CLIENT_ID and YAMMER_APP_CLIENT_SECRET to the values in your Yammer
client application
Step 5) Open the sample application's YMAppDelegate.m file and look at the method with this signature:
- (BOOL)application:(UIApplication *)application openURL:(NSURL *)url sourceApplication:(NSString *)sourceApplication annotation:(id)annotation {
This is the method that is called when the user has logged in and they click the "Allow" button in the safari login web page. That "Allow" button will call the custom URI from step 2 above. In order for your application to provide the same "re-entry" functionality, you need to add this app delegate method to your iOS app delegate.
Note: Once the server sees that a user has clicked the Allow button, future login requests do not display the page with the Allow button. This is a one time occurance for each unique user/yammer-app combination. Subsequent login attempts will return directly to the iOS app without the Allow page.
Step 6) Take a look at YMSampleHomeViewController.m to see a typical workflow for Yammer API calls and user authentication. Start with the "attemptYammerApiCall" method. This simulates what you would typically do in your application to access the Yammer API. The first thing the code does is determine if the authToken is already available in the keychain. If it is, it makes the API call using the authToken. If not, it initiates the login process.
The sample login code is in YMLoginController.m and starts with the method "startLogin". Feel free to copy and paste as much sample code as you'd like from the sample app into your own app, including copying class files, etc.
-[YMLoginController startLogin]
launches the iOS Safari web browser. The browser is launched
with a URL like this: https://www.yammer.com/dialog/oauth?client_id=<your_client_id>&redirect_uri=<your_redirect_uri>
This brings up the login page where the user enters their credentials. After they type in their email address and password, they are presented with a page that will allow them to go back to the app where the rest of the authentication process takes place behind the scenes (-[YMLoginController handleLoginRedirectFromUrl:sourceApplication:]
)
Once the redirect method completes successfully, the authToken is pulled from the returned JSON and stored in the keychain. All subsequent calls to the Yammer API use this authToken as the key into the system.
Important Note: The Safari browser in iOS will hold on to the authToken in a cookie in the browser. So if you have already logged in during testing, and you're trying to test the full login workflow again with the login dialog, you will need to delete cookies from Safari first. You can do this by going to the iOS settings app, selecting Safari and then Clear Cookies and Data. You will also need to delete the authToken from the keychain. There is a button on the YMSampleHomeViewController view that calls the deleteToken method so you can test this.