Solved

C sharp user interface security/permissions

Posted on 2009-05-10
2
419 Views
Last Modified: 2013-12-17
I've searched the web for the last 2 days and cannot find what any help, so here I am.

I'm looking for c sharp samples on implementing a user interface security system. Not RBS. I need to be able to assign access permissions to add, edit or delete buttons on a form based on user or group level security.
0
Comment
Question by:gnixon14
[X]
Welcome to Experts Exchange

Add your voice to the tech community where 5M+ people just like you are talking about what matters.

  • Help others & share knowledge
  • Earn cash & points
  • Learn & ask questions
2 Comments
 
LVL 3

Accepted Solution

by:
nhenny2009 earned 500 total points
ID: 24350220
If I am understanding your question correctly, then try the code below to help you determine the users "group" membership then you can enable/disable buttons as needed based on their group membership.  Take a close look at "WindowsBuiltInRole"...this is what will allow you to do other checks besides "admin" as I have in the example below.

Hope this helps.
using System;
using System.Collections.Generic;
using System.Linq;
using System.Windows.Forms;
using System.Security.Principal;
 
 
namespace testingapp
{
    static class Program
    {
        /// <summary>
        /// The main entry point for the application.
        /// </summary>
        [STAThread]
        static void Main()
        {
            bool IsAdmin = false;
            AdminCheck AC = new AdminCheck();
            IsAdmin = AC.IsUserAdministrator();
            MessageBox.Show("Is user \"" + System.Environment.UserName + "\" is an Admin? " + IsAdmin.ToString(), "Admin Check"); 
            
        }
    }
 
    public class AdminCheck
    {
 
        /// <summary>
        /// method for checking to see if the logged in user
        /// is in the Administrator's group
        /// </summary>
        /// <returns></returns>
        public bool IsUserAdministrator()
        {
            //bool value to hold our return value
            bool isAdmin;
            try
            {
                //get the currently logged in user
                WindowsIdentity user = WindowsIdentity.GetCurrent();
                WindowsPrincipal principal = new WindowsPrincipal(user);
                isAdmin = principal.IsInRole(WindowsBuiltInRole.Administrator);
            }
            catch (UnauthorizedAccessException ex)
            {
                isAdmin = false;
                MessageBox.Show(ex.Message);
            }
            catch (Exception ex)
            {
                isAdmin = false;
                MessageBox.Show(ex.Message);
            }
            return isAdmin;
        }
 
    }
}

Open in new window

0
 

Author Comment

by:gnixon14
ID: 24370433
that might work, but I'm trying to avoid using Role Based Secuirty.
0

Featured Post

PeopleSoft Has Never Been Easier

PeopleSoft Adoption Made Smooth & Simple!

On-The-Job Training Is made Intuitive & Easy With WalkMe's On-Screen Guidance Tool.  Claim Your Free WalkMe Account Now

Question has a verified solution.

If you are experiencing a similar issue, please ask a related question

Suggested Solutions

Title # Comments Views Activity
ASP.NET Built-In Report Creator / Viewer 5 41
C# LINQ 5 43
vb.net application has warrnings about VB6 calls. 2 47
Windows Universal App 22 62
Many of us here at EE write code. Many of us write exceptional code; just as many of us write exception-prone code. As we all should know, exceptions are a mechanism for handling errors which are typically out of our control. From database errors, t…
This article shows how to deploy dynamic backgrounds to computers depending on the aspect ratio of display
With Secure Portal Encryption, the recipient is sent a link to their email address directing them to the email laundry delivery page. From there, the recipient will be required to enter a user name and password to enter the page. Once the recipient …

738 members asked questions and received personalized solutions in the past 7 days.

Join the community of 500,000 technology professionals and ask your questions.

Join & Ask a Question