Clients wishing to access an OA4MP server directly can do so using the supplied programming API. This document outlines the steps needed and discusses how to accomplish this.
The only supported method for including the client API in your project is via maven. This is supported by most every IDE and works well from the command line too. Simply include the following dependency in your project pom:
<dependency> <groupId>edu.uiuc.ncsa.myproxy</groupId> <artifactId>oa4mp-client-oauth1</artifactId> <version>6.0.3</version> </dependency>
<dependency> <groupId>edu.uiuc.ncsa.myproxy</groupId> <artifactId>oa4mp-client-oauth2</artifactId> <version>6.0.3</version> </dependency>
All references should be resolved at build time.
The major class that you will need is an instance of org.oa4mp.client.api.OA4MPService.java This has precisely two basic calls:
public OA4MPResponse requestCert(); public AssetResponse getCert(String tempToken, String verifier)
The first generates a public/private keypair and certificate request. The OA4MPResponse object contains the URI to which to redirect the user and the generated private key. You must redirect the user to the given URI since this is where s/he will authenticate with the MyProxy server.
Once the user has finished, the server does a callback to the uri you specify. It will contain parameters in the request for the temp token and verifier. You must pass these to the method. The OA4MPService instance will then complete the rest of the OAuth protocol and get the certificate. The AssetResponse contains the username, i.e. the name the user used to authenticate and the X509 certificate itself.
ClientEnvironment ce = ClientEnvironmentUtil.load("/path/to/file", "my-cfg"); OA4MPService service = new OA4MPService(ce); OA4MPResponse response = service.requestCert();
Later, once the user has authenticated and the callback has been invoked, the identifier, access token and verifier need to be used:
ClientEnvironment ce = ClientEnvironmentUtil.load("/path/to/file", "my-cfg"); OA4MPService service = new OA4MPService(ce); String accessToken; // from the callback URL String verifier; // from the callback URL AssetResponse assetResponse = service.getCert(accessToken, verifier);
ClientEnvironment ce; // as per above. OA4MPService service = new OA4MPService(ce); Identifier id = BasicIdentifier.newID("my:test:uri/1"); OA4MPResponse response = service.requestCert(id);
At this point, the first exchange with the server is done and an asset with the given id has been created in the store. After callback when you have the accessToken and the verifier you can finish the exchange and get the asset:
String accessToken; String verifier; // other values as per the previous example AssetResponse response = service.getCert(accessToken, verifier, id); Asset asset = ce.getAssetStore().get(id);