com.azure.resourcemanager.sql.models.SqlSyncGroup Maven / Gradle / Ivy
Go to download
Show more of this group Show more artifacts with this name
Show all versions of azure-resourcemanager-sql Show documentation
Show all versions of azure-resourcemanager-sql Show documentation
This package contains Microsoft Azure Sql Management SDK. For documentation on how to use this package, please see https://aka.ms/azsdk/java/mgmt
The newest version!
// Copyright (c) Microsoft Corporation. All rights reserved.
// Licensed under the MIT License.
package com.azure.resourcemanager.sql.models;
import com.azure.core.annotation.Fluent;
import com.azure.core.http.rest.PagedFlux;
import com.azure.core.http.rest.PagedIterable;
import com.azure.resourcemanager.resources.fluentcore.arm.models.ExternalChildResource;
import com.azure.resourcemanager.resources.fluentcore.arm.models.HasResourceGroup;
import com.azure.resourcemanager.resources.fluentcore.model.Appliable;
import com.azure.resourcemanager.resources.fluentcore.model.HasInnerModel;
import com.azure.resourcemanager.resources.fluentcore.model.Refreshable;
import com.azure.resourcemanager.resources.fluentcore.model.Updatable;
import com.azure.resourcemanager.sql.fluent.models.SyncGroupInner;
import java.time.OffsetDateTime;
import reactor.core.publisher.Mono;
/** An immutable client-side representation of an Azure SQL Server Sync Group. */
@Fluent
public interface SqlSyncGroup
extends ExternalChildResource,
HasInnerModel,
HasResourceGroup,
Refreshable,
Updatable {
/** @return name of the SQL Server to which this Sync Group belongs */
String sqlServerName();
/** @return name of the SQL Database to which this Sync Group belongs */
String sqlDatabaseName();
/** @return the parent SQL Database ID */
String parentId();
/** @return sync interval of the sync group */
int interval();
/** @return last sync time of the sync group */
OffsetDateTime lastSyncTime();
/** @return conflict resolution policy of the sync group */
SyncConflictResolutionPolicy conflictResolutionPolicy();
/** @return the ARM resource id of the sync database in the sync group */
String syncDatabaseId();
/** @return user name for the sync group hub database credential */
String databaseUserName();
/** @return sync state of the sync group */
SyncGroupState syncState();
/** @return sync schema of the sync group */
SyncGroupSchema schema();
/** Deletes the Sync Group resource. */
void delete();
/**
* Deletes the SQL Sync Group resource asynchronously.
*
* @return a representation of the deferred computation of this call
*/
Mono deleteAsync();
/** Refreshes a hub database schema. */
void refreshHubSchema();
/**
* Refreshes a hub database schema asynchronously.
*
* @return a representation of the deferred computation of this call
*/
Mono refreshHubSchemaAsync();
/**
* Gets a collection of hub database schemas.
*
* @return the paged list of SyncFullSchemaProperty objects if successful.
*/
PagedIterable listHubSchemas();
/**
* Gets a collection of hub database schemas asynchronously.
*
* @return a representation of the deferred computation of this call.
*/
PagedFlux listHubSchemasAsync();
/**
* Gets a collection of sync group logs.
*
* @param startTime get logs generated after this time.
* @param endTime get logs generated before this time.
* @param type the types of logs to retrieve
* @return the paged list containing the group log property objects if successful.
*/
PagedIterable listLogs(String startTime, String endTime, String type);
/**
* Gets a collection of sync group logs asynchronously.
*
* @param startTime get logs generated after this time.
* @param endTime get logs generated before this time.
* @param type the types of logs to retrieve
* @return a representation of the deferred computation of this call returning the group log property objects if
* successful.
*/
PagedFlux listLogsAsync(String startTime, String endTime, String type);
/** Triggers a sync group synchronization. */
void triggerSynchronization();
/**
* Triggers a sync group synchronization.
*
* @return a representation of the deferred computation of this call
*/
Mono triggerSynchronizationAsync();
/** Cancels a sync group synchronization. */
void cancelSynchronization();
/**
* Cancels a sync group synchronization asynchronously.
*
* @return a representation of the deferred computation of this call
*/
Mono cancelSynchronizationAsync();
/** @return the SQL Sync Member entry point */
SqlSyncMemberOperations.SqlSyncMemberActionsDefinition syncMembers();
/**************************************************************
* Fluent interfaces to provision a SQL Sync Group
**************************************************************/
/** The template for a SQL Sync Group update operation, containing all the settings that can be modified. */
interface Update
extends SqlSyncGroup.UpdateStages.WithSyncDatabaseId,
SqlSyncGroup.UpdateStages.WithDatabaseUserName,
SqlSyncGroup.UpdateStages.WithDatabasePassword,
SqlSyncGroup.UpdateStages.WithConflictResolutionPolicy,
SqlSyncGroup.UpdateStages.WithInterval,
SqlSyncGroup.UpdateStages.WithSchema,
Appliable {
}
/** Grouping of all the SQL Sync Group update stages. */
interface UpdateStages {
/** The SQL Sync Group definition to set the database ID to sync with. */
interface WithSyncDatabaseId {
/**
* Sets the sync database ID.
*
* @param databaseId the sync database ID value to set
* @return The next stage of the definition.
*/
SqlSyncGroup.Update withSyncDatabaseId(String databaseId);
}
/** The SQL Sync Group definition to set the database user name. */
interface WithDatabaseUserName {
/**
* Sets the database user name.
*
* @param userName the database user name
* @return The next stage of the definition.
*/
SqlSyncGroup.Update withDatabaseUserName(String userName);
}
/** The SQL Sync Group definition to set the database login password. */
interface WithDatabasePassword {
/**
* Sets the database login password.
*
* @param password the database login password
* @return The next stage of the definition.
*/
SqlSyncGroup.Update withDatabasePassword(String password);
}
/** The SQL Sync Group definition to set the schema. */
interface WithSchema {
/**
* Sets the schema.
*
* @param schema the schema object to set
* @return The next stage of the definition.
*/
SqlSyncGroup.Update withSchema(SyncGroupSchema schema);
}
/** The SQL Sync Group definition to set the conflict resolution policy. */
interface WithConflictResolutionPolicy {
/**
* Sets the conflict resolution policy to "HubWin".
*
* @return The next stage of the definition.
*/
SqlSyncGroup.Update withConflictResolutionPolicyHubWins();
/**
* Sets the conflict resolution policy to "MemberWin".
*
* @return The next stage of the definition.
*/
SqlSyncGroup.Update withConflictResolutionPolicyMemberWins();
}
/** The SQL Sync Group definition to set the sync frequency. */
interface WithInterval {
/**
* Sets the sync frequency.
*
* @param interval the sync frequency; set to -1 for manual sync
* @return The next stage of the definition.
*/
SqlSyncGroup.Update withInterval(int interval);
}
}
}
© 2015 - 2024 Weber Informatics LLC | Privacy Policy