UNIT 5 (Database Security)
• Database Security means to keep sensitive
  information safe and prevent the loss of data.
  Security of data base is controlled by Database
  Administrator (DBA).
• The following are the main control measures are
  used to provide security of data in databases:
• 1. Authentication 2. Access control 3. Inference
  control 4. Flow control 5. Database Security
  applying Statistical Method 6. Encryption
• Authentication                                              :
  Authentication is the process of confirmation that whether
  the user log in only according to the rights provided to him
  to perform the activities of data base.
• A particular user can login only up to his privilege but he
  can’t access the other sensitive data. The privilege of
  accessing sensitive data is restricted by using
  Authentication .
• By using these authentication tools for biometrics such as
  retina and figure prints can prevent the data base from
  unauthorized/malicious users.
    Authentication/Authorization
• A fundamental step in securing a database
  system is validating the identity of the user
  who is accessing the database (authentication)
  and controlling what operations they can
  perform (authorization). A strong
  authentication and authorization strategy
  helps protect the users and their data from
  attackers.
                               Authorization
Authorization is a privilege provided by the Database Administer. Users of the database can
only view the contents they are authorized to view. The rest of the database is out of
bounds to them.
The different permissions for authorizations available are:
Primary Permission -  This is granted to users publicly and directly.
Secondary Permission -  This is granted to groups and automatically awarded to a user if he
is a member of the group.
Public Permission -  This is publicly granted to all the users.
Context sensitive permission -  This is related to sensitive content and only granted to a
select users.
The categories of authorization that can be given to users are:
System Administrator -  This is the highest administrative authorization for a user. Users
with this authorization can also execute some database administrator commands such as
restore or upgrade a database.
System Control -  This is the highest control authorization for a user. This allows
maintenance operations on the database but not direct access to data.
System Maintenance -  This is the lower level of system control authority. It also allows
users to maintain the database but within a database manager instance.
System Monitor -  Using this authority, the user can monitor the database and take
snapshots of it.
                  Access Control
• After the authentication process has been completed,
  user authorization can be determined by Access Control.
• The term Access Control actually refers to the control over
  access to system resources after a user's account
  credentials and identity have been authenticated and
  access to the system granted.
• For example, a particular user, or group of users, might
  only be permitted access to certain files after logging into
  a system, while simultaneously being denied access to all
  other resources.
          ACCESS CONTROL MODELS
• ACCESS CONTROL MODEL –
• MAC- Mandatory access control
• DAC -Discretionary access control
• RAC-Role Based access control
 MANDATORY ACCESS CONTROL (MAC)
 MANDATORY ACCESS CONTROL (MAC) - OPPOSITE OF
DAC AND IS MOST RESTRICTIVE ACCESS CONTROL
MODEL
 • Mandatory access control establishes strict security
policies for individual users and the resources, systems,
or data they are allowed to access.
These policies are controlled by an administrator;
individual users are not given the authority to set, alter,
or revoke permissions in a way that contradicts existing
policies.
                              MAC
• Under this system, both the subject (user) and the object (data,
  system, or other resource) must be assigned similar security
  attributes in order to interact with each other.
• MAC takes a hierarchical approach to controlling access to
  resources. Under a MAC enforced environment access to all
  resource objects (such as data files) is controlled by settings
  defined by the system administrator.
• As such, all access to resource objects is strictly controlled by the
  operating system based on system administrator configured
  settings.
• It is not possible under MAC enforcement for users to change the
  access control of a resource.
                                     MAC
• Mandatory Access Control begins with security labels assigned to all resource
  objects on the system. These security labels contain two pieces of information - a
  classification (top secret, confidential etc) and a category (which is essentially an
  indication of the management level, department or project to which the object is
  available).
• Similarly, each user account on the system also has classification and category
  properties from the same set of properties applied to the resource objects.
• When a user attempts to access a resource under Mandatory Access Control the
  operating system checks the user's classification and categories and compares
  them to the properties of the object's security label.
• If the user's credentials match the MAC security label properties of the object
  access is allowed. It is important to note that both the classification and
  categories must match.
• A user with top secret classification, for example, cannot access a resource if they
  are not also a member of one of the required categories for that object.
                       MAC
• Mandatory Access Control is by far the most secure
  access control environment but does not come
  without a price.
• Firstly, MAC requires a considerable amount of
  planning before it can be effectively implemented.
• Once implemented it also imposes a high system
  management overhead due to the need to constantly
  update object and account labels to accommodate
  new data, new users and changes in the categorization
  and classification of existing users.
                          2. DAC
Least Restrictive Model
Once a user is given permission to access an object (usually by a
system administrator or through an existing access control list),
they can grant access to other users on an as-needed basis.
Unlike Mandatory Access Control (MAC) where access to system
resources is controlled by the operating system (under the
control of a system administrator), Discretionary Access Control
(DAC) allows each user to control access to their own data.
DAC is typically the default access control mechanism for most
desktop operating systems.
•
                                     DAC
• Instead of a security label in the case of MAC, each resource object on a DAC
  based system has an Access Control List (ACL) associated with it.
• An ACL contains a list of users and groups to which the user has permitted access
  together with the level of access for each user or group. For example, User A may
  provide read-only access on one of her files to User B, read and write access on
  the same file to User C and full control to any user belonging to Group 1.
• It is important to note that under DAC a user can only set access permissions for
  resources which they already own.
• A hypothetical User A cannot, therefore, change the access control for a file that
  is owned by User B. User A can, however, set access permissions on a file that she
  owns.
• Discretionary Access Control provides a much more flexible environment than
  Mandatory Access Control but also increases the risk that data will be made
  accessible to users that should not necessarily be given access.
     ROLE BASED ACCESS CONTROL (RBAC)
• ROLE BASED ACCESS CONTROL (RBAC) - CONSIDERED
  MORE “REAL-WORLD” ACCESS CONTROL THAN OTHER
  MODELS BECAUSE ACCESS is BASED ON USER’S JOB
  FUNCTION WITHIN ORGANIZATION
• Essentially, RBAC assigns permissions to particular roles in
  an organization. Users are then assigned to that particular
  role. For example, an accountant in a company will be
  assigned to the Accountant role, gaining access to all the
  resources permitted for all accountants on the system.
  Similarly, a software engineer might be assigned to
  the developer role.
• Role-based access control establishes permissions
  based on groups (defined sets of users, such as bank
  employees) and roles (defined sets of actions, like those
  that a bank teller or a branch manager might perform).
• Individuals can perform any action that is assigned to
  their role, and may be assigned multiple roles as
  necessary.
• Like MAC, users are not permitted to change the level
  of access control that has been assigned to their role.