import { Command as $Command } from "@smithy/smithy-client"; import type { MetadataBearer as __MetadataBearer } from "@smithy/types"; import type { ECRClientResolvedConfig, ServiceInputTypes, ServiceOutputTypes } from "../ECRClient"; import type { PutReplicationConfigurationRequest, PutReplicationConfigurationResponse } from "../models/models_0"; /** * @public */ export type { __MetadataBearer }; export { $Command }; /** * @public * * The input for {@link PutReplicationConfigurationCommand}. */ export interface PutReplicationConfigurationCommandInput extends PutReplicationConfigurationRequest { } /** * @public * * The output of {@link PutReplicationConfigurationCommand}. */ export interface PutReplicationConfigurationCommandOutput extends PutReplicationConfigurationResponse, __MetadataBearer { } declare const PutReplicationConfigurationCommand_base: { new (input: PutReplicationConfigurationCommandInput): import("@smithy/smithy-client").CommandImpl; new (input: PutReplicationConfigurationCommandInput): import("@smithy/smithy-client").CommandImpl; getEndpointParameterInstructions(): import("@smithy/middleware-endpoint").EndpointParameterInstructions; }; /** *

Creates or updates the replication configuration for a registry. The existing * replication configuration for a repository can be retrieved with the DescribeRegistry API action. The first time the * PutReplicationConfiguration API is called, a service-linked IAM role is created in * your account for the replication process. For more information, see Using * service-linked roles for Amazon ECR in the Amazon Elastic Container Registry User Guide. * For more information on the custom role for replication, see Creating an IAM role for replication.

* *

When configuring cross-account replication, the destination account must grant the * source account permission to replicate. This permission is controlled using a * registry permissions policy. For more information, see PutRegistryPolicy.

*
* @example * Use a bare-bones client and the command you need to make an API call. * ```javascript * import { ECRClient, PutReplicationConfigurationCommand } from "@aws-sdk/client-ecr"; // ES Modules import * // const { ECRClient, PutReplicationConfigurationCommand } = require("@aws-sdk/client-ecr"); // CommonJS import * // import type { ECRClientConfig } from "@aws-sdk/client-ecr"; * const config = {}; // type is ECRClientConfig * const client = new ECRClient(config); * const input = { // PutReplicationConfigurationRequest * replicationConfiguration: { // ReplicationConfiguration * rules: [ // ReplicationRuleList // required * { // ReplicationRule * destinations: [ // ReplicationDestinationList // required * { // ReplicationDestination * region: "STRING_VALUE", // required * registryId: "STRING_VALUE", // required * }, * ], * repositoryFilters: [ // RepositoryFilterList * { // RepositoryFilter * filter: "STRING_VALUE", // required * filterType: "PREFIX_MATCH", // required * }, * ], * }, * ], * }, * }; * const command = new PutReplicationConfigurationCommand(input); * const response = await client.send(command); * // { // PutReplicationConfigurationResponse * // replicationConfiguration: { // ReplicationConfiguration * // rules: [ // ReplicationRuleList // required * // { // ReplicationRule * // destinations: [ // ReplicationDestinationList // required * // { // ReplicationDestination * // region: "STRING_VALUE", // required * // registryId: "STRING_VALUE", // required * // }, * // ], * // repositoryFilters: [ // RepositoryFilterList * // { // RepositoryFilter * // filter: "STRING_VALUE", // required * // filterType: "PREFIX_MATCH", // required * // }, * // ], * // }, * // ], * // }, * // }; * * ``` * * @param PutReplicationConfigurationCommandInput - {@link PutReplicationConfigurationCommandInput} * @returns {@link PutReplicationConfigurationCommandOutput} * @see {@link PutReplicationConfigurationCommandInput} for command's `input` shape. * @see {@link PutReplicationConfigurationCommandOutput} for command's `response` shape. * @see {@link ECRClientResolvedConfig | config} for ECRClient's `config` shape. * * @throws {@link InvalidParameterException} (client fault) *

The specified parameter is invalid. Review the available parameters for the API * request.

* * @throws {@link ServerException} (server fault) *

These errors are usually caused by a server-side issue.

* * @throws {@link ValidationException} (client fault) *

There was an exception validating this request.

* * @throws {@link ECRServiceException} *

Base exception class for all service exceptions from ECR service.

* * * @public */ export declare class PutReplicationConfigurationCommand extends PutReplicationConfigurationCommand_base { /** @internal type navigation helper, not in runtime. */ protected static __types: { api: { input: PutReplicationConfigurationRequest; output: PutReplicationConfigurationResponse; }; sdk: { input: PutReplicationConfigurationCommandInput; output: PutReplicationConfigurationCommandOutput; }; }; }