• Status: Solved
  • Priority: Medium
  • Security: Public
  • Views: 297
  • Last Modified:

PHP User Permissions

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
t3chguy
Asked:
t3chguy
  • 2
1 Solution
 
Ray PaseurCommented:
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
 
t3chguyAuthor Commented:
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
 
Ray PaseurCommented:
+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

Concerto Cloud for Software Providers & ISVs

Can Concerto Cloud Services help you focus on evolving your application offerings, while delivering the best cloud experience to your customers? From DevOps to revenue models and customer support, the answer is yes!

Learn how Concerto can help you.

  • 2
Tackle projects and never again get stuck behind a technical roadblock.
Join Now