Citrix Virtual Apps and Desktops SDK

Set-AcctDBConnection

Configures a database connection for the ADIdentity Service.

Syntax


Set-AcctDBConnection [-DBConnection] <String> [-Force] [-LoggingId <Guid>] [-BearerToken <String>] [-TraceParent <String>] [-TraceState <String>] [-VirtualSiteId <String>] [-AdminAddress <String>] [<CommonParameters>]

<!--NeedCopy-->

Detailed Description

Specifies the database connection string for use by the currently selected Citrix ADIdentity Service instance.

The service saves the connection string and attempts to contact the specified database. If the database cannot initially be contacted the service retries the connection at intervals until connection with the database is successfully established.

It is not possible to set a new database connection string for the service if one is already set. The connection string must first be set to $null. This action causes the service to reset and return to its idle state, at which point a new connection string can be set.

When a database connection string is successfully set for the service, a status of OK is returned by the cmdlet. If the database connection string is set to $null, a DBUnconfigured status is returned.

A syntactically invalid connection string is not saved.

Only Windows authentication is supported within the connection string; a connection string containing SQL authentication credentials is always rejected as invalid.

The current service instance is that on the local machine, or that explicitly specified by the last usage of the -AdminAddress parameter to a ADIdentity SDK cmdlet.

Parameters

Name Description Required? Pipeline Input Default Value
DBConnection Specifies the database connection string to be used by the ADIdentity Service. Passing in $null will clear any existing database connection configured. true false  
Force If present, allows the local administrator to set the connection string to null when there are problems contacting the database or other services. false false false
LoggingId Specifies the identifier of the high-level operation this cmdlet call forms a part of. Citrix Studio and Director typically create high-level operations. PowerShell scripts can also wrap a series of cmdlet calls in a high-level operation by way of the Start-LogHighLevelOperation and Stop-LogHighLevelOperation cmdlets. false false  
BearerToken Specifies the bearer token assigned to the calling user false false  
TraceParent Specifies the trace parent assigned for internal diagnostic tracing use false false  
TraceState Specifies the trace state assigned for internal diagnostic tracing use false false  
VirtualSiteId Specifies the virtual site the PowerShell snap-in will connect to. false false  
AdminAddress The address of a Citrix Virtual Apps and Desktops controller the PowerShell snap-in will connect to. You can provide this as a host name or an IP address. false false Localhost. Once a value is provided by any cmdlet, this value becomes the default.

Input Type

None

You cannot pipe input into this cmdlet.

Return Values

Citrix.Fma.Sdk.Utilities.Service.Servicestatusinfo

The Set-AcctDBConnection cmdlet returns an object describing the status of the ADIdentity Service together with extra diagnostics information.

  • ServiceStatus <string> The status of the Machine Creation Service instance that adopted the connection string. Possible ServiceStatus values are:

  • OK: The ADIdentity Service instance is configured with a valid database and service schema. The service is operational.

  • DBUnconfigured: No database connection string is set for the ADIdentity Service instance.

  • DBRejectedConnection: The database rejected the logon attempt from the ADIdentity Service. This may be because the service attempted to log on with invalid credentials or because a database has not been installed in the specified location.

  • InvalidDBConfigured: The specified database does not exist, is not visible to the ADIdentity Service instance, or the service’s schema within the database is invalid.

  • DBNotFound: The specified database could not be located with the configured connection string.

  • DBNewerVersionThanService: The version of the ADIdentity Service currently in use is newer than, and incompatible with, the version of the ADIdentity Service schema on the database. Upgrade the ADIdentity Service to a more recent version.

  • DBOlderVersionThanService: The version of the ADIdentity Service schema on the database is newer than, and incompatible with, the version of the ADIdentity Service currently in use. Upgrade the database schema to a more recent version.

  • DBVersionChangeInProgress: A database schema upgrade is in progress.

  • PendingFailure: Connectivity between the ADIdentity Service instance and the database has been lost. This may be a transitory network error, but may indicate a loss of connectivity that requires administrator intervention.

  • Failed: Connectivity between the ADIdentity Service instance and the database has been lost for an extended period of time, or has failed due to a configuration problem. The service instance cannot operate while its connection to the database is unavailable.

  • Unknown: The status of the ADIdentity Service cannot be determined.

  • ExtraInfo <System.Collections.Generic.Dictionary[string, string]> Dictionary providing extra diagnostics information for the database identified by the connection string. It contains at least the following keys, and their associated string values:

  • Server.Version: Database server version number.

  • Server.IsClustered: “True” if the database server is clustered; “False” otherwise.

  • Database.Status: Status of the database. When operating normally, the value is “Normal”.

  • Database.RecoveryModel: Recovery model of the database (e.g. “Simple”).

  • Database.LastBackupDate: Date of the last backup of this database.

  • Database.IsReadCommittedSnapshotOn: “True” if the READ_COMMITTED_SNAPSHOT database option is enabled; “False” otherwise.

  • Database.Collation: Collation order of the database (e.g. “Latin1_General_100_CI_AS_KS”).

  • Database.IsMirroringEnabled: “True” if the database is mirrored; “False” otherwise.

  • Database.AvailabilityGroupName: The name of the availability group of which this database is a member. Beware that the corresponding values are always strings. Therefore, to test Boolean values, you must use statements like if ($info[“Server.IsClustered”] == “True”) instead of just if ($info[“Server.IsClustered”])

Notes

If the command fails, the following errors can be returned.

  • InvalidDBConnectionString: The database connection string has an invalid format.

  • DatabaseConnectionDetailsAlreadyConfigured: There was already a database connection configured. After a configuration is set, it can only be set to $null.

  • PermissionDenied: You do not have permission to execute this command.

  • AuthorizationError: There was a problem communicating with the Citrix Delegated Administration Service.

  • ConfigurationLoggingError: The operation could not be performed because of a configuration logging error.

  • CommunicationError: There was a problem communicating with the remote service.

  • ExceptionThrown: An unexpected error occurred. For more details, see the Windows event logs on the controller or the Citrix Virtual Apps and Desktops logs.

Examples

Example 1


C:\PS>Set-AcctDBConnection "Server=dbserver\SQLEXPRESS;Database=XDDB;Trusted_Connection=True"

ServiceStatus ExtraInfo

------------- ---------

OK            {...}

<!--NeedCopy-->

Description

Configures the service instance to use a database called XDDB on an SQL Server Express database running on the machine called dbserver. Integrated Windows authentication is required.

Example 2


C:\PS>Set-AcctDBConnection -DBConnection $null

ServiceStatus  ExtraInfo

-------------- ---------

DBUnconfigured {...}

<!--NeedCopy-->

Description

Resets the service instance’s database connection string. The service instance resets and returns to an idle state until a valid new database connection string is specified.

Example 3


c:\PS>Set-AcctDBConnection -DBConnection "Server=serverName\SQLEXPRESS;Initial Catalog = databaseName;  Integrated Security = True"

          OK

ServiceStatus ExtraInfo

------------- ---------

OK            {...}

<!--NeedCopy-->

Description

Configures a database connection string for the ADIdentity Service.

Example 4


c:\PS>Set-AcctDBConnection -DBConnection "Invalid Connection String"

          Invalid database connection string format.

<!--NeedCopy-->

Description

Configures an invalid database connection string for the ADIdentity Service.

Set-AcctDBConnection