地下室的流星雨
看一个人是否聪明看他的答案;看一个人是否有智慧看他的问题。

Sharepoint 2007中,用SPD设计的工作流并没有提供任务重新指派的功能,但是在某些场景下,我们确实很需要这样的功能,但是如何实现呢?

界面上就很简单了,无非就是在下拉菜单中添加一个操作项“重新指派”就可以了,使用Feature就可以了,不再多讲。

但是后台如何实现呢?我们最直接想到的方法就是将“分配对象”属性直接设置为其他用户:

代码如下:

//test reassign
                SPSecurity.RunWithElevatedPrivileges(delegate()
                {
                    using (SPSite spsite = new SPSite("http://localhost:1000/yoursite%22))
                    using (SPWeb spweb = spsite.OpenWeb())
                    {

                        SPList list = spweb.Lists["工作任务"];
                        SPListItem task1 = list.GetItemById(1);
                        task1[SPBuiltInFieldId.AssignedTo] = spweb.SiteUsers["zhangsan"];
                        task1.Update();

                    }
                });
//end test reassign

运行的时候你会发现,执行到task1.Update(); 的时候,会扔出一个异常“此任务当前被某个正在运行的工作流锁定,无法对其进行编辑。”

如果你不用task1.Update(),而是用task1.SystemUpdate(),那么虽然能够成功更新“分配对象”,但是在完成任务时会有如下问题“数据源控件未能执行更新命令”:

所以用SystemUpdate()不行,我认为SystemUpdate是绕过了工作流的一些触发操作,从而导致任务不可用。

所以仍然检查第一个异常产生的原因,我一直认为工作流有可能对正在运行的任务进行了“Lock”处理,于是反复在Microsoft.SharePoint.Workflow寻找加锁和解锁的处理机制,结果均没有找到,经过多次尝试、反编译和查找资料,发现在类“Microsoft.SharePoint.Workflow.SPWinOEItemReceiver”中,扔出了该异常,如下:

SPResource.GetString("WorkflowTaskLocked", new object[0]);

而扔出该异常的条件是:

((int) itemById[SPBuiltInFieldId.WorkflowVersion]) != 1

很奇怪的现象!

于是修改了代码,做了如下处理:

//test reassign
                SPSecurity.RunWithElevatedPrivileges(delegate()
                {
                    using (SPSite spsite = new SPSite("http://localhost:1000/yoursite%22))
                    using (SPWeb spweb = spsite.OpenWeb())
                    {

                        SPList list = spweb.Lists["工作任务"];
                        SPListItem task1 = list.GetItemById(1);

                        task1[SPBuiltInFieldId.WorkflowVersion] = 1;
                        task1[SPBuiltInFieldId.AssignedTo] = spweb.SiteUsers["zhangsan"];
                        task1.Update();

                    }
                });
//end test reassign

结果成功!

原来是类SPWinOEItemReceiver的ItemUpdating(SPItemEventProperties properties)监听了Task的更新事件,如果task1[SPBuiltInFieldId.WorkflowVersion]不等于1,那么则扔出“此任务当前被某个正在运行的工作流锁定,无法对其进行编辑。”,这是一个容易让人迷惑的信息。

目前还不是很明白Sharepoint这样设置

跟我遇到类似的问题:http://geekswithblogs.net/MTex/archive/2008/03/01/120117.aspx

                            http://geek.hubkey.com/2007/09/locked-workflow.html

用上述的方法,可以实现工作流任务的的重新指派。

更进一步的完善,可以考虑和OutLook日历相结合,实现自动委派。

 

本文转自:http://www.cnblogs.com/HeavyMetal/archive/2009/09/03/1559681.html

posted on 2010-08-28 11:21  地下室的流星雨  阅读(1109)  评论(0编辑  收藏  举报