Setting a user's Out of Office Status

Setting a user's Out of Office status via the API may be required in custom automation code or in other custom code based solutions that interact with user worklists.

These code snippets require references to the assemblies:

  • SourceCode.HostClientAPI
  • SourceCode.Workflow.Client

The following code sample demonstrates how to set a users Out of Office status:

Copy

Set a users Out of Office status

using (SourceCode.Workflow.Client.Connection K2Conn = new Connection()) {
    //open a simple connection for simplicity
    K2Conn.Open("localhost");
    //set Out of Office ON for the current user
    K2Conn.SetUserStatus(UserStatuses.OOF);
    //set Out of Office OFF for the current user
    K2Conn.SetUserStatus(UserStatuses.Available);
    //set Out of Office ON for a managed user
    K2Conn.SetUserStatus(@"[Label]:[Domain\Username]", UserStatuses.OOF); //e.g. K2:DOMAIN\Username
    //set Out of Office OFF for a managed user
    K2Conn.SetUserStatus(@"[Label]:[Domain\Username]", UserStatuses.Available); //e.g. K2:DOMAIN\Username
}

The following code sample demonstrates how to define Out of Office worklist settings to specify how Worklist items should be delegated when the user is Out Of Office. When defining the worklist criteria to redirect a worklist item, you can only filter on Activity Name and Folio.

Copy

Delegating worklist items when the user is OOO

using(SourceCode.Workflow.Client.Connection K2Conn = new Connection()) {
    //open a simple connection for simplicity
    K2Conn.Open("localhost");

    //Define Worklist criteria to retrieve worklistitems to be delegated to the other user
    WorklistCriteria worklistcriteria = new WorklistCriteria();
    worklistcriteria.Platform = "ASP";
    //Define the user that the work must be delegated to as a Destination
    Destinations worktypedestinations = new Destinations();
    worktypedestinations.Add(new Destination(@"[Label]:[Domain\Username]", DestinationType.User)); //e.g. K2:DOMAIN\Username
    //Link the filters and destinations to the Work
    WorkType worktype = new WorkType("MyWork", worklistcriteria, worktypedestinations);

    //optional: define a separate set of criteria for any "Exception" tasks that
    //must be delegated to a different user, in this sample, tasks for a specific workflow
    WorklistCriteria worklistexceptioncriteria = new WorklistCriteria();
    worklistexceptioncriteria.Platform = "ASP";
    worklistexceptioncriteria.AddFilterField(WCField.ProcessName, WCCompare.Equal, "[ExceptionProcessName]");
    //Define the user that the exception work must be delegated to as a Destination
    Destinations worktypeexceptiondestinations = new Destinations();
    worktypedestinations.Add(new Destination(@"[Label]:[DOMAIN\ExceptionUserName]", DestinationType.User));
    // Link the filters and destinations to the Exception Work
    WorkTypeException worktypeexception = new WorkTypeException("MyWorkException", worklistexceptioncriteria, worktypeexceptiondestinations);
    worktype.WorkTypeExceptions.Add(worktypeexception);

    //now set up the worklist Out of Office (OOF) delegation
    WorklistShare worklistshare = new WorklistShare();
    worklistshare.ShareType = ShareType.OOF;

    //Set time interval for the Sharing. These dates may be used to only share work for a specific period
    worklistshare.StartDate = DateTime.MinValue;
    worklistshare.EndDate = DateTime.MinValue;

    //add the worktype
    worklistshare.WorkTypes.Add(worktype);
    //Share the worklist
    K2Conn.ShareWorkList(worklistshare);
    //Share the worklist for a managed user
    K2Conn.ShareWorkList(@"[Label]:[Domain\Username]", worklistshare);

    //When the current user's status is set to OOF the worklist shares defined above will take effect
    K2Conn.SetUserStatus(UserStatuses.OOF);
}

StartDate and EndDate Properties

The StartDate and EndDate fields exposed in the API are not currently supported in all User Interfaces where Out of Office can be configured.

The Out of Office status check box in Workspace will reflect the user's status, regardless of the OOF Start or End dates. Therefore if the Start and End dates have been programmatically set and the user's status has been set to OOF, the Workspace check box will show a check mark before, during, and after the Start and End dates. The workflowManagementServer.SetUserStatus(@"K2:[domain\username]", UserStatusses.OOF); will need to be reset to workflowManagementServer.SetUserStatus(@"K2:[domain\username]", UserStatusses.ACTIVE); in order for the Workspace OOF check box to become unchecked. Alternatively, uncheck the OOF check box in Workspace once the End date has been reached.