#IMS Global - LTI™ Utilities [![Build Status](https://travis-ci.org/pfgray/basiclti-util-java.svg?branch=master)](https://travis-ci.org/pfgray/basiclti-util-java) What is it? ----------- LTI™ Utilities are a set of utility classes to aid in the development of LTI v1.0 consumers and providers. They deal with much of the heavy lifting and make the process more opaque to the developer. How to use: ----------- With Maven: Include in your project's `pom.xml`: ```xml org.imsglobal basiclti-util 1.1.2 ``` This library provides support for: **Tool Providers**: 1. Verifying an LTI launch request 2. Sending LTI 1.1 Outcomes request (xml-based) 3. AspectJ launch verifiers for easy integration with Spring-web. **Tool Consumers**s: 1. Creating a valid LTI launch request Some exploratory support for LTIv2: 1. Parsing Tool Profiles 2. Validating Tool Capabilities & Services LTI Providers: ---- **Verifying an LTI launch request.** ```java HttpServletRequest request; // java servlet request LtiVerifier ltiVerifier = new LtiOauthVerifier(); String key = request.getParameter("oauth_consumer_key"); String secret = // retrieve corresponding secret for key from db LtiVerificationResult ltiResult = ltiVerifier.verify(request, secret); ``` **Sending LTI 1.1 Outcomes request (xml-based).** ```java //send Request directly IMSPOXRequest.sendReplaceResult(url, key, secret, sourcedid, score); //or build the request to send later: HttpPost request = IMSPOXRequest.buildReplaceResult(url, key, secret, sourcedid, score, true); ``` **AspectJ launch verifiers for easy integration with Spring-web.** Spring Controller (LTI Producer): ```java @Lti @RequestMapping(value = "/lti", method = RequestMethod.POST) public String ltiEntry(HttpServletRequest request, LtiVerificationResult result) { if(!result.getSuccess()){ return "error"; } else { return "success"; } } ``` KeyService Implementation: ```java public class MockKeyService implements LtiKeySecretService { public String getSecretForKey(String key) { return "secret"; } } ``` Spring Context xml: ```xml ``` LTI Consumers: ---- **Building an LTI launch request.** ```java LtiSigner ltiSigner = new LtiOauthSigner(); Map signedParameters = signParameters(parameters, key, secret, url, "POST"); ``` © 2014 IMS Global Learning Consortium, Inc. All Rights Reserved.