private void butSetAll_Click(object sender, EventArgs e) { if (gridMain.SelectedIndices.Length == 0) { MsgBox.Show(this, "Please select user first."); return; } GroupPermission perm; for (int i = 0; i < Enum.GetNames(typeof(Permissions)).Length; i++) { if (i == (int)Permissions.SecurityAdmin || i == (int)Permissions.StartupMultiUserOld || i == (int)Permissions.StartupSingleUserOld || i == (int)Permissions.EhrKeyAdd) { continue; } perm = GroupPermissions.GetPerm(SelectedGroupNum, (Permissions)i); if (perm == null) { perm = new GroupPermission(); perm.PermType = (Permissions)i; perm.UserGroupNum = SelectedGroupNum; try{ GroupPermissions.Insert(perm); } catch (Exception ex) { MessageBox.Show(ex.Message); } changed = true; } } FillTreePerm(); }
private void butOK_Click(object sender, System.EventArgs e) { if (textDate.errorProvider1.GetError(textDate) != "" ) { MsgBox.Show(this, "Please fix data entry errors first."); return; } int newerDays = PIn.Int(textDays.Text); if (newerDays > 3000) { MsgBox.Show(this, "Days must be less than 3000."); return; } Cur.NewerDays = newerDays; Cur.NewerDate = PIn.Date(textDate.Text); try{ if (Cur.IsNew) { GroupPermissions.Insert(Cur); } else { GroupPermissions.Update(Cur); } } catch (Exception ex) { MessageBox.Show(ex.Message); return; } DialogResult = DialogResult.OK; }
private void butOK_Click(object sender, System.EventArgs e) { if (textDate.errorProvider1.GetError(textDate) != "" || textDays.errorProvider1.GetError(textDays) != "") { MsgBox.Show(this, "Please fix data entry errors first."); return; } int newerDays = PIn.Int(textDays.Text); if (newerDays > GroupPermissions.NewerDaysMax) { MsgBox.Show(this, $"Days must be less than {GroupPermissions.NewerDaysMax.ToString()}."); return; } Cur.NewerDays = newerDays; Cur.NewerDate = PIn.Date(textDate.Text); try{ if (Cur.IsNew) { GroupPermissions.Insert(Cur); } else { GroupPermissions.Update(Cur); } SecurityLogs.MakeLogEntry(Permissions.SecurityAdmin, 0, $"Permission '{Cur.PermType}' granted to " + $"'{UserGroups.GetGroup(Cur.UserGroupNum).Description}'"); } catch (Exception ex) { MessageBox.Show(ex.Message); return; } DialogResult = DialogResult.OK; }
///<summary>Gives the current usergroup all permissions. There should only be one usergroup selected when this is called. Throws exceptions.</summary> public void SetAll() { if (_listUserGroupNums.Count != 1) { throw new Exception("SetAll may not be called when multiple usergroups are selected."); } GroupPermission perm; for (int i = 0; i < Enum.GetNames(typeof(Permissions)).Length; i++) { if (i == (int)Permissions.SecurityAdmin || i == (int)Permissions.StartupMultiUserOld || i == (int)Permissions.StartupSingleUserOld || i == (int)Permissions.EhrKeyAdd) { continue; } perm = GroupPermissions.GetPerm(_listUserGroupNums.First(), (Permissions)i); if (perm == null) { perm = new GroupPermission(); perm.PermType = (Permissions)i; perm.UserGroupNum = _listUserGroupNums.First(); try { GroupPermissions.Insert(perm); } catch (Exception ex) { MessageBox.Show(ex.Message); } } } //add all the report permissions as well List <DisplayReport> _listDisplayReportAll = DisplayReports.GetAll(false); foreach (DisplayReport report in _listDisplayReportAll) { if (GroupPermissions.HasPermission(_listUserGroupNums.First(), Permissions.Reports, report.DisplayReportNum)) { continue; //don't bother creating or adding the permission if the usergroup already has it. } perm = new GroupPermission(); perm.NewerDate = DateTime.MinValue; perm.NewerDays = 0; perm.PermType = Permissions.Reports; perm.UserGroupNum = _listUserGroupNums.First(); perm.FKey = report.DisplayReportNum; try { GroupPermissions.Insert(perm); } catch (Exception ex) { MessageBox.Show(ex.Message); } } FillTreePerm(); }
private DialogResult userControlSecurityTabs_ReportPermissionChecked(object sender,SecurityEventArgs e) { GroupPermission perm = e.Perm; FormReportSetup FormRS = new FormReportSetup(perm.UserGroupNum,true); FormRS.ShowDialog(); if(FormRS.DialogResult==DialogResult.Cancel) { return FormRS.DialogResult; } if(!FormRS.HasReportPerms) {//Only insert base Reports permission if the user actually has any reports allowed return FormRS.DialogResult; } try { GroupPermissions.Insert(perm); } catch(Exception ex) { MessageBox.Show(ex.Message); return DialogResult.Cancel; } return FormRS.DialogResult; }
private void treePermissions_MouseDown(object sender, System.Windows.Forms.MouseEventArgs e) { clickedPermNode = treePermissions.GetNodeAt(e.X, e.Y); if (clickedPermNode == null) { return; } //treePermissions.BeginUpdate(); if (clickedPermNode.Parent == null) //level 1 { if (e.X < 5 || e.X > 17) { return; } } else if (clickedPermNode.Parent.Parent == null) //level 2 { if (e.X < 24 || e.X > 36) { return; } } else if (clickedPermNode.Parent.Parent.Parent == null) //level 3 { if (e.X < 43 || e.X > 55) { return; } } if (clickedPermNode.ImageIndex == 1) //unchecked, so need to add a permission { GroupPermission perm = new GroupPermission(); perm.PermType = (Permissions)clickedPermNode.Tag; perm.UserGroupNum = SelectedGroupNum; if (GroupPermissions.PermTakesDates(perm.PermType)) { FormGroupPermEdit FormG = new FormGroupPermEdit(perm); FormG.IsNew = true; FormG.ShowDialog(); if (FormG.DialogResult == DialogResult.Cancel) { treePermissions.EndUpdate(); return; } } else { try{ GroupPermissions.Insert(perm); } catch (Exception ex) { MessageBox.Show(ex.Message); return; } } } else if (clickedPermNode.ImageIndex == 2) //checked, so need to delete the perm { try{ GroupPermissions.RemovePermission(SelectedGroupNum, (Permissions)clickedPermNode.Tag); } catch (Exception ex) { MessageBox.Show(ex.Message); return; } } FillTreePerm(); changed = true; }
///<summary>Toggles permissions based on the node the user has clicked. ///Will do nothing if in Read-Only mode or more than one usergroup is selected.</summary> private void treePermissions_MouseDown(object sender, System.Windows.Forms.MouseEventArgs e) { if (ReadOnly || _listUserGroupNums.Count != 1) { return; } _clickedPermNode = treePermissions.GetNodeAt(e.X, e.Y); if (_clickedPermNode == null) { return; } //Do nothing if the user didn't click on a check box. if (_clickedPermNode.Parent == null) //level 1 { if (e.X < 5 || e.X > 17) { return; } } else if (_clickedPermNode.Parent.Parent == null) //level 2 { if (e.X < 24 || e.X > 36) { return; } } else if (_clickedPermNode.Parent.Parent.Parent == null) //level 3 { if (e.X < 43 || e.X > 55) { return; } } //User clicked on a check box. Do stuff. if (_clickedPermNode.ImageIndex == 1) //unchecked, so need to add a permission { GroupPermission perm = new GroupPermission(); perm.PermType = (Permissions)_clickedPermNode.Tag; perm.UserGroupNum = _listUserGroupNums.First(); if (GroupPermissions.PermTakesDates(perm.PermType)) { perm.IsNew = true; //Call an event that bubbles back up to the calling Form. The event returns a dialog result so we know how to continue here. DialogResult result = GroupPermissionChecked?.Invoke(sender, new SecurityEventArgs(perm)) ?? DialogResult.Cancel; if (result == DialogResult.Cancel) { treePermissions.EndUpdate(); return; } } else if (perm.PermType == Permissions.Reports) //Reports permission is being checked. //Call an event that bubbles back up to the calling Form. The event returns a dialog result so we know how to continue here. { DialogResult result = ReportPermissionChecked?.Invoke(sender, new SecurityEventArgs(perm)) ?? DialogResult.Cancel; if (result == DialogResult.Cancel) { treePermissions.EndUpdate(); return; } } else { try { GroupPermissions.Insert(perm); SecurityLogs.MakeLogEntry(Permissions.SecurityAdmin, 0, "Permission '" + perm.PermType + "' granted to '" + UserGroups.GetGroup(perm.UserGroupNum).Description + "'"); } catch (Exception ex) { MessageBox.Show(ex.Message); return; } } if (perm.PermType.In(Permissions.ProcComplEdit, Permissions.ProcExistingEdit)) { //Adding ProcComplEdit full, so add ProcComplEditlimited too. //Do the same for EO and EC procs GroupPermission permLimited = GroupPermissions.GetPerm(_listUserGroupNums.First(), Permissions.ProcComplEditLimited); if (permLimited == null) { GroupPermissions.RefreshCache(); //refresh NewerDays/Date to add the same for ProcComplEditLimited perm = GroupPermissions.GetPerm(_listUserGroupNums.First(), perm.PermType); permLimited = new GroupPermission(); permLimited.NewerDate = perm.NewerDate; permLimited.NewerDays = perm.NewerDays; permLimited.UserGroupNum = perm.UserGroupNum; permLimited.PermType = Permissions.ProcComplEditLimited; try { GroupPermissions.Insert(permLimited); SecurityLogs.MakeLogEntry(Permissions.SecurityAdmin, 0, "Permission '" + perm.PermType + "' granted to '" + UserGroups.GetGroup(perm.UserGroupNum).Description + "'"); } catch (Exception ex) { MessageBox.Show(ex.Message); return; } } } } else if (_clickedPermNode.ImageIndex == 2) //checked, so need to delete the perm { try { GroupPermissions.RemovePermission(_listUserGroupNums.First(), (Permissions)_clickedPermNode.Tag); SecurityLogs.MakeLogEntry(Permissions.SecurityAdmin, 0, "Permission '" + _clickedPermNode.Tag + "' revoked from '" + UserGroups.GetGroup(_listUserGroupNums.First()).Description + "'"); } catch (Exception ex) { MessageBox.Show(ex.Message); return; } if ((Permissions)_clickedPermNode.Tag == Permissions.ProcComplEditLimited) { //Deselecting ProcComplEditLimted, deselect ProcComplEdit and ProcExistingEdit permissions if present. List <Permissions> listPermissions = new List <Permissions>(); if (GroupPermissions.HasPermission(_listUserGroupNums.First(), Permissions.ProcComplEdit, 0)) { listPermissions.Add(Permissions.ProcComplEdit); } if (GroupPermissions.HasPermission(_listUserGroupNums.First(), Permissions.ProcExistingEdit, 0)) { listPermissions.Add(Permissions.ProcExistingEdit); } listPermissions.ForEach(x => { try { GroupPermissions.RemovePermission(_listUserGroupNums.First(), x); SecurityLogs.MakeLogEntry(Permissions.SecurityAdmin, 0, "Permission '" + _clickedPermNode.Tag + "' revoked from '" + UserGroups.GetGroup(_listUserGroupNums.First()).Description + "'"); } catch (Exception ex) { MessageBox.Show(ex.Message); return; } }); } } else if (_clickedPermNode.ImageIndex == 3) //Partially checked (currently only applies to Reports permission) { try { GroupPermissions.RemovePermission(_listUserGroupNums.First(), (Permissions)_clickedPermNode.Tag); SecurityLogs.MakeLogEntry(Permissions.SecurityAdmin, 0, "Permission '" + _clickedPermNode.Tag + "' revoked from '" + UserGroups.GetGroup(_listUserGroupNums.First()).Description + "'"); } catch (Exception ex) { MessageBox.Show(ex.Message); return; } } if ((Permissions)_clickedPermNode.Tag == Permissions.AccountProcsQuickAdd) { string programName = PrefC.GetString(PrefName.SoftwareName); MsgBox.Show(this, programName + " needs to be restarted on workstations before the changes will take place."); } FillTreePerm(); }