Thor Logo dbatools

Revoke-DbaAgPermission

View Source
Chrissy LeMaire (@cl), netnerds.net
Windows, Linux, macOS

Synopsis

Revokes permissions from SQL Server logins on database mirroring endpoints or availability groups.

Description

Removes specific permissions from SQL Server logins on either database mirroring endpoints or availability groups. This is commonly needed when service accounts change roles, security policies require permission reductions, or during availability group maintenance and troubleshooting. For endpoints, you can revoke most standard permissions like Connect, Alter, and Control. For availability groups, only Alter, Control, TakeOwnership, and ViewDefinition permissions can be revoked.

Syntax

Revoke-DbaAgPermission
    [[-SqlInstance] <DbaInstanceParameter[]>]
    [[-SqlCredential] <PSCredential>]
    [[-Login] <String[]>]
    [[-AvailabilityGroup] <String[]>]
    [-Type] <String[]>
    [[-Permission] <String[]>]
    [[-InputObject] <Login[]>]
    [-EnableException]
    [-WhatIf]
    [-Confirm]
    [<CommonParameters>]

 

Examples

 

Example: 1
PS C:\> Revoke-DbaAgPermission -SqlInstance sql2017a -Type AvailabilityGroup -AvailabilityGroup SharePoint -Login ad\spservice -Permission CreateAnyDatabase

Removes CreateAnyDatabase permissions from ad\spservice on the SharePoint availability group on sql2017a. Does not prompt for confirmation.

Example: 2
PS C:\> Revoke-DbaAgPermission -SqlInstance sql2017a -Type AvailabilityGroup -AvailabilityGroup ag1, ag2 -Login ad\spservice -Permission CreateAnyDatabase -Confirm

Removes CreateAnyDatabase permissions from ad\spservice on the ag1 and ag2 availability groups on sql2017a. Prompts for confirmation.

Example: 3
PS C:\> Get-DbaLogin -SqlInstance sql2017a | Out-GridView -Passthru | Revoke-DbaAgPermission -Type EndPoint

Revokes the selected logins Connect permissions on the DatabaseMirroring endpoint for sql2017a.

Required Parameters

-Type

Determines whether to revoke permissions on database mirroring endpoints or availability groups. This parameter is mandatory.
Use ‘Endpoint’ to revoke permissions on the DatabaseMirroring endpoint, typically needed for Always On setup or mirroring configurations.
Use ‘AvailabilityGroup’ to revoke permissions directly on specific availability group objects for more granular security control.

PropertyValue
Alias
RequiredTrue
Pipelinefalse
Default Value
Accepted ValuesEndpoint,AvailabilityGroup

Optional Parameters

-SqlInstance

The target SQL Server instance or instances. Server version must be SQL Server version 2012 or higher.

PropertyValue
Alias
RequiredFalse
Pipelinefalse
Default Value
-SqlCredential

Login to the target instance using alternative credentials. Accepts PowerShell credentials (Get-Credential).
Windows Authentication, SQL Server Authentication, Active Directory - Password, and Active Directory - Integrated are all supported.
For MFA support, please use Connect-DbaInstance.

PropertyValue
Alias
RequiredFalse
Pipelinefalse
Default Value
-Login

Specifies the SQL Server logins or Windows accounts to remove permissions from. Required when using the SqlInstance parameter.
Use this when you need to revoke access from service accounts, developers, or other principals that no longer need endpoint or availability group permissions.
If the specified login doesn’t exist, the function will attempt to create it first.

PropertyValue
Alias
RequiredFalse
Pipelinefalse
Default Value
-AvailabilityGroup

Specifies which availability groups to target for permission revocation. Required when using Type ‘AvailabilityGroup’.
Use this to limit the scope when you only want to revoke permissions on specific AGs rather than all availability groups in the instance.
Accepts multiple availability group names for bulk operations.

PropertyValue
Alias
RequiredFalse
Pipelinefalse
Default Value
-Permission

Specifies which permissions to revoke from the targeted logins. Defaults to ‘Connect’ if not specified.
For endpoints, most permissions are valid including Connect, Alter, and Control. CreateAnyDatabase is not supported for endpoints.
For availability groups, only Alter, Control, TakeOwnership, and ViewDefinition are supported.
Use Connect for basic endpoint access, Alter for configuration changes, Control for full permissions, or ViewDefinition for read-only metadata access.

PropertyValue
Alias
RequiredFalse
Pipelinefalse
Default ValueConnect
Accepted ValuesAlter,Connect,Control,CreateAnyDatabase,CreateSequence,Delete,Execute,Impersonate,Insert,Receive,References,Select,Send,TakeOwnership,Update,ViewChangeTracking,ViewDefinition
-InputObject

Accepts SQL Server login objects from the pipeline, typically from Get-DbaLogin.
Use this approach when you want to filter or select specific logins before revoking permissions, or when combining with other dbatools commands.
This parameter provides an alternative to specifying SqlInstance and Login parameters directly.

PropertyValue
Alias
RequiredFalse
Pipelinetrue (ByValue)
Default Value
-EnableException

By default, when something goes wrong we try to catch it, interpret it and give you a friendly warning message.
This avoids overwhelming you with “sea of red” exceptions, but is inconvenient because it basically disables advanced scripting.
Using this switch turns this “nice by default” feature off and enables you to catch exceptions with your own try/catch.

PropertyValue
Alias
RequiredFalse
Pipelinefalse
Default ValueFalse
-WhatIf

Shows what would happen if the command were to run. No actions are actually performed.

PropertyValue
Aliaswi
RequiredFalse
Pipelinefalse
Default Value
-Confirm

Prompts you for confirmation before executing any changing operations within the command.

PropertyValue
Aliascf
RequiredFalse
Pipelinefalse
Default Value