Introduction
Dans le but de remplacer le feed natif de ScrumPilot par le feed de Yammer, et aussi d’informer des gens affiliés à Yammer, mais qui n'ont pas de compte ScrumPilot ou Team Foundation Server, j'ai fabriqué une librairie pour accéder facilement à Yammer et interagir avec lui.
Codes sources
sur CodePlex : Yammer.SimpleAPIPréalable
Pour dialoguer avec Yammer au travers de son API, il faut préalablement configurer une "Apps" dans Yammer.
Le didacticiel est bien fait, et ci-dessous, des copies d'écran de ma propre inscription.
Notez l'adresse de redirection en bas du formulaire qui pointe vers une adresse locale.
Exemple d'utilisation
Dans ma solution, j'ai ajouté une application MVC qui illustre l'utilisation de la librairie.
Connexion
Le but de l'écran ci-dessous est de saisir les renseignements fournis par l'inscription, le Client ID et de Client Secret fourni par Yammer.
Post dans le Controller
Le post dans le Controller est des plus classiques, il prépare les informations à envoyer, il redirige vers Yammer qui demande si l'application est autorisée. Je stocke les informations de connections pour les sauvegarder au retour.
[HttpPost] public ActionResult Index(IndexViewModel model) { if (ModelState.IsValid) { // prepare info for Yammer var myConfig = new ClientConfigurationContainer { ClientCode = null, ClientId = model.ClientId, ClientSecret = model.ClientSecret, // especially where it should return // after auth RedirectUri = Request.Url.AbsoluteUri + Url.Action("AuthCode") }; // Create a new Rest Client var myYammer = new YammerClient(myConfig); // Make the right Yammer Url var url = myYammer.GetLoginLinkUri(); // Save data in Session this.TempData["YammerConfig"] = myConfig; // go to Yammer return Redirect(url); } return View(model); }
Si tout se passe bien, vous devriez arriver sur un écran comme celui-ci, il vous demande l'autorisation de partager vos informations avec votre application (celle que vous avez déclarée dans le préambule, pour ma part ScrumPilot)
En cliquant sur "Allow", Yammer retourne vers votre application en lui fournissant un code d’authentification.
Pour une meilleure compréhension de la mécanique générale de cette authentification, je vous renvoie vers OAuth 2.
Résultat et interactions
public ActionResult AuthCode(String code) { if (!String.IsNullOrWhiteSpace(code)) { var myConfig = this.TempData["YammerConfig"] as ClientConfigurationContainer; myConfig.ClientCode = code; var myYammer = new YammerClient(myConfig); // Some examples // var yammerToken = myYammer.GetToken(); // var l = myYammer .GetUsers(); // var t = myYammer .GetImpersonateTokens(); // var i = myYammer .SendInvitation("test@test.fr"); // var m = myYammer .PostMessage("A test from here", // 0, "Event" topic); return View(myYammer.GetUserInfo()); } return null; }
Un petit exemple :
Aucun commentaire:
Enregistrer un commentaire