Programs execute in sandboxes called domains
Resources (objects) live in protection domains called types
Policies describe the ways those resources can be used through access vectors and transition rules
Each process or object has an associated security descriptor which consists of identity, role and domain.
At runtime when a process wants access to an object the security descriptors of both are matched and compared and access is only allowed when the policies allow it.
All access rules are kept in policy files and there are tens of thousands of access rules.
Roles define which domains a user can enter. They do not provide access by themselves.
A user can have several roles but only one active role at any time. No role merging is done. The system itself knows only four roles (system, staff, sysadm, user) and few installations add more roles.