How to: Provision a FIM Certificate Management Unlinked Temporary Card Request
The following examples show how to provision a Forefront Identity Manager Certificate Management (FIM CM) Temporary Card request for a temporary card that is not linked to an existing profile. The first example demonstrates how to do this using CreateUnlinkedTempCardRequest. The second example shows a more manual approach.
CLMUtils.CreateLinkedTempCardRequest
Sub Provision(ByVal mventry As MVEntry)
Implements IMVSynchronization.Provision
Try
If mventry("objectGUID").IsPresent Then
CLMUtils.CreateUnlinkedTempCardRequest(CLMMA,
New Guid(mventry("objectGUID").BinaryValue),
"CLM Sample Profile Template")
End If
' Log and rethrow any exception.
Catch ex As Exception
Logging.Logging.LogException(ex,
"Provision",
"Caught exception",
False)
Throw
End Try
End Sub 'IMVSynchronization.Provision
void IMVSynchronization.Provision (MVEntry mventry)
{
try
{
if (mventry["objectGUID"].IsPresent)
{
CLMUtils.CreateUnlinkedTempCardRequest(CLMMA,
new Guid(mventry["objectGUID"].BinaryValue),
"CLM Sample Profile Template");
}
}
// Log and rethrow any exception.
catch(Exception ex)
{
Logging.Logging.LogException(ex,
"Provision",
"Caught exception",
false);
throw;
}
}
Provision Linked Temporary Card Request
Sub Provision(ByVal mventry As MVEntry)
Implements IMVSynchronization.Provision
Try
If mventry("objectGUID").IsPresent Then
Dim targetCLMMA As ConnectedMA =
mventry.ConnectedMAs("CertificateLifecycleManagerMA")
Dim csentry As CSEntry =
targetCLMMA.Connectors.StartNewConnector("clmRequest")
csentry.DN = targetCLMMA.EscapeDNComponent("CN=" +
Guid.NewGuid().ToString())
csentry("req_type").IntegerValue = 11
csentry("req_type_name").Value = "TemporaryCardEnroll"
csentry("req_target_user_uuid").BinaryValue =
mventry("objectGUID").BinaryValue
csentry("req_profile_template_name").Value =
"Smart Card User Template"
csentry("req_profile_template_uuid").BinaryValue =
New Guid().ToByteArray()
' GUID of profile template you can get from
' CLMUtils.GetProfileUuidFromProfileTemplateName
' or manually.
csentry.CommitNewConnector()
End If
' Log and rethrow any exception.
Catch ex As Exception
Logging.Logging.LogException(ex,
"Provision",
"Caught exception",
False)
Throw
End Try
End Sub 'IMVSynchronization.Provision
void IMVSynchronization.Provision(MVEntry mventry)
{
try
{
if (mventry["objectGUID"].IsPresent)
{
ConnectedMA targetCLMMA =
mventry.ConnectedMAs["CertificateLifecycleManagerMA"];
CSEntry csentry =
targetCLMMA.Connectors.StartNewConnector("clmRequest");
csentry.DN = targetCLMMA.EscapeDNComponent("CN=" +
Guid.NewGuid().ToString());
csentry["req_type"].IntegerValue = 11;
csentry["req_type_name"].Value = "TemporaryCardEnroll";
csentry["req_target_user_uuid"].BinaryValue =
mventry["objectGUID"].BinaryValue;
csentry["req_profile_template_name"].Value =
"Smart Card User Template";
csentry["req_profile_template_uuid"].BinaryValue =
new Guid(GUIDValue).ToByteArray();
// GUIDValue is the GUID of the profile template
// you can get from
// CLMUtils.GetProfileUuidFromProfileTemplateName
// or manually
csentry.CommitNewConnector();
}
}
// Log and rethrow any exception.
catch (Exception ex)
{
Logging.Logging.LogException(ex,
"Provision",
"Caught exception",
false);
throw;
}
}
See Also
Reference
Concepts
Forefront Identity Manager Certificate Management Connected Data Sources