?
Solved

PHP User Permissions

Posted on 2013-10-29
3
Medium Priority
?
295 Views
Last Modified: 2013-10-29
I am working on a complete overhaul of our corporate intranet, and I'm looking for guidance regarding setting up user permissions.

Currently, we have about 65 applications, 350 users nationwide, and functions within each application.

Not all users have access to all applications, and if an employee does have access to an application, they may not have access to all functions within.

My line of thinking right now is this:
- Assign each application a unique Id.

- Assign each user permissions to the application ID's that they would need.

- Create a functions table that would hold function names, such as canEdit, canConvert,  canDelete, etc.

- Assign each user access to the functions they would need by either a 1 or a 0 value in the database table.

There clearly isn't a right or wrong answer to this, but I wanted to consult with an expert to get their opinion on my issue, as the articles I've read on the subject do not really clarify how many users or functions they are dealing with.

Thanks in advance!
0
Comment
Question by:t3chguy
[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
3 Comments
 
LVL 111

Accepted Solution

by:
Ray Paseur earned 2000 total points
ID: 39608688
I think you're on fairly firm ground with that kind of a design

You would have a one-to-many relationship between persons and applications, and a one-to-many relationship between person+application and permissions.  This would allow you to add or remove persons easily, join applications to persons, and allocate permissions to each person independently of the various applications they would use.  Initial setup may be a bit of work, but table maintenance will be a breeze for the administrator.
0
 
LVL 1

Author Closing Comment

by:t3chguy
ID: 39608752
Thank you sir!  Glad I got that clarification.  I'm going to be posting this same question in a MySQL section to see if a DBA can help layout these tables.

As a side note, you'll be pleased to know that my new revision of this corporate intranet will be utilizing PDO!
0
 
LVL 111

Expert Comment

by:Ray Paseur
ID: 39608802
+1 for PDO!  Thanks for the points and thanks for using EE, ~Ray

And just a note for going forward... You can choose up to three Zones when you post a question, so you can get a little more intellectual cross-pollination that way.
0

Featured Post

WordPress Tutorial 2: Terminology

An important part of learning any new piece of software is understanding the terminology it uses. Thankfully WordPress uses fairly simple names for everything that make it easy to start using the software.

Question has a verified solution.

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

Build an array called $myWeek which will hold the array elements Today, Yesterday and then builds up the rest of the week by the name of the day going back 1 week.   (CODE) (CODE) Then you just need to pass your date to the function. If i…
These days socially coordinated efforts have turned into a critical requirement for enterprises.
Learn how to match and substitute tagged data using PHP regular expressions. Demonstrated on Windows 7, but also applies to other operating systems. Demonstrated technique applies to PHP (all versions) and Firefox, but very similar techniques will w…
The viewer will learn how to dynamically set the form action using jQuery.
Suggested Courses

771 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