Delegation (computer security)
Delegation is the process of a computer user handing over their authentication credentials to another user.[1][2] In role-based access control models, delegation of authority involves delegating roles that a user can assume or the set of permissions that he can acquire, to other users.[3]
Types of delegation in IT networks[]
There are essentially two classes of delegation: delegation at Authentication/Identity Level, and delegation at Authorization/Access Control Level.
Delegation at Authentication/Identity level[]
It is defined as follows: If an authentication mechanism provides an effective identity different from the validated identity of the user then it is called identity delegation at the authentication level, provided the owner of the effective identity has previously authorized the owner of the validated identity to use his identity.[4]
The existing techniques of identity delegation using sudo
or su
commands of UNIX are very popular.[citation needed] To use the sudo
command, a person first has to start his session with his own original identity. It requires the delegated account password or explicit authorizations granted by the system administrator. The user login delegation described in the patent of Mercredi and Frey is also an identity delegation.[5]
Delegation at Authorization/Access Control level[]
The most common way of ensuring computer security is access control mechanisms provided by operating systems such as UNIX, Linux, Windows, Mac OS, etc.[6]
If the delegation is for very specific rights, also known as fine-grained, such as with Role-based access control (RBAC) delegation, then there is always a risk of under-delegation, i.e., the delegator does not delegate all the necessary permissions to perform a delegated job. This may cause the denial of service, which is very undesirable in some environments, such as in safety critical systems or in health care. In RBAC-based delegation, one option to achieve delegation is by reassigning a set of permissions to the role of a delegatee; however, finding the relevant permissions for a particular job is not an easy task for large and complex systems. Moreover, by assigning these permissions to a delegatee role, all other users who are associated with that particular role get the delegated rights.
If the delegation is achieved by assigning the roles of a delegator to a delegatee then it would not only be a case of over-delegation but also the problem that the delegator has to figure out what roles, in the complex hierarchy of RBAC, are necessary to perform a particular job. These types of problems are not present in identity delegation mechanisms and normally the user interface is simpler.
More details can be found at RBAC.
References[]
- ^ Barka, E., Sandhu, R.: A role-based delegation model and some extensions. In: Proceedings of 16th Annual Computer Security Application Conference, New Orleans, U.S.A. (December 2000)
- ^ A mechanism for identity delegation at authentication level, N Ahmed, CD Jensen - Proceedings of the 14th Nordic Conference …, 2009 - portal.acm.org, 2009
- ^ "Fine-grained role-based delegation in presence of the hybrid role hierarchy". Purdue University. 2006. Retrieved March 29, 2014.
- ^ A mechanism for identity delegation at authentication level, N Ahmed, CD Jensen - Proceedings of the 14th Nordic Conference …, 2009 - portal.acm.org, 2009
- ^ Mercredi, Frey: User login delegation. United States Patent Application Publication, US 2004/0015702 A1 2004
- ^ Gollmann, D.: Computer Security 2e. John Wiley and Sons, Chichester (2005)
- Computer access control