Server.Grant Method (ServerPermissionSet, String[], Boolean, String)
Assembly: Microsoft.SqlServer.Smo (in microsoft.sqlserver.smo.dll)
public void Grant ( ServerPermissionSet permission, string[] granteeNames, bool grantGrant, string asRole )
public void Grant ( ServerPermissionSet permission, String[] granteeNames, boolean grantGrant, String asRole )
public function Grant ( permission : ServerPermissionSet, granteeNames : String[], grantGrant : boolean, asRole : String )
Parameters
- permission
A ServerPermissionSet object that specifies the permission.
- granteeNames
A String array that specifies a list of grantees to be granted the set of permissions.
- grantGrant
A Boolean property that specifies whether the grantee is given the ability to grant the set of permissions to other users on the instance of Microsoft SQL Server.
If True, the grantee is given the ability to grant the specified set of permissions to other users on the instance of Microsoft SQL Server.
If False, the grantee is not given the ability to grant the specified set of permissions to other users on the instance of Microsoft SQL Server.
- asRole
A String value that specifies the role that the user assumes when granting the specified set of permissions to other users on the instance of Microsoft SQL Server. Use this parameter for grantees who are members of more than one role.
'Connect to the local, default instance of SQL Server. Dim svr As Server svr = New Server() 'Define a ServerPermissionSet that contains permission to Create Endpoint and Alter Any Endpoint. Dim sps As ServerPermissionSet sps = New ServerPermissionSet(ServerPermission.CreateEndpoint) sps.Add(ServerPermission.AlterAnyEndpoint) 'This sample assumes that the grantee already has permission to Create Endpoints. 'Enumerate and display the server permissions in the set for the grantee specified in the vGrantee string variable. Dim spis As ServerPermissionInfo() spis = svr.EnumServerPermissions(vGrantee, sps) Dim spi As ServerPermissionInfo Console.WriteLine("=================Before revoke===========================") For Each spi In spis Console.WriteLine(spi.Grantee & " has " & spi.PermissionType.ToString & " permission.") Next Console.WriteLine(" ") 'Remove a permission from the set. sps.Remove(ServerPermission.CreateEndpoint) 'Revoke the create endpoint permission from the grantee. svr.Revoke(sps, vGrantee) 'Enumerate and display the server permissions in the set for the grantee specified in the vGrantee string variable. spis = svr.EnumServerPermissions(vGrantee, sps) Console.WriteLine("=================After revoke============================") For Each spi In spis Console.WriteLine(spi.Grantee & " has " & spi.PermissionType.ToString & " permission.") Next Console.WriteLine(" ") 'Grant the Create Endpoint permission to the grantee. svr.Grant(sps, vGrantee) 'Enumerate and display the server permissions in the set for the grantee specified in the vGrantee string variable. spis = svr.EnumServerPermissions(vGrantee, sps) Console.WriteLine("=================After grant=============================") For Each spi In spis Console.WriteLine(spi.Grantee & " has " & spi.PermissionType.ToString & " permission.") Next Console.WriteLine("")
