Skip to main content

Token

This is a sample of how to manage users' token via the IDaaS Administration API. To run this sample, you must have a valid IDaaS Administration API application in your IDaaS tenant. For more information, see the quick start guide.

caution

This sample is for demonstration purposes only. It is not intended for production use. In production, you should use a secure method to store the client secret and the application id.

Initialize the Administration API client

To perform user management operations, you must first initialize the Administration API client. The following code shows how to initialize the client.

import com.entrustdatacard.intellitrust.admin.ApiClient;
import com.entrustdatacard.intellitrust.admin.api.*;
import com.entrustdatacard.intellitrust.admin.model.*;

public class Main {
private static final String SHARED_SECRET = "YOUR_SHARED_SECRET";
private static final String HOST_NAME = "YOUR_HOST_NAME";
private static final String APPLICATION_ID = "YOUR_APPLICATION_ID";

public static void main(String[] args) throws Exception {
ApiClient apiClient = new ApiClient();
apiClient.setBasePath(HOST_NAME);

AdminAuthApi adminAuthApi = new AdminAuthApi(apiClient);

AdminApiAuthentication authParams = new AdminApiAuthentication()
.applicationId(APPLICATION_ID)
.sharedSecret(SHARED_SECRET);
AdminApiAuthenticationResult authResult = adminAuthApi.authenticateAdminApiUsingPOST(authParams);


apiClient.setApiKey(authResult.getAuthToken());
}
}

Create a Token

The following code shows how to create a token of the given type for the given user.

import com.entrustdatacard.intellitrust.admin.ApiClient;
import com.entrustdatacard.intellitrust.admin.api.*;
import com.entrustdatacard.intellitrust.admin.model.*;

import java.util.ArrayList;
import java.util.List;

public class Main {
private static final String SHARED_SECRET = "YOUR_SHARED_SECRET";
private static final String HOST_NAME = "YOUR_HOST_NAME";
private static final String APPLICATION_ID = "YOUR_APPLICATION_ID";

public static void main(String args[]) throws Exception {
// initialize the API client with the IDaaS hostname
ApiClient apiClient = new ApiClient();
apiClient.setBasePath(HOST_NAME);
AdminAuthApi adminAuthApi = new AdminAuthApi(apiClient);

// make a request to authenticate to the admin API application in IDaaS
AdminApiAuthentication authParms =
new AdminApiAuthentication()
.applicationId(APPLICATION_ID)
.sharedSecret(SHARED_SECRET);
AdminApiAuthenticationResult authResult = adminAuthApi.authenticateAdminApiUsingPOST(authParms);

// after authenticating to IDaaS, set the auth token in the API client so that it is used to authenticate
// subsequent admin calls
apiClient.setApiKey(authResult.getAuthToken());

// Create TokensAPI
TokensApi tokensApi = new TokensApi(apiClient);
String userID = "b0bba595-6876-4758-8b77-b785e17aff76";
String tokenType = "ENTRUST_SOFT_TOKEN";
List<ActivateParms.TypeEnum> types = new ArrayList<>();
types.add(ActivateParms.TypeEnum.ONLINE);

ActivateParms activateParms = new ActivateParms()
.deliverActivationEmail(true)
.type(types);
TokenCreateParms tokenCreateParms = new TokenCreateParms()
.activateParms(activateParms);

// Create a token of the given type for the given user
Token token = tokensApi.createTokenUsingPOST(userID, tokenType, tokenCreateParms);

System.out.println(token);
}
}

Activate a Token

The following code shows how to activate a token.

import com.entrustdatacard.intellitrust.admin.ApiClient;
import com.entrustdatacard.intellitrust.admin.api.*;
import com.entrustdatacard.intellitrust.admin.model.*;

import java.awt.Desktop;
import java.io.File;
import java.nio.file.Files;
import java.nio.file.Paths;
import java.util.ArrayList;
import java.util.Base64;
import java.util.List;

public class Main {
private static final String SHARED_SECRET = "YOUR_SHARED_SECRET";
private static final String HOST_NAME = "YOUR_HOST_NAME";
private static final String APPLICATION_ID = "YOUR_APPLICATION_ID";

public static void main(String args[]) throws Exception {
// initialize the API client with the IDaaS hostname
ApiClient apiClient = new ApiClient();
apiClient.setBasePath(HOST_NAME);
AdminAuthApi adminAuthApi = new AdminAuthApi(apiClient);

// make a request to authenticate to the admin API application in IDaaS
AdminApiAuthentication authParms =
new AdminApiAuthentication()
.applicationId(APPLICATION_ID)
.sharedSecret(SHARED_SECRET);
AdminApiAuthenticationResult authResult = adminAuthApi.authenticateAdminApiUsingPOST(authParms);

// after authenticating to IDaaS, set the auth token in the API client so that it is used to authenticate
// subsequent admin calls
apiClient.setApiKey(authResult.getAuthToken());

// Create TokensAPI
TokensApi tokensApi = new TokensApi(apiClient);
String userID = "b0bba595-6876-4758-8b77-b785e17aff76";
String tokenType = "ENTRUST_SOFT_TOKEN";
List<ActivateParms.TypeEnum> types = new ArrayList<>();
types.add(ActivateParms.TypeEnum.ONLINE);

ActivateParms activateParms = new ActivateParms()
.deliverActivationEmail(true)
.type(types);
TokenCreateParms tokenCreateParms = new TokenCreateParms()
.activateParms(activateParms);

// Create a token of the given type for the given user
Token token = tokensApi.createTokenUsingPOST(userID, tokenType, tokenCreateParms);

// Activate the token
activateParms = new ActivateParms()
.deliverActivationEmail(true)
.returnQRCode(true)
.type(types);

ActivateResult activateResult = tokensApi.startActivateTokenUsingPOST(token.getId(), activateParms);

// Base64 decode the QR code
byte[] decodedQRCode = Base64.getDecoder().decode(activateResult.getActivationQRCode());

// Save the QR code to a file
Files.write(Paths.get("qrcode.png"), decodedQRCode);

// Open the QR code file
Desktop.getDesktop().open(new File("qrcode.png"));

System.out.println("Scan the QR Code with your Entrust Identity and input the activation code below");
System.out.println("Activation Code: " + activateResult.getActivationPassword());
}
}