/// <summary> /// Post the specified request. /// </summary> /// <param name="request">Request.</param> public object Post(WpsJobAddGroupRequestTep request) { var context = TepWebContext.GetWebContext(PagePrivileges.AdminOnly); try { context.Open(); context.LogInfo(this, string.Format("/job/wps/{{jobId}}/group POST jobId='{0}',Id='{1}'", request.JobId, request.Id)); WpsJob wps = WpsJob.FromIdentifier(context, request.JobId); var gids = wps.GetAuthorizedGroupIds(); List <int> ids = gids != null?gids.ToList() : new List <int>(); List <Group> groups = new List <Group>(); foreach (int id in ids) { groups.Add(Group.FromId(context, id)); } foreach (Group grp in groups) { if (grp.Id == request.Id) { return(new WebResponseBool(false)); } } wps.GrantPermissionsToGroups(new int[] { request.Id }); context.Close(); } catch (Exception e) { context.LogError(this, e.Message, e); context.Close(); throw e; } return(new WebResponseBool(true)); }
/// <summary> /// Put the specified request. /// </summary> /// <param name="request">Request.</param> public object Put(WpsJobUpdateGroupsRequestTep request) { var context = TepWebContext.GetWebContext(PagePrivileges.AdminOnly); try { context.Open(); context.LogInfo(this, string.Format("/job/wps/{{jobId}}/group PUT jobId='{0}',Id='{1}'", request.JobId, request.ToArray() != null ? string.Join(",", request.ToArray()) : "null")); WpsJob wps = WpsJob.FromIdentifier(context, request.JobId); string sql = String.Format("DELETE FROM wpsjob_perm WHERE id_wpsjob={0} AND id_grp IS NOT NULL;", wps.Id); context.Execute(sql); wps.GrantPermissionsToGroups(request.ToArray()); context.Close(); } catch (Exception e) { context.LogError(this, e.Message, e); context.Close(); throw e; } return(new WebResponseBool(true)); }