I have personal documents stored on Google Drive. While preparing to provide several documents to my attorney for the H1B visa extension, PERM, and green card process, I may have attempted to access Google Drive to download those personal documents. During that time, I encountered a block and likely requested access to Google Drive. However, I want to clarify that I never used Google Drive to download or upload any documents on my work laptop.
CREATEPROCEDURE SP_GetAvailableTasksForTimesheet
@TimeSheetIDINTASBEGIN-- Declare variables to hold the WeekStartDate and WeekEndDateDECLARE@WeekStartDateDATE;
DECLARE@WeekEndDateDATE;
DECLARE@UserName NVARCHAR(100);
-- Fetch the WeekStartDate, WeekEndDate, and UserName from the TimeSheet tableSELECT@WeekStartDate= TimeSheetStartDate,
@WeekEndDate= TimeSheetEndDate,
@UserName= EmployeeNWName
FROM
TimeSheet
WHERE
TimeSheetID =@TimeSheetID;
-- Select tasks that overlap with the given WeekStartDate and WeekEndDate-- and are not already present in the TimeEntry tableSELECTDISTINCT
T.TaskID,
T.TaskName,
T.TaskStartDate,
T.TaskEndDate,
PR.ProjectID,
P.ProjectName
FROM Task T
JOIN ProjectResource PR ON PR.ProjectID = T.ProjectID
JOIN Project P ON PR.ProjectID = P.ProjectID
WHERE PR.EmployeeNWName =@UserNameAND P.Progress ='Open'AND T.Active =1AND (
-- Check overlap between WeekStartDate-WeekEndDate and TaskStartDate-TaskEndDate@WeekStartDate<= ISNULL(T.TaskEndDate, '9999-12-31') AND@WeekEndDate>= T.TaskStartDate
AND-- Check overlap between WeekStartDate-WeekEndDate and ResourceStartDate-ResourceEndDate@WeekStartDate<= ISNULL(PR.ResourceEndDate, '9999-12-31') AND@WeekEndDate>= PR.ResourceStartDate
AND-- Check overlap between TaskStartDate-TaskEndDate and ResourceStartDate-ResourceEndDate
T.TaskStartDate <= ISNULL(PR.ResourceEndDate, '9999-12-31') AND ISNULL(T.TaskEndDate, '9999-12-31') >= PR.ResourceStartDate
)
ANDNOTEXISTS (
SELECT1FROM TimeEntry TE
WHERE TE.TaskID = T.TaskID
AND TE.TimeSheetID =@TimeSheetID
);
END;
SharePoint Server Subscription Edition (SE) supports the following versions of Windows Server:
Windows Server 2019
Windows Server 2022
Sharepoint server upgrade
SharePoint upgrades from SharePoint 2019 to SharePoint Server Subscription Edition does not support In place upgrade.
We will need Install and configure SharePoint Server Subscription Edition on the new farm
SQL Server
SharePoint Server Subscription Edition (SE) supports the following versions of SQL Server:
SQL Server 2019 (Standard or Enterprise edition)
SQL Server 2022 (Standard or Enterprise edition)
We will need to create new SQL server instance for the
SharePoint Server Subscription Edition (SE) farm and then backup and restore DBs from old to new SQL instance
If we already have SQL Server 2019 in place it will streamline the upgrade process, as it's supported by both SharePoint versions.
Updated Stored Procedure
Here is how the updated SP_GetMissingTimesheets stored procedure might look, incorporating the overlap logic:
sql
ALTERPROCEDURE [TT].[SP_GetMissingTimesheets]
ASBEGINDECLARE@TodayDATE= GETDATE();
DECLARE@WeekStartDateDATE;
DECLARE@WeekEndDateDATE;
-- Clear previous entries in the MissingTimesheets table (optional)-- DELETE FROM MissingTimesheets WHERE Created < DATEADD(WEEK, -5, GETDATE());-- Loop through the past 5 weeksDECLARE@WeekOffsetINT=1;
-- Truncate the MissingTimesheets table to clear any existing dataTRUNCATETABLE MissingTimesheets;
WHILE @WeekOffset<5BEGIN-- Calculate the start and end dates of the week using the functionSELECT@WeekStartDate= WeekStartDate, @WeekEndDate= WeekEndDate
FROM Fun_GetWeekStartEndDate(@Today, -@WeekOffset);
-- Insert missing timesheets into the permanent table, excluding records where date ranges do not overlapINSERTINTO MissingTimesheets (EmployeeEmail, WeekStartDate, WeekEndDate)
SELECTDISTINCT E.EmployeeEmail, @WeekStartDate, @WeekEndDateFROM Resource E
LEFTJOIN TimeSheet TS ON E.EmployeeNWName = TS.EmployeeNWName
AND TS.TimeSheetStartDate =@WeekStartDateAND TS.TimeSheetEndDate =@WeekEndDateWHERE (TS.TimeSheetID ISNULLOR TS.TimeSheetStatus IN ('Not Started', 'Saved', 'Returned'))
ANDEXISTS (
SELECT1FROM Task T
JOIN ProjectResource PR ON PR.ProjectID = T.ProjectID
WHERE PR.EmployeeNWName = E.EmployeeNWName
AND (
-- Check overlap between WeekStartDate-WeekEndDate and TaskStartDate-TaskEndDate
(@WeekStartDate<= ISNULL(T.TaskEndDate, '9999-12-31') AND@WeekEndDate>= T.TaskStartDate)
AND-- Check overlap between WeekStartDate-WeekEndDate and ResourceStartDate-ResourceEndDate
(@WeekStartDate<= ISNULL(PR.ResourceEndDate, '9999-12-31') AND@WeekEndDate>= PR.ResourceStartDate)
AND-- Check overlap between TaskStartDate-TaskEndDate and ResourceStartDate-ResourceEndDate
(T.TaskStartDate <= ISNULL(PR.ResourceEndDate, '9999-12-31') AND ISNULL(T.TaskEndDate, '9999-12-31') >= PR.ResourceStartDate)
)
);
SET@WeekOffset=@WeekOffset+1;
END-- Select and format the missing timesheetsSELECTROW_NUMBER() OVER (ORDERBY E.EmployeeEmail) AS MissingTimesheetID,
E.EmployeeNWName,
E.EmployeeEmail,
E.EmployeeDisplayName,
'<ul>'+ STRING_AGG('<li>'+CONVERT(VARCHAR, M.WeekStartDate, 101) +' - '+CONVERT(VARCHAR, M.WeekEndDate, 101) +'</li>', '') +'</ul>'AS MissingWeeks
FROM
MissingTimesheets M
JOIN Resource E ON M.EmployeeEmail = E.EmployeeEmail
WHERE
M.Created >= DATEADD(WEEK, -5, @Today)
GROUPBY
E.EmployeeNWName,
E.EmployeeEmail,
E.EmployeeDisplayName;
END;
Stored Procedure
sql
CREATEPROCEDURE SP_AddEmployeeToGeneralProjects
@EmployeeNWName NVARCHAR(100)
ASBEGIN-- Declare a variable to hold the ProjectIDDECLARE@ProjectIDINT;
-- Cursor to iterate through projects with Portfolio 'General'DECLARE ProjectCursor CURSORFORSELECT ProjectID
FROM Project
WHERE PortfolioID = (SELECT PortfolioID FROM Portfolio WHERE PortfolioName ='General');
OPEN ProjectCursor;
FETCH NEXT FROM ProjectCursor INTO@ProjectID;
WHILE @@FETCH_STATUS=0BEGIN-- Check if EmployeeNWName is already in the ProjectResource table for the current ProjectID
IF NOTEXISTS (
SELECT1FROM ProjectResource
WHERE ProjectID =@ProjectIDAND EmployeeNWName =@EmployeeNWName
)
BEGIN-- Insert the EmployeeNWName into the ProjectResource tableINSERTINTO ProjectResource (ProjectID, EmployeeNWName, ResourceStartDate, Active)
VALUES (@ProjectID, @EmployeeNWName, GETDATE(), 1); -- Assuming Active and StartDateENDFETCH NEXT FROM ProjectCursor INTO@ProjectID;
ENDCLOSE ProjectCursor;
DEALLOCATE ProjectCursor;
END;
Updated Stored Procedure
sql
ALTERPROCEDURE [TT].[SP_GetMissingTimesheets]
ASBEGINDECLARE@TodayDATE= GETDATE();
DECLARE@WeekStartDateDATE;
DECLARE@WeekEndDateDATE;
-- Clear previous entries in the MissingTimesheets table (optional)-- DELETE FROM MissingTimesheets WHERE Created < DATEADD(WEEK, -5, GETDATE());-- Loop through the past 5 weeksDECLARE@WeekOffsetINT=1;
-- Truncate the MissingTimesheets table to clear any existing dataTRUNCATETABLE MissingTimesheets;
WHILE @WeekOffset<5BEGIN-- Calculate the start and end dates of the week using the functionSELECT@WeekStartDate= WeekStartDate, @WeekEndDate= WeekEndDate
FROM Fun_GetWeekStartEndDate(@Today, -@WeekOffset);
-- Insert missing timesheets into the permanent tableINSERTINTO MissingTimesheets (EmployeeEmail, WeekStartDate, WeekEndDate)
SELECT E.EmployeeEmail, @WeekStartDate, @WeekEndDateFROM Resource E
LEFTJOIN TimeSheet TS
ON E.EmployeeNWName = TS.EmployeeNWName
AND TS.TimeSheetStartDate =@WeekStartDateAND TS.TimeSheetEndDate =@WeekEndDateWHERE TS.TimeSheetID ISNULLOR TS.TimeSheetStatus IN ('Not Started', 'Saved', 'Returned');
SET@WeekOffset=@WeekOffset+1;
END-- Select and format the missing timesheetsSELECTROW_NUMBER() OVER (ORDERBY EmployeeEmail) AS MissingTimesheetID,
E.EmployeeNWName,
E.EmployeeEmail,
E.EmployeeDisplayName,
'<ul>'+ STRING_AGG('<li>'+CONVERT(VARCHAR, M.WeekStartDate, 101) +' - '+CONVERT(VARCHAR, M.WeekEndDate, 101) +'</li>', '') +'</ul>'AS MissingWeeks
FROM
MissingTimesheets M
JOIN Resource E ON M.EmployeeEmail = E.EmployeeEmail
WHERE
M.Created >= DATEADD(WEEK, -5, @Today)
GROUPBY
E.EmployeeNWName,
E.EmployeeEmail,
E.EmployeeDisplayName;
END;
sql
CREATEPROCEDURE SP_FindMissingTimesheets
ASBEGINDECLARE@TodayDATE= GETDATE();
DECLARE@WeekStartDateDATE;
DECLARE@WeekEndDateDATE;
-- Clear previous entries in the MissingTimesheets table (optional)-- DELETE FROM MissingTimesheets WHERE Created < DATEADD(WEEK, -5, GETDATE());-- Loop through the past 5 weeksDECLARE@WeekOffsetINT=0;
WHILE @WeekOffset<5BEGIN-- Calculate the start and end dates of the week using the functionSELECT@WeekStartDate= WeekStartDate, @WeekEndDate= WeekEndDate
FROM dbo.Fun_GetWeekStartEndDate(@Today, -@WeekOffset);
-- Insert missing timesheets into the permanent tableINSERTINTO MissingTimesheets (EmployeeEmail, WeekStartDate, WeekEndDate)
SELECT E.EmployeeEmail, @WeekStartDate, @WeekEndDateFROM Resource E
LEFTJOIN TimeSheet TS
ON E.EmployeeNWName = TS.EmployeeNWName
AND TS.TimeSheetStartDate =@WeekStartDateAND TS.TimeSheetEndDate =@WeekEndDateWHERE TS.TimeSheetID ISNULLOR TS.Status IN ('Not Started', 'Saved');
SET@WeekOffset=@WeekOffset+1;
END-- Select and format the missing timesheetsSELECTROW_NUMBER() OVER (ORDERBY EmployeeEmail) AS ID,
EmployeeEmail,
'<ul>'+ STRING_AGG('<li>'+CONVERT(VARCHAR, WeekStartDate, 101) +' - '+CONVERT(VARCHAR, WeekEndDate, 101) +'</li>', '') +'</ul>'AS MissingWeeks
FROM
MissingTimesheets
WHERE
Created >= DATEADD(WEEK, -5, @Today)
GROUPBY
EmployeeEmail;
END;
K2 workflow instances bloats the database over the time period and at some point you would want to delete the old workflow instance which are completed or in error status.
Unfortunately, there is no way to delete specific instances of workflow, in other words, you could not select specific instance and delete them. However, you can delete then in a bulk.
For instance, you would want to delete old workflow instances, which are completed and occupying the significant space in database. Instances where you are not going to report anything. Or, you just want to delete then as a part of clean up activity.
You can follow below steps to do so.
If you have 4.7 vision installed you can go to management workspace. For older version, you can follow similar steps
Expand workflow server node.
Go to your category to find workflow for which you want to delete workflow instances.
Click on versions.
Select version you want to delete.
6. Check “Delete all historical (log) data for selected versions”
Be careful though, “Delete all historical (log) data for selected versions” option deletes all workflow instances including active as well. Basically, it wipes out all the instances for that version from k2 database.
I asked the question to k2 support, What is the difference between Create and generate smartobject? and they provided below answer, thought would be helpful to share.
There are three different options available to create/manage SmartObject from a SQL Service Instance via SmartObject Service Tester tool:
a. From service instance > Create SmartObjects
- manages the creation and updates of all SQL SmartObjects of the service instance as well as SmartObject's category as a set (no control over displayname and guid)
- allows for the appending of a string to all of the SmartObject system name (no control over the overall displayname, systemname, guid)
- can be used to update all SmartObject as a set if there are changes to the database objects schema(tables, views, sprocs)
- displayname, systemname and guid will remain the same (if targeting the same set of SmartObject)
b. From service instance > Generate SmartObjects
- manages the creation and updates of all SQL SmartObjects of the service instance as a set (no control over displayname, systemname, category, guid)
- can be used to update all SmartObject as a set if there are changes to the database objects schema (tables, views, sprocs)
- displayname, systemname and guid will remain the same
c. From Service Object > Create SmartObject (singular)
- allows for managing of the SystemName/DisplayName, GUID, and category SmartObject is created in
- can be used to regenerate/update the existing SmartObject by targeting the 'SystemName' of the SmartObject (with the 'Check Name' button) and returning the current GUID for this SmartObject (with the 'Get Existing Guid' button) before publishing it again
** if not returning the existing name and GUID, a new SmartObject with different value will be created
* all three options mainly used if there are NO customization with the SmartObject and the default generated functionality is desired; as regenerating the SmartObject with the same SystemName and GUID will remove any customization previously done; if SmartObject was customized, manually changes to these objects in the designer that they were designed in (K2 Designer, K2 Studio, K2 for Visual Studio) will preserve the customization.
How do you fix the process in errors?
1. Sometimes the error is because of network issues, some connection problem or no proper inputs. If you just go to the error profile in the workspace and retry the error it fixes the problem.
2. If above approach does not resolve the error you can use the K2 Process Management tool in Visual Studio.
As shown in the figure below. you can select process clicking View->K2 Process Management tool in visual studio. Select the process in error and open the process and fix the error.
After fixing the error, go back to the k2 process management and click redeploy the process.
You can provide the label and deploy the process. It will fix that instance of the process. Then you can fix the processes with similar error hitting the retry button and selecting the fixed version of the process.
The IPC (The Inter Process Communication) event wizard is normally used to implement a Parent-Child workflow or sub-workflow requirement.
Also it is useful when you want to split a larger workflow into sub-processes, when you have processes that are generically re-usable, or when you want to start multiple instances of a child workflow from a parent workflow.
You can use it to set Folio, Originator, and data field values for a Child workflow as part of the wizard.
There are two options while configuring the call to the child process Synchronous: Parent workflow waits for Child workflow to complete. Asynchronous: 'fire-and-forget' style, in which the Parent workflow continues immediately after starting the Child workflow.
Use advanced destination rules (Plan per Slot, No Destinations) to allow one Parent workflow to start multiple Children
What are different activity planning options in Advance destination rule? and explain them.
There are three main Activity Planning options: Plan Just Once, Plan Per Destination, and Plan Per Slot.
Plan Just Once :
This default option. K2 will execute the events in the Activity prior to the Client Event just one time, regardless of how many destinations or slots have been defined. The events after the Client event will be executed each time a user completes a task. This is the default behavior for Activities.
This option is most appropriate for high-volume scenarios where a large group gets the task but only one user will ever need to open the task.
When this option is selected, there is only one activity instance, which is shared amongst all destinations for the task. Plan per destination:
This approach is most often used when more than one person will open the task, and you need to capture input from each user into the same activity datafields.
K2 creates separate copies of the Activity Instance for each destination
Plan per destination – All at Once :
K2 will execute the events in the activity for each destination in the activity in parallel fashion. Each event in the activity is repeated for each destination, and then K2 moves on to the next event in the activity and repeats that event for each destination.
This planning option specifies that all destinations will get the task at the same time (Parallel). Any one of the destination users can open the task and complete it. If any of the outcomes are true for the activity, the other copies of the task are removed from the other user’s task lists, and K2 completes the activity.
Plan per destination – One at a Time : K2 will execute the events in the activity for each destination in the activity in serial fashion. K2 starts with the first destination and executes the Events in the activity once for that destination. If the Outcome is false, K2 moves on to the second destination and then executes the events in sequence for the second destination. This is repeated for each destination in the activity until the Outcome succeeds or no more destinations are available. Plan per slot – (no destinations) :
This setting is normally used for activities that only contain server events when you want to repeat the events in the activity N-number of times for each slot in the activity.
It is similar to the Plan Per Destination – All at Once setting except that K2 does not use the Destinations to determine how many times to execute the events but rather the number of slots specified on the next page of the Destination Rule wizard.
What is use of Update Design Templates in K2 visual studio workflows?
The purpose of this tool is to apply enhanced code templates when you have upgraded your K2 environment to a newer version of the platform.The Update Design Templates command in the K2 design tools will wipe out any customizations you may have applied because it restores the original templates for all items and will undo any customization.
What event is use to write a code in workflow?
Default server event wizard is used to write a code in workflow. It is only available in K2 for Visual studio.
How can be method be called from custom assembly or service?
There are alternative approaches to using code in your workflows:
1. You can add reference to the assembly and call method in a class adding using namespace reference in default server code event
2. You can use the Code Reference Event to call methods for referenced assemblies and services.
When a workflow must interact with a system that is not exposed as a K2 SmartObject, but you do not wish to write code, the code reference event comes to the rescue. This event can be used to call methods on web services (asmx), WCF services and assemblies (.NET and COM dll’s).
3. If you need to call the same assembly/Service multiple times, it is recommended to expose that assembly/Service as a SmartObject.
By using one of the available EndPoint Service Brokers,
By writing a custom Broker that exposes the necessary functions. This will allow you (and other designers) to call the methods in the Service/Assembly easily without having to write code.
What is Asynchronous server event?
Asynchronous Server Events are used when you want the server event to wait for an external system to call back. The external system will use a serial number to complete the task and tell the K2 server event to continue.
What are the different places in workflow you can enable and handle exception?
You can handle the exception at event, activity, line,
escalation rule, escalation action and at process level