All Downloads are FREE. Search and download functionalities are using the official Maven repository.

com.microsoft.azure.management.sql.SqlServer Maven / Gradle / Ivy

/**
 * Copyright (c) Microsoft Corporation. All rights reserved.
 * Licensed under the MIT License. See License.txt in the project root for
 * license information.
 */

package com.microsoft.azure.management.sql;

import com.microsoft.azure.management.apigeneration.Beta;
import com.microsoft.azure.management.apigeneration.Fluent;
import com.microsoft.azure.management.apigeneration.Method;
import com.microsoft.azure.management.resources.fluentcore.arm.models.GroupableResource;
import com.microsoft.azure.management.resources.fluentcore.arm.models.Resource;
import com.microsoft.azure.management.resources.fluentcore.model.Appliable;
import com.microsoft.azure.management.resources.fluentcore.model.Creatable;
import com.microsoft.azure.management.resources.fluentcore.model.Refreshable;
import com.microsoft.azure.management.resources.fluentcore.model.Updatable;
import com.microsoft.azure.management.sql.implementation.ServerInner;
import com.microsoft.azure.management.sql.implementation.SqlServerManager;
import rx.Observable;

import java.util.List;
import java.util.Map;

/**
 * An immutable client-side representation of an Azure SQL Server.
 */
@Fluent
@Beta(Beta.SinceVersion.V1_7_0)
public interface SqlServer extends
        GroupableResource,
        Refreshable,
        Updatable {

    /**
     * @return fully qualified name of the SQL Server
     */
    String fullyQualifiedDomainName();

    /**
     * @return the administrator login user name for the SQL Server
     */
    String administratorLogin();

    /**
     * @return the SQL Server version
     */
    String version();

    /**
     * @return the SQL Server "kind"
     */
    @Beta(Beta.SinceVersion.V1_7_0)
    String kind();

    /**
     * @return the state of the server.
     */
    @Beta(Beta.SinceVersion.V1_7_0)
    String state();

    /**
     * @return true if Managed Service Identity is enabled for the SQL server
     */
    @Beta(Beta.SinceVersion.V1_8_0)
    boolean isManagedServiceIdentityEnabled();

    /**
     * @return the System Assigned (Local) Managed Service Identity specific Active Directory tenant ID assigned
     * to the SQL server.
     */
    @Beta(Beta.SinceVersion.V1_8_0)
    String systemAssignedManagedServiceIdentityTenantId();

    /**
     * @return the System Assigned (Local) Managed Service Identity specific Active Directory service principal ID
     * assigned to the SQL server.
     */
    @Beta(Beta.SinceVersion.V1_8_0)
    String systemAssignedManagedServiceIdentityPrincipalId();

    /**
     * @return the type of Managed Service Identity used for the SQL server.
     */
    @Beta(Beta.SinceVersion.V1_8_0)
    IdentityType managedServiceIdentityType();


    // Actions

    /**
     * @return returns the list of usages (ServerMetric) of Azure SQL Server
     */
    @Method
    @Deprecated
    List listUsages();

    /**
     * @return returns the list of usage metrics for an Azure SQL Server
     */
    @Method
    @Beta(Beta.SinceVersion.V1_7_0)
    List listUsageMetrics();

    /**
     * @return the list of information on all service objectives
     */
    @Method
    List listServiceObjectives();

    /**
     * Gets the information on a particular Sql Server Service Objective.
     * @param serviceObjectiveName name of the service objective to be fetched
     * @return information of the service objective
     */
    @Beta(Beta.SinceVersion.V1_7_0)
    ServiceObjective getServiceObjective(String serviceObjectiveName);

    /**
     * Returns all the recommended elastic pools for the server.
     *
     * @return list of recommended elastic pools for the server
     */
    @Method
    Map listRecommendedElasticPools();

    /**
     * @return the list of all restorable dropped databases
     */
    @Method
    List listRestorableDroppedDatabases();

    /**
     * @return the list of all restorable dropped databases
     */
    @Method
    @Beta(Beta.SinceVersion.V1_7_0)
    Observable listRestorableDroppedDatabasesAsync();

    /**
     * Sets the Azure services default access to this server to true.
     * 

* A firewall rule named "AllowAllWindowsAzureIps" with the start IP "0.0.0.0" will be added * to the SQL server if one does not exist. * * @return the SQL Firewall rule */ @Beta(Beta.SinceVersion.V1_7_0) @Method SqlFirewallRule enableAccessFromAzureServices(); /** * Sets the Azure services default access to this server to false. *

* The firewall rule named "AllowAllWindowsAzureIps" will be removed from the SQL server. */ @Beta(Beta.SinceVersion.V1_7_0) @Method void removeAccessFromAzureServices(); /** * Sets an Active Directory administrator to this server. *

* Azure Active Directory authentication allows you to centrally manage identity and access * to your Azure SQL Database V12. * * @param userLogin the user or group login; it can be the name or the email address * @param id the user or group unique ID * @return a representation of a SQL Server Active Directory administrator object */ @Beta(Beta.SinceVersion.V1_7_0) @Method SqlActiveDirectoryAdministrator setActiveDirectoryAdministrator(String userLogin, String id); /** * Gets the Active Directory administrator for this server. * * @return a representation of a SQL Server Active Directory administrator object (null if one is not set) */ @Beta(Beta.SinceVersion.V1_7_0) @Method SqlActiveDirectoryAdministrator getActiveDirectoryAdministrator(); /** * Removes the Active Directory administrator from this server. */ @Beta(Beta.SinceVersion.V1_7_0) @Method void removeActiveDirectoryAdministrator(); /** * Gets a SQL server automatic tuning state and options. * * @return the SQL server automatic tuning state and options */ @Method @Beta(Beta.SinceVersion.V1_8_0) SqlServerAutomaticTuning getServerAutomaticTuning(); // Collections /** * @return the entry point to manage SQL Firewall rules for this server */ @Beta(Beta.SinceVersion.V1_7_0) SqlFirewallRuleOperations.SqlFirewallRuleActionsDefinition firewallRules(); /** * @return the entry point to manage SQL Virtual Network Rule for this server */ @Beta(Beta.SinceVersion.V1_8_0) SqlVirtualNetworkRuleOperations.SqlVirtualNetworkRuleActionsDefinition virtualNetworkRules(); /** * @return the entry point to manage the SQL Elastic Pools for this server */ @Beta(Beta.SinceVersion.V1_7_0) SqlElasticPoolOperations.SqlElasticPoolActionsDefinition elasticPools(); /** * @return entry point to manage Databases for this SQL server */ @Beta(Beta.SinceVersion.V1_7_0) SqlDatabaseOperations.SqlDatabaseActionsDefinition databases(); /** * @return the entry point to manage SQL Server DNS aliases for this server */ @Beta(Beta.SinceVersion.V1_8_0) SqlServerDnsAliasOperations.SqlServerDnsAliasActionsDefinition dnsAliases(); /** * @return the entry point to manage SQL Failover Group for this server */ @Beta(Beta.SinceVersion.V1_8_0) SqlFailoverGroupOperations.SqlFailoverGroupActionsDefinition failoverGroups(); /** * @return the entry point to manage SQL Server Keys for this server */ @Beta(Beta.SinceVersion.V1_8_0) SqlServerKeyOperations.SqlServerKeyActionsDefinition serverKeys(); /** * @return the entry point to manage SQL Encryption Protector for this server */ @Beta(Beta.SinceVersion.V1_9_0) SqlEncryptionProtectorOperations.SqlEncryptionProtectorActionsDefinition encryptionProtectors(); /** * @return the entry point to manage SQL Server Security Alert Policy for this server */ @Beta(Beta.SinceVersion.V1_15_0) SqlServerSecurityAlertPolicyOperations.SqlServerSecurityAlertPolicyActionsDefinition serverSecurityAlertPolicies(); /************************************************************** * Fluent interfaces to provision a SqlServer **************************************************************/ /** * Container interface for all the definitions that need to be implemented. */ interface Definition extends DefinitionStages.Blank, DefinitionStages.WithGroup, DefinitionStages.WithAdministratorLogin, DefinitionStages.WithAdministratorPassword, DefinitionStages.WithElasticPool, DefinitionStages.WithDatabase, DefinitionStages.WithFirewallRule, DefinitionStages.WithCreate { } /** * Grouping of all the storage account definition stages. */ interface DefinitionStages { /** * The first stage of the SQL Server definition. */ interface Blank extends DefinitionWithRegion { } /** * A SQL Server definition allowing resource group to be set. */ interface WithGroup extends GroupableResource.DefinitionStages.WithGroup { } /** * A SQL Server definition setting administrator user name. */ interface WithAdministratorLogin { /** * Sets the administrator login user name. * * @param administratorLogin administrator login user name * @return Next stage of the SQL Server definition */ WithAdministratorPassword withAdministratorLogin(String administratorLogin); } /** * A SQL Server definition setting admin user password. */ interface WithAdministratorPassword { /** * Sets the administrator login password. * * @param administratorLoginPassword password for administrator login * @return Next stage of the SQL Server definition */ WithCreate withAdministratorPassword(String administratorLoginPassword); } /** * A SQL Server definition setting the Active Directory administrator. */ @Beta(Beta.SinceVersion.V1_7_0) interface WithActiveDirectoryAdministrator { /** * Sets the SQL Active Directory administrator. *

* Azure Active Directory authentication allows you to centrally manage identity and access * to your Azure SQL Database V12. * * @param userLogin the user or group login; it can be the name or the email address * @param id the user or group unique ID * @return Next stage of the SQL Server definition */ WithCreate withActiveDirectoryAdministrator(String userLogin, String id); } /** * A SQL Server definition setting the managed service identity. */ @Beta(Beta.SinceVersion.V1_8_0) interface WithSystemAssignedManagedServiceIdentity { /** * Sets a system assigned (local) Managed Service Identity (MSI) for the SQL server resource. * * @return Next stage of the SQL Server definition */ @Beta(Beta.SinceVersion.V1_8_0) @Method WithCreate withSystemAssignedManagedServiceIdentity(); } /** * A SQL Server definition for specifying elastic pool. */ interface WithElasticPool { /** * Begins the definition of a new SQL Elastic Pool to be added to this server. * * @param elasticPoolName the name of the new SQL Elastic Pool * @return the first stage of the new SQL Elastic Pool definition */ @Beta(Beta.SinceVersion.V1_7_0) SqlElasticPool.DefinitionStages.Blank defineElasticPool(String elasticPoolName); /** * Creates new elastic pool in the SQL Server. * @param elasticPoolName name of the elastic pool to be created * @param elasticPoolEdition edition of the elastic pool * @param databaseNames names of the database to be included in the elastic pool * @return Next stage of the SQL Server definition */ @Deprecated WithCreate withNewElasticPool(String elasticPoolName, ElasticPoolEdition elasticPoolEdition, String... databaseNames); /** * Creates new elastic pool in the SQL Server. * @param elasticPoolName name of the elastic pool to be created * @param elasticPoolEdition edition of the elastic pool * @return Next stage of the SQL Server definition */ @Deprecated WithCreate withNewElasticPool(String elasticPoolName, ElasticPoolEdition elasticPoolEdition); } /** * A SQL Server definition for specifying the databases. */ interface WithDatabase { /** * Begins the definition of a new SQL Database to be added to this server. * * @param databaseName the name of the new SQL Database * @return the first stage of the new SQL Database definition */ @Beta(Beta.SinceVersion.V1_7_0) SqlDatabase.DefinitionStages.Blank defineDatabase(String databaseName); /** * Creates new database in the SQL Server. * @param databaseName name of the database to be created * @return Next stage of the SQL Server definition */ @Deprecated WithCreate withNewDatabase(String databaseName); } /** * The stage of the SQL Server definition allowing to specify the SQL Firewall rules. */ interface WithFirewallRule { /** * Sets the Azure services default access to this server to false. *

* The default is to allow Azure services default access to this server via a special * firewall rule named "AllowAllWindowsAzureIps" with the start IP "0.0.0.0". * * @return Next stage of the SQL Server definition */ @Beta(Beta.SinceVersion.V1_7_0) WithCreate withoutAccessFromAzureServices(); /** * Begins the definition of a new SQL Firewall rule to be added to this server. * * @param firewallRuleName the name of the new SQL Firewall rule * @return the first stage of the new SQL Firewall rule definition */ @Beta(Beta.SinceVersion.V1_7_0) SqlFirewallRule.DefinitionStages.Blank defineFirewallRule(String firewallRuleName); /** * Creates new firewall rule in the SQL Server. * * @param ipAddress ipAddress for the firewall rule * @return Next stage of the SQL Server definition */ @Deprecated WithCreate withNewFirewallRule(String ipAddress); /** * Creates new firewall rule in the SQL Server. * * @param startIPAddress start IP address for the firewall rule * @param endIPAddress end IP address for the firewall rule * @return Next stage of the SQL Server definition */ @Deprecated WithCreate withNewFirewallRule(String startIPAddress, String endIPAddress); /** * Creates new firewall rule in the SQL Server. * * @param startIPAddress start IP address for the firewall rule * @param endIPAddress end IP address for the firewall rule * @param firewallRuleName name for the firewall rule * @return Next stage of the SQL Server definition */ @Deprecated WithCreate withNewFirewallRule(String startIPAddress, String endIPAddress, String firewallRuleName); } /** * The stage of the SQL Server definition allowing to specify the SQL Virtual Network Rules. */ @Beta(Beta.SinceVersion.V1_8_0) interface WithVirtualNetworkRule { /** * Begins the definition of a new SQL Virtual Network Rule to be added to this server. * * @param virtualNetworkRuleName the name of the new SQL Virtual Network Rule * @return the first stage of the new SQL Virtual Network Rule definition */ @Beta(Beta.SinceVersion.V1_8_0) SqlVirtualNetworkRule.DefinitionStages.Blank defineVirtualNetworkRule(String virtualNetworkRuleName); } /** * A SQL Server definition with sufficient inputs to create a new * SQL Server in the cloud, but exposing additional optional inputs to * specify. */ @Beta(Beta.SinceVersion.V1_7_0) interface WithCreate extends Creatable, WithActiveDirectoryAdministrator, WithSystemAssignedManagedServiceIdentity, WithElasticPool, WithDatabase, WithFirewallRule, WithVirtualNetworkRule, DefinitionWithTags { } } /** * The template for a SQLServer update operation, containing all the settings that can be modified. */ @Beta(Beta.SinceVersion.V1_7_0) interface Update extends Appliable, UpdateStages.WithAdministratorPassword, UpdateStages.WithElasticPool, UpdateStages.WithDatabase, UpdateStages.WithFirewallRule, UpdateStages.WithSystemAssignedManagedServiceIdentity, Resource.UpdateWithTags { } /** * Grouping of all the SQLServer update stages. */ interface UpdateStages { /** * A SQL Server update stage setting admin user password. */ interface WithAdministratorPassword { /** * Sets the administrator login password. * * @param administratorLoginPassword password for administrator login * @return Next stage of the update. */ Update withAdministratorPassword(String administratorLoginPassword); } /** * A SQL Server definition setting the managed service identity. */ @Beta(Beta.SinceVersion.V1_8_0) interface WithSystemAssignedManagedServiceIdentity { /** * Sets a system assigned (local) Managed Service Identity (MSI) for the SQL server resource. * * @return Next stage of the SQL Server definition */ @Beta(Beta.SinceVersion.V1_8_0) @Method Update withSystemAssignedManagedServiceIdentity(); } /** * A SQL Server definition for specifying elastic pool. */ interface WithElasticPool { /** * Create new elastic pool in the SQL Server. * @param elasticPoolName name of the elastic pool to be created * @param elasticPoolEdition edition of the elastic pool * @param databaseNames names of the database to be included in the elastic pool * @return Next stage of the SQL Server update */ @Beta(Beta.SinceVersion.V1_7_0) @Deprecated Update withNewElasticPool(String elasticPoolName, ElasticPoolEdition elasticPoolEdition, String... databaseNames); /** * Create new elastic pool in the SQL Server. * @param elasticPoolName name of the elastic pool to be created * @param elasticPoolEdition edition of the elastic pool * @return Next stage of the SQL Server update */ @Beta(Beta.SinceVersion.V1_7_0) @Deprecated Update withNewElasticPool(String elasticPoolName, ElasticPoolEdition elasticPoolEdition); /** * Removes elastic pool from the SQL Server. * @param elasticPoolName name of the elastic pool to be removed * @return Next stage of the SQL Server update */ @Deprecated Update withoutElasticPool(String elasticPoolName); } /** * A SQL Server definition for specifying the databases. */ interface WithDatabase { /** * Create new database in the SQL Server. * @param databaseName name of the database to be created * @return Next stage of the SQL Server update */ @Deprecated Update withNewDatabase(String databaseName); /** * Remove database from the SQL Server. * @param databaseName name of the database to be removed * @return Next stage of the SQL Server update */ @Deprecated Update withoutDatabase(String databaseName); } /** * The stage of the SQL Server update definition allowing to specify the SQL Firewall rules. */ interface WithFirewallRule { /** * Create new firewall rule in the SQL Server. * * @param ipAddress IP address for the firewall rule * @return Next stage of the SQL Server update */ @Deprecated Update withNewFirewallRule(String ipAddress); /** * Create new firewall rule in the SQL Server. * * @param startIPAddress Start IP address for the firewall rule * @param endIPAddress IP address for the firewall rule * @return Next stage of the SQL Server update */ @Deprecated Update withNewFirewallRule(String startIPAddress, String endIPAddress); /** * Creates new firewall rule in the SQL Server. * * @param startIPAddress start IP address for the firewall rule * @param endIPAddress end IP address for the firewall rule * @param firewallRuleName name for the firewall rule * @return Next stage of the SQL Server update */ @Deprecated Update withNewFirewallRule(String startIPAddress, String endIPAddress, String firewallRuleName); /** * Removes firewall rule from the SQL Server. * * @param firewallRuleName name of the firewall rule to be removed * @return Next stage of the SQL Server update */ @Deprecated Update withoutFirewallRule(String firewallRuleName); } } }





© 2015 - 2025 Weber Informatics LLC | Privacy Policy