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

com.microsoft.azure.management.sql.SqlElasticPool 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.Region;
import com.microsoft.azure.management.resources.fluentcore.arm.models.ExternalChildResource;
import com.microsoft.azure.management.resources.fluentcore.arm.models.HasResourceGroup;
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.Attachable;
import com.microsoft.azure.management.resources.fluentcore.model.HasInner;
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.ElasticPoolInner;

import org.joda.time.DateTime;
import rx.Completable;
import rx.Observable;

import java.util.List;

/**
 * An immutable client-side representation of an Azure SQL Elastic Pool.
 */
@Fluent
@Beta(Beta.SinceVersion.V1_7_0)
public interface SqlElasticPool
    extends
        ExternalChildResource,
        HasInner,
        HasResourceGroup,
        Refreshable,
        Updatable {

    /**
     * @return name of the SQL Server to which this elastic pool belongs
     */
    String sqlServerName();

    /**
     * @return the creation date of the Azure SQL Elastic Pool
     */
    DateTime creationDate();

    /**
     * @return the state of the Azure SQL Elastic Pool
     */
    ElasticPoolState state();

    /**
     * @return the edition of Azure SQL Elastic Pool
     */
    ElasticPoolEdition edition();

    /**
     * @return The total shared DTU for the SQL Azure Database Elastic Pool
     */
    int dtu();

    /**
     * @return the maximum DTU any one SQL Azure database can consume.
     */
    int databaseDtuMax();

    /**
     * @return the minimum DTU all SQL Azure Databases are guaranteed
     */
    int databaseDtuMin();

    /**
     * @return the storage limit for the SQL Azure Database Elastic Pool in MB
     */
    @Deprecated
    int storageMB();

    /**
     * @return the storage capacity limit for the SQL Azure Database Elastic Pool in MB
     */
    @Beta(Beta.SinceVersion.V1_7_0)
    int storageCapacityInMB();

    /**
     * @return the parent SQL server ID
     */
    @Beta(Beta.SinceVersion.V1_7_0)
    String parentId();

    /**
     * @return the name of the region the resource is in
     */
    @Beta(Beta.SinceVersion.V1_7_0)
    String regionName();

    /**
     * @return the region the resource is in
     */
    @Beta(Beta.SinceVersion.V1_7_0)
    Region region();


    // Actions

    /**
     * @return the information about elastic pool activities
     */
    @Method
    List listActivities();

    /**
     * @return a representation of the deferred computation of the information about elastic pool activities
     */
    @Beta(Beta.SinceVersion.V1_7_0)
    @Method
    Observable listActivitiesAsync();

    /**
     * @return the information about elastic pool database activities
     */
    @Method
    List listDatabaseActivities();

    /**
     * @return the information about elastic pool database activities
     */
    @Beta(Beta.SinceVersion.V1_7_0)
    @Method
    Observable listDatabaseActivitiesAsync();

    /**
     * Lists the database metrics for this SQL Elastic Pool.
     *
     * @param filter an OData filter expression that describes a subset of metrics to return
     * @return the elastic pool's database metrics
     */
    @Method
    @Beta(Beta.SinceVersion.V1_7_0)
    List listDatabaseMetrics(String filter);

    /**
     * Asynchronously lists the database metrics for this SQL Elastic Pool.
     *
     * @param filter an OData filter expression that describes a subset of metrics to return
     * @return a representation of the deferred computation of this call
     */
    @Method
    @Beta(Beta.SinceVersion.V1_7_0)
    Observable listDatabaseMetricsAsync(String filter);

    /**
     * Lists the database metric definitions for this SQL Elastic Pool.
     *
     * @return the elastic pool's metric definitions
     */
    @Method
    @Beta(Beta.SinceVersion.V1_7_0)
    List listDatabaseMetricDefinitions();

    /**
     * Asynchronously lists the database metric definitions for this SQL Elastic Pool.
     *
     * @return a representation of the deferred computation of this call
     */
    @Method
    @Beta(Beta.SinceVersion.V1_7_0)
    Observable listDatabaseMetricDefinitionsAsync();

    /**
     * Lists the SQL databases in this SQL Elastic Pool.
     *
     * @return the information about databases in elastic pool
     */
    @Method
    List listDatabases();

    /**
     * Asynchronously lists the SQL databases in this SQL Elastic Pool.
     *
     * @return a representation of the deferred computation of this call
     */
    @Method
    @Beta(Beta.SinceVersion.V1_7_0)
    Observable listDatabasesAsync();

    /**
     * Gets the specific database in the elastic pool.
     *
     * @param databaseName name of the database to look into
     * @return the information about specific database in elastic pool
     */
    SqlDatabase getDatabase(String databaseName);

    /**
     * Adds a new SQL Database to the Elastic Pool.
     *
     * @param databaseName name of the database
     * @return the database
     */
    @Beta(Beta.SinceVersion.V1_7_0)
    SqlDatabase addNewDatabase(String databaseName);

    /**
     * Adds an existing SQL Database to the Elastic Pool.
     *
     * @param databaseName name of the database
     * @return the database
     */
    @Beta(Beta.SinceVersion.V1_7_0)
    SqlDatabase addExistingDatabase(String databaseName);

    /**
     * Adds an existing SQL Database to the Elastic Pool.
     *
     * @param database the database to be added
     * @return the database
     */
    @Beta(Beta.SinceVersion.V1_7_0)
    SqlDatabase addExistingDatabase(SqlDatabase database);

    /**
     * Removes an existing SQL Database from the Elastic Pool.
     *
     * @param databaseName name of the database
     * @return the database
     */
    @Beta(Beta.SinceVersion.V1_7_0)
    SqlDatabase removeDatabase(String databaseName);

    /**
     * Deletes this SQL Elastic Pool from the parent SQL server.
     */
    @Method
    void delete();

    /**
     * Deletes this SQL Elastic Pool asynchronously from the parent SQL server.
     *
     * @return a representation of the deferred computation of this call
     */
    @Method
    Completable deleteAsync();


    /**************************************************************
     * Fluent interfaces to provision a SQL Elastic Pool
     **************************************************************/

    /**
     * Container interface for all the definitions that need to be implemented.
     *
     * @param  the stage of the parent definition to return to after attaching this definition
     */
    interface SqlElasticPoolDefinition extends
            DefinitionStages.Blank,
            DefinitionStages.WithEdition,
            DefinitionStages.WithBasicEdition,
            DefinitionStages.WithStandardEdition,
            DefinitionStages.WithPremiumEdition,
            DefinitionStages.WithAttach {
    }

    /**
     * Grouping of all the storage account definition stages.
     */
    interface DefinitionStages {
        /**
         * The first stage of the SQL Server definition.
         *
         * @param  the stage of the parent definition to return to after attaching this definition
         */
        interface Blank extends SqlElasticPool.DefinitionStages.WithEdition {
        }

        /**
         * The SQL Elastic Pool definition to set the edition for database.
         *
         * @param  the stage of the parent definition to return to after attaching this definition
         */
        interface WithEdition {
            /**
             * Sets the edition for the SQL Elastic Pool.
             *
             * @param edition edition to be set for elastic pool.
             * @return The next stage of the definition.
             */
            @Deprecated
            @Beta(Beta.SinceVersion.V1_7_0)
            SqlElasticPool.DefinitionStages.WithAttach withEdition(ElasticPoolEdition edition);

            /**
             * Sets the basic edition for the SQL Elastic Pool.
             *
             * @return The next stage of the definition.
             */
            @Beta(Beta.SinceVersion.V1_7_0)
            @Method
            SqlElasticPool.DefinitionStages.WithBasicEdition withBasicPool();

            /**
             * Sets the standard edition for the SQL Elastic Pool.
             *
             * @return The next stage of the definition.
             */
            @Beta(Beta.SinceVersion.V1_7_0)
            @Method
            SqlElasticPool.DefinitionStages.WithStandardEdition withStandardPool();

            /**
             * Sets the premium edition for the SQL Elastic Pool.
             *
             * @return The next stage of the definition.
             */
            @Beta(Beta.SinceVersion.V1_7_0)
            @Method
            SqlElasticPool.DefinitionStages.WithPremiumEdition withPremiumPool();
        }

        /**
         * The SQL Elastic Pool definition to set the eDTU and storage capacity limits for a basic pool.
         *
         * @param  the stage of the parent definition to return to after attaching this definition
         */
        interface WithBasicEdition extends SqlElasticPool.DefinitionStages.WithAttach {
            /**
             * Sets the total shared eDTU for the SQL Azure Database Elastic Pool.
             *
             * @param eDTU total shared eDTU for the SQL Azure Database Elastic Pool
             * @return The next stage of the definition.
             */
            @Beta(Beta.SinceVersion.V1_7_0)
            SqlElasticPool.DefinitionStages.WithBasicEdition withReservedDtu(SqlElasticPoolBasicEDTUs eDTU);

            /**
             * Sets the maximum number of eDTU a database in the pool can consume.
             *
             * @param eDTU maximum eDTU a database in the pool can consume
             * @return The next stage of the definition.
             */
            @Beta(Beta.SinceVersion.V1_7_0)
            SqlElasticPool.DefinitionStages.WithBasicEdition withDatabaseDtuMax(SqlElasticPoolBasicMaxEDTUs eDTU);

            /**
             * Sets the minimum number of eDTU for each database in the pool are regardless of its activity.
             *
             * @param eDTU minimum eDTU for all SQL Azure databases
             * @return The next stage of the definition.
             */
            @Beta(Beta.SinceVersion.V1_7_0)
            SqlElasticPool.DefinitionStages.WithBasicEdition withDatabaseDtuMin(SqlElasticPoolBasicMinEDTUs eDTU);
        }

        /**
         * The SQL Elastic Pool definition to set the eDTU and storage capacity limits for a standard pool.
         *
         * @param  the stage of the parent definition to return to after attaching this definition
         */
        interface WithStandardEdition extends SqlElasticPool.DefinitionStages.WithAttach {
            /**
             * Sets the total shared eDTU for the SQL Azure Database Elastic Pool.
             *
             * @param eDTU total shared eDTU for the SQL Azure Database Elastic Pool
             * @return The next stage of the definition.
             */
            @Beta(Beta.SinceVersion.V1_7_0)
            SqlElasticPool.DefinitionStages.WithStandardEdition withReservedDtu(SqlElasticPoolStandardEDTUs eDTU);

            /**
             * Sets the maximum number of eDTU a database in the pool can consume.
             *
             * @param eDTU maximum eDTU a database in the pool can consume
             * @return The next stage of the definition.
             */
            @Beta(Beta.SinceVersion.V1_7_0)
            SqlElasticPool.DefinitionStages.WithStandardEdition withDatabaseDtuMax(SqlElasticPoolStandardMaxEDTUs eDTU);

            /**
             * Sets the minimum number of eDTU for each database in the pool are regardless of its activity.
             *
             * @param eDTU minimum eDTU for all SQL Azure databases
             * @return The next stage of the definition.
             */
            @Beta(Beta.SinceVersion.V1_7_0)
            SqlElasticPool.DefinitionStages.WithStandardEdition withDatabaseDtuMin(SqlElasticPoolStandardMinEDTUs eDTU);

            /**
             * Sets the storage capacity for the SQL Azure Database Elastic Pool.
             *
             * @param storageCapacity storage capacity for the SQL Azure Database Elastic Pool
             * @return The next stage of the definition.
             */
            @Beta(Beta.SinceVersion.V1_7_0)
            SqlElasticPool.DefinitionStages.WithStandardEdition withStorageCapacity(SqlElasticPoolStandardStorage storageCapacity);
        }

        /**
         * The SQL Elastic Pool definition to set the eDTU and storage capacity limits for a premium pool.
         *
         * @param  the stage of the parent definition to return to after attaching this definition
         */
        interface WithPremiumEdition extends SqlElasticPool.DefinitionStages.WithAttach {
            /**
             * Sets the total shared eDTU for the SQL Azure Database Elastic Pool.
             *
             * @param eDTU total shared eDTU for the SQL Azure Database Elastic Pool
             * @return The next stage of the definition.
             */
            @Beta(Beta.SinceVersion.V1_7_0)
            SqlElasticPool.DefinitionStages.WithPremiumEdition withReservedDtu(SqlElasticPoolPremiumEDTUs eDTU);

            /**
             * Sets the maximum number of eDTU a database in the pool can consume.
             *
             * @param eDTU maximum eDTU a database in the pool can consume
             * @return The next stage of the definition.
             */
            @Beta(Beta.SinceVersion.V1_7_0)
            SqlElasticPool.DefinitionStages.WithPremiumEdition withDatabaseDtuMax(SqlElasticPoolPremiumMaxEDTUs eDTU);

            /**
             * Sets the minimum number of eDTU for each database in the pool are regardless of its activity.
             *
             * @param eDTU minimum eDTU for all SQL Azure databases
             * @return The next stage of the definition.
             */
            @Beta(Beta.SinceVersion.V1_7_0)
            SqlElasticPool.DefinitionStages.WithPremiumEdition withDatabaseDtuMin(SqlElasticPoolPremiumMinEDTUs eDTU);

            /**
             * Sets the storage capacity for the SQL Azure Database Elastic Pool.
             *
             * @param storageCapacity storage capacity for the SQL Azure Database Elastic Pool
             * @return The next stage of the definition.
             */
            @Beta(Beta.SinceVersion.V1_7_0)
            SqlElasticPool.DefinitionStages.WithPremiumEdition withStorageCapacity(SqlElasticPoolPremiumSorage storageCapacity);
        }

        /**
         * The SQL Elastic Pool definition to set the minimum DTU for database.
         *
         * @param  the stage of the parent definition to return to after attaching this definition
         */
        interface WithDatabaseDtuMin {
            /**
             * Sets the minimum DTU all SQL Azure Databases are guaranteed.
             *
             * @param databaseDtuMin minimum DTU for all SQL Azure databases
             * @return The next stage of the definition.
             */
            @Deprecated
            SqlElasticPool.DefinitionStages.WithAttach withDatabaseDtuMin(int databaseDtuMin);
        }

        /**
         * The SQL Elastic Pool definition to set the maximum DTU for one database.
         *
         * @param  the stage of the parent definition to return to after attaching this definition
         */
        interface WithDatabaseDtuMax {
            /**
             * Sets the maximum DTU any one SQL Azure Database can consume.
             *
             * @param databaseDtuMax maximum DTU any one SQL Azure Database can consume
             * @return The next stage of the definition.
             */
            @Deprecated
            SqlElasticPool.DefinitionStages.WithAttach withDatabaseDtuMax(int databaseDtuMax);
        }

        /**
         * The SQL Elastic Pool definition to set the number of shared DTU for elastic pool.
         *
         * @param  the stage of the parent definition to return to after attaching this definition
         */
        interface WithDtu {
            /**
             * Sets the total shared DTU for the SQL Azure Database Elastic Pool.
             *
             * @param dtu total shared DTU for the SQL Azure Database Elastic Pool
             * @return The next stage of the definition.
             */
            @Deprecated
            SqlElasticPool.DefinitionStages.WithAttach withDtu(int dtu);
        }

        /**
         * The SQL Elastic Pool definition to set the storage limit for the SQL Azure Database Elastic Pool in MB.
         *
         * @param  the stage of the parent definition to return to after attaching this definition
         */
        interface WithStorageCapacity {
            /**
             * Sets the storage limit for the SQL Azure Database Elastic Pool in MB.
             *
             * @param storageMB storage limit for the SQL Azure Database Elastic Pool in MB
             * @return The next stage of the definition.
             */
            @Deprecated
            SqlElasticPool.DefinitionStages.WithAttach withStorageCapacity(int storageMB);
        }

        /** The final stage of the SQL Elastic Pool definition.
         * 

* At this stage, any remaining optional settings can be specified, or the SQL Elastic Pool definition * can be attached to the parent SQL Server definition. * @param the stage of the parent definition to return to after attaching this definition */ interface WithAttach extends WithDatabaseDtuMin, WithDatabaseDtuMax, WithDtu, WithStorageCapacity, Attachable.InDefinition { } } /** * The template for a SQL Elastic Pool update operation, containing all the settings that can be modified. */ interface Update extends UpdateStages.WithReservedDTUAndStorageCapacity, UpdateStages.WithDatabaseDtuMax, UpdateStages.WithDatabaseDtuMin, UpdateStages.WithDtu, UpdateStages.WithStorageCapacity, UpdateStages.WithDatabase, Resource.UpdateWithTags, Appliable { } /** * Grouping of all the SQL Elastic Pool update stages. */ interface UpdateStages { /** * The SQL Elastic Pool definition to set the minimum DTU for database. */ interface WithDatabaseDtuMin { /** * Sets the minimum DTU all SQL Azure Databases are guaranteed. * * @param databaseDtuMin minimum DTU for all SQL Azure databases * @return The next stage of definition. */ @Deprecated Update withDatabaseDtuMin(int databaseDtuMin); } /** * The SQL Elastic Pool definition to set the maximum DTU for one database. */ interface WithDatabaseDtuMax { /** * Sets the maximum DTU any one SQL Azure Database can consume. * * @param databaseDtuMax maximum DTU any one SQL Azure Database can consume * @return The next stage of definition. */ @Deprecated Update withDatabaseDtuMax(int databaseDtuMax); } /** * The SQL Elastic Pool definition to set the number of shared DTU for elastic pool. */ interface WithDtu { /** * Sets the total shared DTU for the SQL Azure Database Elastic Pool. * * @param dtu total shared DTU for the SQL Azure Database Elastic Pool * @return The next stage of definition. */ @Deprecated Update withDtu(int dtu); } /** * The SQL Elastic Pool definition to set the storage limit for the SQL Azure Database Elastic Pool in MB. */ interface WithStorageCapacity { /** * Sets the storage limit for the SQL Azure Database Elastic Pool in MB. * * @param storageMB storage limit for the SQL Azure Database Elastic Pool in MB * @return The next stage of definition. */ @Deprecated Update withStorageCapacity(int storageMB); } /** * The SQL Elastic Pool update definition to set the eDTU and storage capacity limits. */ interface WithReservedDTUAndStorageCapacity { /** * Sets the total shared eDTU for the SQL Azure Database Elastic Pool. * * @param eDTU total shared eDTU for the SQL Azure Database Elastic Pool * @return The next stage of the update definition. */ @Beta(Beta.SinceVersion.V1_7_0) Update withReservedDtu(SqlElasticPoolBasicEDTUs eDTU); /** * Sets the maximum number of eDTU a database in the pool can consume. * * @param eDTU maximum eDTU a database in the pool can consume * @return The next stage of the update definition. */ @Beta(Beta.SinceVersion.V1_7_0) Update withDatabaseDtuMax(SqlElasticPoolBasicMaxEDTUs eDTU); /** * Sets the minimum number of eDTU for each database in the pool are regardless of its activity. * * @param eDTU minimum eDTU for all SQL Azure databases * @return The next stage of the update definition. */ @Beta(Beta.SinceVersion.V1_7_0) Update withDatabaseDtuMin(SqlElasticPoolBasicMinEDTUs eDTU); /** * Sets the total shared eDTU for the SQL Azure Database Elastic Pool. * * @param eDTU total shared eDTU for the SQL Azure Database Elastic Pool * @return The next stage of the update definition. */ @Beta(Beta.SinceVersion.V1_7_0) Update withReservedDtu(SqlElasticPoolStandardEDTUs eDTU); /** * Sets the maximum number of eDTU a database in the pool can consume. * * @param eDTU maximum eDTU a database in the pool can consume * @return The next stage of the update definition. */ @Beta(Beta.SinceVersion.V1_7_0) Update withDatabaseDtuMax(SqlElasticPoolStandardMaxEDTUs eDTU); /** * Sets the minimum number of eDTU for each database in the pool are regardless of its activity. * * @param eDTU minimum eDTU for all SQL Azure databases * @return The next stage of the update definition. */ @Beta(Beta.SinceVersion.V1_7_0) Update withDatabaseDtuMin(SqlElasticPoolStandardMinEDTUs eDTU); /** * Sets the storage capacity for the SQL Azure Database Elastic Pool. * * @param storageCapacity storage capacity for the SQL Azure Database Elastic Pool * @return The next stage of the update definition. */ @Beta(Beta.SinceVersion.V1_7_0) Update withStorageCapacity(SqlElasticPoolStandardStorage storageCapacity); /** * Sets the total shared eDTU for the SQL Azure Database Elastic Pool. * * @param eDTU total shared eDTU for the SQL Azure Database Elastic Pool * @return The next stage of the update definition. */ @Beta(Beta.SinceVersion.V1_7_0) Update withReservedDtu(SqlElasticPoolPremiumEDTUs eDTU); /** * Sets the maximum number of eDTU a database in the pool can consume. * * @param eDTU maximum eDTU a database in the pool can consume * @return The next stage of the update definition. */ @Beta(Beta.SinceVersion.V1_7_0) Update withDatabaseDtuMax(SqlElasticPoolPremiumMaxEDTUs eDTU); /** * Sets the minimum number of eDTU for each database in the pool are regardless of its activity. * * @param eDTU minimum eDTU for all SQL Azure databases * @return The next stage of the update definition. */ @Beta(Beta.SinceVersion.V1_7_0) Update withDatabaseDtuMin(SqlElasticPoolPremiumMinEDTUs eDTU); /** * Sets the storage capacity for the SQL Azure Database Elastic Pool. * * @param storageCapacity storage capacity for the SQL Azure Database Elastic Pool * @return The next stage of the update definition. */ @Beta(Beta.SinceVersion.V1_7_0) Update withStorageCapacity(SqlElasticPoolPremiumSorage storageCapacity); } /** * The SQL Elastic Pool definition to add the Database in the elastic pool. */ interface WithDatabase { /** * Creates a new database in the SQL elastic pool. * * @param databaseName name of the new database to be added in the elastic pool * @return The next stage of the definition. */ Update withNewDatabase(String databaseName); /** * Adds an existing database in the SQL elastic pool. * * @param databaseName name of the existing database to be added in the elastic pool * @return The next stage of the definition. */ Update withExistingDatabase(String databaseName); /** * Adds the database in the SQL elastic pool. * * @param database database instance to be added in SQL elastic pool * @return The next stage of the definition. */ Update withExistingDatabase(SqlDatabase database); } } }





© 2015 - 2025 Weber Informatics LLC | Privacy Policy