Identity
Membership Providers have been inadequate for modern authentication. Forcing integrations to use custom HTTP modules and other approaches to get into the request pipeline to do redirects to other authentication systems.
This old mechanism has been replaced with Identity Extensions, allowing to define custom authentication modules to be developed and implemented where the built-in forms, LDAP, Basic, Windows, or SAML offerings do not provide a solution.
Usually, custom Identity Extensions point to a custom user base or attempt to offer a mixed-mode authentication where multiple checks are made against different systems.
An Identity Extension could not only authenticate users but manage their group subscriptions which control access to individual forms and administrator applications.
In the case that a different system needs to be notified or a more customised approach used, then an Escalation Extension can be built to handle the situation.
Identity Extension Development Walkthrough
The walkthroughs below have been created using Microsoft’s Visual Studio 2017. All sample code is based version 7.0 of the C# language and version 4.6 of the .NET Framework.
This walkthrough will show how to create a “SimpleEscalation” Escalation Extension – in this case, it will write a line in a text file on the server whenever the Escalation triggers.
- Open Visual Studio and create a new Class Library Project and give it a meaningful name. For this example, we will use SampleEscalationExtension. Ensure that the .NET Framework 4.6.2 is selected.
- Rename Class1to something more meaningful such asSimpleEscalation.
- Click ‘Yes’ to the rename all references prompt.
- Add the following references to the project.
- Intelledox.Extension.dll
- Intelledox.Extension.Escalation.dll
- Intelledox.QAWizard.dll
- Intelledox.QAWizard.Design.dll
- Intelledox.Model.dll
Best Practice
- Reference Paths point to correct Intelledox Infiniti deployment path, usually located
C:\inetpub\wwwroot\Infiniti\Produce\bin.- Copy Local property should be set to
Falsefor all Intelledox Infiniti References, as this could corrupt your instance if an older reference is copied to an upgraded site.
Reference Path
Copy Local = False
- Inherit from Intelledox.Extension.Escalation.EscalationExtensionand override necessary EscalationExtension methods, as per the sample below.
using System;
using System.Threading.Tasks;
using Intelledox.Extension.Escalation;
using Intelledox.QAWizard;
namespace SampleEscalationExtension
{
  public class SimpleEscalation : EscalationExtension
  {
    public override ExtensionIdentity ExtensionIdentity
    {
      get => throw new NotImplementedException(); protected set => throw new NotImplementedException();
    }
    public override Task RunAsync(EscalationProperties properties)
    {
      throw new NotImplementedException();
    }
    public override bool SupportsRecurring()
    {
      throw new NotImplementedException();
    }
  }
}
Build SuccessfullyThe project should build at this point without error.
- Implement the ExtensionIdentity property so that it initializes the ExtensionIdentity object containing an Idand aNameto register the Escalation within Infiniti. TheIdneeds to be unique and theNameis displayed to the user in Design.
public override ExtensionIdentity ExtensionIdentity { get; protected set; }
= new ExtensionIdentity()
{
  Id = new Guid("3A9E90C7-2826-4C29-8641-6DE92D5D0F8D"),
  Name = "Infiniti Simple Escalation Extension"
};- The SupportsRecurring()method defines whether or not this Escalation can run multiple times for a particular project. For this particular example, there is no reason why this can't run repeatedly.
public override bool SupportsRecurring()
{
  return true;
}
NoteThe Reassignment Escalation is an example of an Escalation which doesn’t support recurring – once the project has been assigned to somebody else, it can’t be reassigned to them again.
- The RunAsync()method defines what happens when the Escalation executes.
 For this example, the method is going to write “Hello World” and a timestamp to a file on the server.
public override async Task RunAsync(EscalationProperties properties)
{
  using (System.IO.StreamWriter file = new System.IO.StreamWriter(@"C:\temp\HelloWorld.txt", true))
  {
    await file.WriteLineAsync(DateTime.Now.ToString());
  }
}- Build your Escalation to ensure it compiles without error. The Escalation can now be deployed and tested.
SchedulerThe directory the file is located in may need to change depending on the permissions on your server. The Infiniti Scheduler must have permission to write to the location specified, otherwise, the Escalation will fail.
Deploying an Escalation Extension
Escalation Extensions are deployed to an Infiniti environment by copying the Escalation Extension .dll file to the Scheduler bin directory and referencing it within Scheduler appsettings.json file.
- 
Locate your SampleEscalationExtension.dllfile and copy it to the Scheduler root (usually locatedC:\inetpub\wwwroot\Infiniti\IntelledoxScheduler).
- 
Open the produce appsettings.jsonfile and locate the “Extensions” section of the file.
- 
Add a new Escalation Extension element using the following syntax to the appsettings.json
"namespace, class AssemblyName"Examle:
"Extensions": [
  "Intelledox.Extension.ActionBuiltin.PrintAction, Intelledox.Extension.ActionBuiltin",
  "Intelledox.Extension.ActionBuiltin.UserAction, Intelledox.Extension.ActionBuiltin",
  "Intelledox.Extension.ActionBuiltin.WebhookAction, Intelledox.Extension.ActionBuiltin",
  "Intelledox.Extension.ActionBuiltin.RESTAction, Intelledox.Extension.ActionBuiltin",
  "Intelledox.Extension.ActionBuiltin.OracleAction, Intelledox.Extension.ActionBuiltin",
  "Intelledox.Extension.ActionBuiltin.PushNotificationAction, Intelledox.Extension.ActionBuiltin",
  "Intelledox.Extension.EscalationBuiltin.EmailEscalation, Intelledox.Extension.EscalationBuiltin",
  "Intelledox.Extension.EscalationBuiltin.ReassignmentEscalation, Intelledox.Extension.EscalationBuiltin",
  "Intelledox.Extension.EscalationBuiltin.PushNotificationEscalation, Intelledox.Extension.EscalationBuiltin",
  "SampleStateExtensions.SimpleState, SampleStateExtensions"
],- Save the appsettings.jsonfile.
- Add this Escalation into a Workflow test project and make sure it creates a file in C:\temp\HelloWorld.txt as expected when escalation rules are met.
More ExamplesMore examples are available in Intelledox Github account
Final Full Code
using System;
using System.Threading.Tasks;
using Intelledox.Extension.Escalation;
using Intelledox.QAWizard;
namespace SampleEscalationExtension
{
  public class SimpleEscalation : EscalationExtension
  {
    public override ExtensionIdentity ExtensionIdentity { get; protected set; }
    = new ExtensionIdentity()
    {
      Id = new Guid("3A9E90C7-2826-4C29-8641-6DE92D5D0F8D"),
      Name = "Infiniti Simple Escalation Extension"
    };
    // Main entry point in the escalation where it will perform its custom operations
    public override async Task RunAsync(EscalationProperties properties)
    {
      // Implement custom escalation details here. Send notifications, update services, etc
      using (System.IO.StreamWriter file = new System.IO.StreamWriter(@"C:\temp\HelloWorld.txt", true))
      {
        await file.WriteLineAsync(DateTime.Now.ToString());
      }
    }
    // Defines whether or not this escalation is allowed run multiple times for a particular project
    public override bool SupportsRecurring()
    {
      return true;
    }
  }
}Updated 5 months ago


 visualstudio.com
visualstudio.com