Gestion de sécurité sous SQL Server
I. Les différents modes de sécurité d'accès de SQL SERVER
SQL Server dispose d`un système de sécurité qui lui est propre.
Windows dispose également de son système de sécurité à travers les comptes utilisateurs.
SQL Server permet de fédérer (ou non) ces deux systèmes et propose deux modes d'accès :
- Le mode de sécurité intégrée qui utilise la Sécurité de Windows. De ce fait, les utilisateurs conservent un seul nom d'accès et un. Seul mot de passe pour Windows et SQL Server.
- Le mode de sécurité mixte (sécurité SQL Server ou Windows). Dans ce cas l'utilisateur peut se connecter au serveur SQL à partir de son compte Windows ou de son nom d`accès SQL qui peut alors être différent.
II. Principe de fonctionnement de la sécurité
Pour utiliser une base de données sur un serveur, il faut :
- Avoir la permission d'accéder à ce serveur, (chaque utilisateur doit posséder un nom d'accès au serveur appelé nom de connexion)
- Avoir la permission d'accéder à la base de données (chaque utilisateur doit posséder un nom d'utilisateur de la base de données)
- Chaque utilisateur de la base de données se verra attribuer des autorisations lui permettant de manipuler les différents objets de la base (table, vue, Procédures stockées...).
Les utilisateurs disposant d'un statut spécial On distingue trois utilisateurs particuliers :
L'administrateur de SQL Server qui a pour nom d'accès sa. ll dispose de tous les droits et n'a donc pas de nom d'utilisateur pour les bases de données.
Le créateur d'une base de données appelé également propriétaire de la base ou DBO (Data Base Owner). Il dispose de l'intégralité des permissions sur cette base.
Le créateur d'un objet dans une base de données (table, vue, procédure stockée, déclencheur ....) devient le propriétaire de cet objet (DBOO) et dispose de toutes les permissions sur cet objet.
Accès à un serveur SQL Server par authentification Windows
Le nom de connexion à un serveur SQL Server correspond au nom du compte Windows SQL Server n'est accessible qu'à partir de la validation d'ouverture de session.
Dans la base système "Master" sont stockés tous les noms de connexion et les mots de passe associés.
Créer une connexion à SQL Server
En mode sécurité Windows :
CREATE LOGIN nom_connexion
FROM WINDOWS
nom_connexion doit être un nom d'utilisateur ou de groupe Windows
En mode sécurité Mixte :
CREATE LOGIN nom_connexion
WITH PASSWORD = mon_mot_de_passe
Création d'un utilisateur de BD
CREATE USER nomUtilisateur [FOR LOGIN maConnexion]
Exemple :
create login con1
with password ='123'
create user Util1 for login con1
Gestion des droits
Il est possible de gérer l'attribution de privilèges au niveau du serveur, de la BD entière, au niveau d`un schéma particulier ou au niveau d'un objet particulier.
Les privilèges peuvent être accordés à un utilisateur ou un rôle de BD ou à une connexion serveur.
Un privilège peut être accordé (GRANT), retiré (REVOKE) quand il a été accordé, ou explicitement interdit (DENY) propre à SQL Server.
a. Droits d`utilisation de DDL
Ces droits permettront à des utilisateurs de créer leurs propres BD, tables, vues, procédures, fonctions
Accorder :
GRANT {ALL l permission [,. . . ]}
TO utilisateur [,. . . ]
WITH GRANT OPTION
Permission : nom de la (ou des) permission(s) de DDL explicitement accordée(s) ou toutes (ALL)
WITH GRANT OPTION : paramètre d`administration, indique que le détenteur de l'autorisation a également la possibilité d'accorder l'autorisation spécifiée à d'autres utilisateurs.
Exemple :
GRANT create database to Util1, Util2
GRANT create view To User3
Retirer :
REVOKE [GRANT OPTION FOR]
(ALL I permission [, . . .])
FROM utilisateur [, . . .]
[CASCADE]
GRANT OPTION FOR : pour retirer simplement le paramètre d'administration
CASCADE : si la permission retirée a été accordée WITH GRANT OPTION, CASCADE retirera également le privilège aux utilisateurs qui l`ont reçus ainsi de l`utilisateur concerné par la suppression initiale du privilège. SQL Server oblige d'ailleurs à mentionner CASCADE quand un droit a été accordé WITH GRANT OPTION
Exemple :
REVOKE create database FROM Util1
Interdire :
Permet d'interdire à un utilisateur l'utilisation d'un privilège même s'il en reçoit la permission soit directement, soit par appartenance à un groupe
DENY permission [, . . . ]
TO utlilsateur [, . . . ]
[CASCADE]
Exemple :
DENY create database TO Util1
b. Droits d'utilisation de DML
Ces droits permettront de fixer les autorisations sur les opérations de SELECT, INSERT, UPDATE, DELETE, EXECUTE portant sur des objets particuliers, accordées à des utilisateurs. Ces droits sont en général gérés par des propriétaires de l'objet.
Accorder :
GRANT {ALL | permission [(colonne [,. . ])] [,. . . ]}
ON Objet [(colonne, [, . . .]
TO utilisateur [, . . .]
WITH GRANT OPTION
Objet : correspond au nom complet (nomSchema.nomObjet)
Exemple :
GRANT ALL ON Client TO Util1
GRANT SELECT ON Compte TO Util2
GRANT INSERT,UPDATE,DELETE ON Mouvement TO Util1,Util2
Retirer :
REVOKE [GRANT OPTION FOR]
{ALL | permission[(colonne, [,. . . ])] [,. . ]}
ON Objet [(colonne, [,. . . ])]
{FROM|TO] utilisateur [,. . . ]
[CASCADE]
FROM, TO : synonymes : L'usage habituel consiste à utiliser To lors de l'accord et FROM lors du retrait d'un privilège.
Exemple :
REVOKE DELETE ON Client FROM Util1
Interdire :
DENY {ALL | permission[(colonne, [,. . . ])] [,. . ]}
ON Objet [(colonne, [,. . . ])]
TO utilisateur [,. . . ]
[CASCADE]
Exemple :
DENY DELETE ON Client TO Util1
III. Les rôles
Les rôles sont des ensembles "nommés" de droits, des sortes de profils-types. Ils permettent de gérer
Plus facilement l'octroi de privilèges en accordant ceux-ci aux rôles et en accordant ensuite un ou plusieurs rôles aux différents utilisateurs.
L'utilisateur peut ainsi disposer des droits qui lui ont été accordés directement ET de ceux accordés aux différents rôles auxquels il appartient.
a. SQL Server prévoit différents rôles prédéfinis
Le rôle" public" tous les utilisateurs le reçoivent et ne peuvent pas s'y soustraire. On peut bien sûr "configurer" le rôle public en accordant, retirant, ou interdisant telle ou telle permission.
b. Rôles définis par l'utilisateur
Il est possible de définir ses propres rôles. En particulier, ceux-ci seront utiles par exemple quand plusieurs utilisateurs Windows veulent effectuer les mêmes opérations mais qu'il n'existe pas de groupe Windows correspondant et bien sûr lorsque les utilisateurs ne sont pas authentifiés par Windows.
Pour pouvoir définir un rôle. Il faut être membre du rôle db_owner ou db_securityadmin (ou bien du rôle de serveur sysadmin.
On peut accorder un rôle à un autre rôle mais une imbrication répétée peut avoir comme conséquence des pertes de performance.
Créer le rôle
CREATE ROLE nom_role
c. Gestion des membres du rôle
Pour ajouter un utilisateur dans un rôle (càd accorder ce rôle à cet utilisateur)
sp_addrolemember. 'nom_rôle' , 'nom_utilisateur'
Exemple :
CREATE ROLE roleClient
GO
Exec sp_addrolemember 'roleClient', 'Util2'
GO
La procédure stockée système sp_droprolemember permet de sortir un utilisateur des membres du rôle :
sp_droproleinember 'nom rôle' , 'nom_utilisateur'
Exemple :
Exec sp_droprolemember 'roleClient', 'Util2'
d. Gestion des droits du rôle
Exemple :
GRANT ALL ON Client TO roleClient
GRANT SELECT ON Compte TO roleClient
GRANT INSERT,UPDATE,DELETE ON Mouvement TO roleClient,Util13U
REVOKE ALL ON Client TO roleClient
REVOKE SELECT ON Compte TO roleClient
REVOKE INSERT,UPDATE,DELETE ON Mouvement TO roleClient,Util13U
Pas encore de commentaires.
Ajouter un commentaire
Veuillez vous connecter pour ajouter un commentaire.