Partager via


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

CreateUnlinkedTempCardRequest

Concepts

Forefront Identity Manager Certificate Management Connected Data Sources