1

我尝试使用项目服务器 2013 CSOM 更新任务状态进度(状态分配),但出现“未知错误”异常和以下 StackTrace:

在 Microsoft.SharePoint.Client.ClientRequest.ProcessResponseStream(Stream responseStream) 在 Microsoft.SharePoint.Client.ClientRequest.ProcessResponse() 在 Limitless.Components.Project2013.ProjectComponent.UpdateTask(ProjectServerConnection 连接,Guid ProjectUID,List`1 数据)

ProjectContext context = GetProjectContext(connection);
// Get the user name  and their assignments
EnterpriseResource self = EnterpriseResource.GetSelf(context);
context.Load(self, r => r.Name, r => r.Assignments
    .IncludeWithDefaultProperties(a => a.Project, a=>a.Comments));
context.ExecuteQuery();
foreach(var item in self.Assignments)
{
    Entities.Task task = data.Where(t => t.ID == item.Id).SingleOrDefault();
    if(task!= null)
    {
        item.PercentComplete = (short)task.PercentComplete;
        item.Comments = "comment";
    }
}

// Update the assignments and submit the status updates.
self.Assignments.Update();
self.Assignments.SubmitAllStatusUpdates("By PS Web App");
context.ExecuteQuery();

我在共享点日志中找不到任何错误。它是全新安装的 Project Server 2013,它成功检索了任务(StatusAssignments),但之后self.Assignments.Update();抛出 self.Assignments.SubmitAllStatusUpdates("By PS Web App");异常context.ExecuteQuery();

有人遇到过这种情况吗?

4

1 回答 1

0

我希望对于面临同样问题的任何人来说都不算晚,这已经解决并正常工作,但我不确定这是否是正确的方法。

我没有通过当前用户上下文更新 TaskAssignment,而是使用提升的上下文(例如管理上下文)来获取它,并获取资源的分配并更新它们。

//private function to get admin context
ProjectContext elevatedContext = GetProjectElevatedContext(connection);
//private function to get current user context
ProjectContext context = GetProjectContext(connection);

// Get the user name  and their assignments
EnterpriseResource self = EnterpriseResource.GetSelf(context);
context.Load(self, r => r.Id, r => r.Assignments.IncludeWithDefaultProperties(a => a.ActualFinish));
context.ExecuteQuery();

var resource = elevatedContext.EnterpriseResources.GetById(self.Id.ToString());
elevatedContext.Load(resource, r => r.Assignments
    .IncludeWithDefaultProperties(a => a.Project, a => a.Comments, a => a.PercentComplete));
elevatedContext.ExecuteQuery();

int count = 0;

foreach (var item in resource.Assignments)
{
    Entities.Task task = data.Where(t => t.ID == item.Id).SingleOrDefault();
    if (task != null)
    {
        item.PercentComplete = (short)task.PercentComplete;
        item.Comments = "comment";
        count++;
    }
}

resource.Assignments.Update();
resource.Assignments.SubmitAllStatusUpdates($"comment");
elevatedContext.ExecuteQuery();

我找不到 CSOM 授予此类功能的权限。

如果有人有更好的测试解决方案,请贡献:)

于 2018-08-09T08:27:33.973 回答