共用方式為


Creating a Connected Data Source Extension in C#

This topic describes how to create a connected data source extension for an extensible management agent using C# and Visual Studio 2005.

To create a password extension project, copy the Microsoft.MetadirectoryServices assembly to your development system and manually create a reference to the assembly.

You can find the assembly in the bin\assemblies folder of the ILM 2007 FP1 program folder. The default folder for Microsoft Identity Lifecycle Manager 2007, Feature Pack 1 is C:\Program Files\Microsoft Identity Integration Server\bin\assemblies\.

To create a connected data source extension, complete the following steps:

  1. Create a new C# class library project
  2. Add a reference to the Microsoft.MetadirectoryServices assembly
  3. Implement the interfaces
  4. Build the class library
  5. Install the connected data source extension in the extensions folder (optional)

ms695358.wedge(en-us,VS.85).gifTo create a new C# class library project using Visual Studio 2005

  1. Click Start, point to All Programs, and then click Microsoft Visual Studio 2005.

    The Visual Studio 2005 development environment appears.

  2. On the File menu, point to New, and then click Project.

  3. In the New Project dialog box, in Project Types, click Visual C#.

  4. On the Templates menu, click Class Library.

  5. In the Name box, type the name of the rules extension that you are creating, and then click Browse.

  6. Browse to the location where you want to store the project files, click Open, and then click OK.

    The name of the new project now appears in Solution Explorer.

ms695358.wedge(en-us,VS.85).gifTo add a reference to the Microsoft.MetadirectoryServices assembly

  1. On the Project menu in Visual Studio 2005, click Add Reference.

  2. In the .NET tab of the Add Reference dialog box, select Microsoft.MetadirectoryServices, and then click OK. If the file does not appear in the Component Name list, click the Browse tab. Browse to the folder with the assembly file, select Microsoft.MetadirectoryServices.dll, and then click Open.

  3. Click OK to close the Add Reference dialog box.

    In Solution Explorer, Microsoft.MetadirectoryServices now appears as one of the references.

For the import interface, implement the IMAExtensibleFileImport interface. For the export interface for a call-based data source, implement the IMAExtensibleCallExport interface. For the export interface for a file-based data source, import the IMAExtensibleFileExport interface.

ms695358.wedge(en-us,VS.85).gifTo implement the interfaces

  1. Add "using Microsoft.MetadirectoryServices;" to the declarations section above the namespace in the source code.

  2. Change Class1 to the name of your class by adding ": IMAExtensibleFile Import,". For example, if the class name is SampleMAFileExport then the class declaration would be "public class SampleMAFileExport : IMAExtensibleFileImport,".

  3. Add the name of the other interface you have to implement. For example, if you are creating a file-based connected data source extension, then you need to implement the IMAExtensibleFileExport interface. The class declaration would be "public class SampleMAFileExport : IMAExtensibleFileImport, IMAExtensibleFileExport".

  4. Add the following code to implement the IMAExtensibleFileImport interface.

    public void GenerateImportFile( 
        string                      filename, 
        string                      connectTo, 
        string                      user, 
        string                      password, 
        ConfigParameterCollection   configParameters,
        bool                        fullImport, 
        TypeDescriptionCollection   types,
        ref string                  customData 
        )
    
    {
    
    }
    
  5. Add the following code to implement the IMAExtensibleFileExport interface to export data to a call-based data source:

    public void DeliverExportFile(
      string fileName,
      string connectTo,
      string user,
      string password,
      ConfigParameterCollection configParameters
    )
    
    {
    
    }
    

    If you are implementing the IMAExtensibleCallExport interface to export data to a call-based data source, then change the code as appropriate.

ms695358.wedge(en-us,VS.85).gifTo build the class library

  • On the Build menu, click Build Solution.

    If you see the following message, the extension was successfully built:

    ------ Build started: Project: Connected Data Source Extension, Configuration: Debug .NET ------
    
    Preparing resources...
    Updating references...
    Performing main compilation...
    Building satellite assemblies...
    
    
    
    ---------------------- Done ----------------------
    
        Build: 1 succeeded, 0 failed, 0 skipped
    

    The connected data source extension file, which has a .dll extension, is in the bin\Debug folder of the project folder.

    Before using the extension, install it in the ILM 2007 FP1 rules extensions folder. The default folder for extensions is C:\Program Files\Microsoft Identity Integration Server\Extensions.

This procedure is optional. You can set Visual Studio 2005 to install the connected data source extension automatically in the extensions folder as part of the build process.

ms695358.wedge(en-us,VS.85).gifTo install the connected data source extension in the extensions folder

  1. In Solution Explorer, select your class library project.

  2. On the View menu, click Property Pages.

    There are two folders in the Property Pages dialog box: Common Properties and Configuration Properties.

  3. Open the Configuration Properties folder. In the Configuration drop-down list box, click All Configurations.

  4. In the left pane of the Property Pages dialog box, click Build.

  5. In Output Path, type the name of the rules extensions folder or browse to the location of the rules extensions folder.

    The default folder for rules extensions is C:\Program Files\Microsoft Identity Integration Server\Extensions.

  6. Click OK to close the Property Pages dialog box.

See Also

Example: Connected Data Source Extension for Call-Based Data Sources
Example: Connected Data Source Extension for File-Based Data Sources

Send comments about this topic to Microsoft

Build date: 2/16/2009