1{ 2 "version":"2.0", 3 "metadata":{ 4 "apiVersion":"2017-05-31", 5 "endpointPrefix":"mgh", 6 "jsonVersion":"1.1", 7 "protocol":"json", 8 "serviceFullName":"AWS Migration Hub", 9 "serviceId":"Migration Hub", 10 "signatureVersion":"v4", 11 "targetPrefix":"AWSMigrationHub", 12 "uid":"AWSMigrationHub-2017-05-31" 13 }, 14 "operations":{ 15 "AssociateCreatedArtifact":{ 16 "name":"AssociateCreatedArtifact", 17 "http":{ 18 "method":"POST", 19 "requestUri":"/" 20 }, 21 "input":{"shape":"AssociateCreatedArtifactRequest"}, 22 "output":{"shape":"AssociateCreatedArtifactResult"}, 23 "errors":[ 24 {"shape":"AccessDeniedException"}, 25 {"shape":"ThrottlingException"}, 26 {"shape":"InternalServerError"}, 27 {"shape":"ServiceUnavailableException"}, 28 {"shape":"DryRunOperation"}, 29 {"shape":"UnauthorizedOperation"}, 30 {"shape":"InvalidInputException"}, 31 {"shape":"ResourceNotFoundException"}, 32 {"shape":"HomeRegionNotSetException"} 33 ], 34 "documentation":"<p>Associates a created artifact of an AWS cloud resource, the target receiving the migration, with the migration task performed by a migration tool. This API has the following traits:</p> <ul> <li> <p>Migration tools can call the <code>AssociateCreatedArtifact</code> operation to indicate which AWS artifact is associated with a migration task.</p> </li> <li> <p>The created artifact name must be provided in ARN (Amazon Resource Name) format which will contain information about type and region; for example: <code>arn:aws:ec2:us-east-1:488216288981:image/ami-6d0ba87b</code>.</p> </li> <li> <p>Examples of the AWS resource behind the created artifact are, AMI's, EC2 instance, or DMS endpoint, etc.</p> </li> </ul>" 35 }, 36 "AssociateDiscoveredResource":{ 37 "name":"AssociateDiscoveredResource", 38 "http":{ 39 "method":"POST", 40 "requestUri":"/" 41 }, 42 "input":{"shape":"AssociateDiscoveredResourceRequest"}, 43 "output":{"shape":"AssociateDiscoveredResourceResult"}, 44 "errors":[ 45 {"shape":"AccessDeniedException"}, 46 {"shape":"ThrottlingException"}, 47 {"shape":"InternalServerError"}, 48 {"shape":"ServiceUnavailableException"}, 49 {"shape":"DryRunOperation"}, 50 {"shape":"UnauthorizedOperation"}, 51 {"shape":"InvalidInputException"}, 52 {"shape":"PolicyErrorException"}, 53 {"shape":"ResourceNotFoundException"}, 54 {"shape":"HomeRegionNotSetException"} 55 ], 56 "documentation":"<p>Associates a discovered resource ID from Application Discovery Service with a migration task.</p>" 57 }, 58 "CreateProgressUpdateStream":{ 59 "name":"CreateProgressUpdateStream", 60 "http":{ 61 "method":"POST", 62 "requestUri":"/" 63 }, 64 "input":{"shape":"CreateProgressUpdateStreamRequest"}, 65 "output":{"shape":"CreateProgressUpdateStreamResult"}, 66 "errors":[ 67 {"shape":"AccessDeniedException"}, 68 {"shape":"ThrottlingException"}, 69 {"shape":"InternalServerError"}, 70 {"shape":"ServiceUnavailableException"}, 71 {"shape":"DryRunOperation"}, 72 {"shape":"UnauthorizedOperation"}, 73 {"shape":"InvalidInputException"}, 74 {"shape":"HomeRegionNotSetException"} 75 ], 76 "documentation":"<p>Creates a progress update stream which is an AWS resource used for access control as well as a namespace for migration task names that is implicitly linked to your AWS account. It must uniquely identify the migration tool as it is used for all updates made by the tool; however, it does not need to be unique for each AWS account because it is scoped to the AWS account.</p>" 77 }, 78 "DeleteProgressUpdateStream":{ 79 "name":"DeleteProgressUpdateStream", 80 "http":{ 81 "method":"POST", 82 "requestUri":"/" 83 }, 84 "input":{"shape":"DeleteProgressUpdateStreamRequest"}, 85 "output":{"shape":"DeleteProgressUpdateStreamResult"}, 86 "errors":[ 87 {"shape":"AccessDeniedException"}, 88 {"shape":"ThrottlingException"}, 89 {"shape":"InternalServerError"}, 90 {"shape":"ServiceUnavailableException"}, 91 {"shape":"DryRunOperation"}, 92 {"shape":"UnauthorizedOperation"}, 93 {"shape":"InvalidInputException"}, 94 {"shape":"ResourceNotFoundException"}, 95 {"shape":"HomeRegionNotSetException"} 96 ], 97 "documentation":"<p>Deletes a progress update stream, including all of its tasks, which was previously created as an AWS resource used for access control. This API has the following traits:</p> <ul> <li> <p>The only parameter needed for <code>DeleteProgressUpdateStream</code> is the stream name (same as a <code>CreateProgressUpdateStream</code> call).</p> </li> <li> <p>The call will return, and a background process will asynchronously delete the stream and all of its resources (tasks, associated resources, resource attributes, created artifacts).</p> </li> <li> <p>If the stream takes time to be deleted, it might still show up on a <code>ListProgressUpdateStreams</code> call.</p> </li> <li> <p> <code>CreateProgressUpdateStream</code>, <code>ImportMigrationTask</code>, <code>NotifyMigrationTaskState</code>, and all Associate[*] APIs related to the tasks belonging to the stream will throw \"InvalidInputException\" if the stream of the same name is in the process of being deleted.</p> </li> <li> <p>Once the stream and all of its resources are deleted, <code>CreateProgressUpdateStream</code> for a stream of the same name will succeed, and that stream will be an entirely new logical resource (without any resources associated with the old stream).</p> </li> </ul>" 98 }, 99 "DescribeApplicationState":{ 100 "name":"DescribeApplicationState", 101 "http":{ 102 "method":"POST", 103 "requestUri":"/" 104 }, 105 "input":{"shape":"DescribeApplicationStateRequest"}, 106 "output":{"shape":"DescribeApplicationStateResult"}, 107 "errors":[ 108 {"shape":"AccessDeniedException"}, 109 {"shape":"ThrottlingException"}, 110 {"shape":"InternalServerError"}, 111 {"shape":"ServiceUnavailableException"}, 112 {"shape":"InvalidInputException"}, 113 {"shape":"PolicyErrorException"}, 114 {"shape":"ResourceNotFoundException"}, 115 {"shape":"HomeRegionNotSetException"} 116 ], 117 "documentation":"<p>Gets the migration status of an application.</p>" 118 }, 119 "DescribeMigrationTask":{ 120 "name":"DescribeMigrationTask", 121 "http":{ 122 "method":"POST", 123 "requestUri":"/" 124 }, 125 "input":{"shape":"DescribeMigrationTaskRequest"}, 126 "output":{"shape":"DescribeMigrationTaskResult"}, 127 "errors":[ 128 {"shape":"AccessDeniedException"}, 129 {"shape":"ThrottlingException"}, 130 {"shape":"InternalServerError"}, 131 {"shape":"ServiceUnavailableException"}, 132 {"shape":"InvalidInputException"}, 133 {"shape":"ResourceNotFoundException"}, 134 {"shape":"HomeRegionNotSetException"} 135 ], 136 "documentation":"<p>Retrieves a list of all attributes associated with a specific migration task.</p>" 137 }, 138 "DisassociateCreatedArtifact":{ 139 "name":"DisassociateCreatedArtifact", 140 "http":{ 141 "method":"POST", 142 "requestUri":"/" 143 }, 144 "input":{"shape":"DisassociateCreatedArtifactRequest"}, 145 "output":{"shape":"DisassociateCreatedArtifactResult"}, 146 "errors":[ 147 {"shape":"AccessDeniedException"}, 148 {"shape":"ThrottlingException"}, 149 {"shape":"InternalServerError"}, 150 {"shape":"ServiceUnavailableException"}, 151 {"shape":"DryRunOperation"}, 152 {"shape":"UnauthorizedOperation"}, 153 {"shape":"InvalidInputException"}, 154 {"shape":"ResourceNotFoundException"}, 155 {"shape":"HomeRegionNotSetException"} 156 ], 157 "documentation":"<p>Disassociates a created artifact of an AWS resource with a migration task performed by a migration tool that was previously associated. This API has the following traits:</p> <ul> <li> <p>A migration user can call the <code>DisassociateCreatedArtifacts</code> operation to disassociate a created AWS Artifact from a migration task.</p> </li> <li> <p>The created artifact name must be provided in ARN (Amazon Resource Name) format which will contain information about type and region; for example: <code>arn:aws:ec2:us-east-1:488216288981:image/ami-6d0ba87b</code>.</p> </li> <li> <p>Examples of the AWS resource behind the created artifact are, AMI's, EC2 instance, or RDS instance, etc.</p> </li> </ul>" 158 }, 159 "DisassociateDiscoveredResource":{ 160 "name":"DisassociateDiscoveredResource", 161 "http":{ 162 "method":"POST", 163 "requestUri":"/" 164 }, 165 "input":{"shape":"DisassociateDiscoveredResourceRequest"}, 166 "output":{"shape":"DisassociateDiscoveredResourceResult"}, 167 "errors":[ 168 {"shape":"AccessDeniedException"}, 169 {"shape":"ThrottlingException"}, 170 {"shape":"InternalServerError"}, 171 {"shape":"ServiceUnavailableException"}, 172 {"shape":"DryRunOperation"}, 173 {"shape":"UnauthorizedOperation"}, 174 {"shape":"InvalidInputException"}, 175 {"shape":"ResourceNotFoundException"}, 176 {"shape":"HomeRegionNotSetException"} 177 ], 178 "documentation":"<p>Disassociate an Application Discovery Service discovered resource from a migration task.</p>" 179 }, 180 "ImportMigrationTask":{ 181 "name":"ImportMigrationTask", 182 "http":{ 183 "method":"POST", 184 "requestUri":"/" 185 }, 186 "input":{"shape":"ImportMigrationTaskRequest"}, 187 "output":{"shape":"ImportMigrationTaskResult"}, 188 "errors":[ 189 {"shape":"AccessDeniedException"}, 190 {"shape":"ThrottlingException"}, 191 {"shape":"InternalServerError"}, 192 {"shape":"ServiceUnavailableException"}, 193 {"shape":"DryRunOperation"}, 194 {"shape":"UnauthorizedOperation"}, 195 {"shape":"InvalidInputException"}, 196 {"shape":"ResourceNotFoundException"}, 197 {"shape":"HomeRegionNotSetException"} 198 ], 199 "documentation":"<p>Registers a new migration task which represents a server, database, etc., being migrated to AWS by a migration tool.</p> <p>This API is a prerequisite to calling the <code>NotifyMigrationTaskState</code> API as the migration tool must first register the migration task with Migration Hub.</p>" 200 }, 201 "ListApplicationStates":{ 202 "name":"ListApplicationStates", 203 "http":{ 204 "method":"POST", 205 "requestUri":"/" 206 }, 207 "input":{"shape":"ListApplicationStatesRequest"}, 208 "output":{"shape":"ListApplicationStatesResult"}, 209 "errors":[ 210 {"shape":"AccessDeniedException"}, 211 {"shape":"ThrottlingException"}, 212 {"shape":"InternalServerError"}, 213 {"shape":"ServiceUnavailableException"}, 214 {"shape":"InvalidInputException"}, 215 {"shape":"HomeRegionNotSetException"} 216 ], 217 "documentation":"<p>Lists all the migration statuses for your applications. If you use the optional <code>ApplicationIds</code> parameter, only the migration statuses for those applications will be returned.</p>" 218 }, 219 "ListCreatedArtifacts":{ 220 "name":"ListCreatedArtifacts", 221 "http":{ 222 "method":"POST", 223 "requestUri":"/" 224 }, 225 "input":{"shape":"ListCreatedArtifactsRequest"}, 226 "output":{"shape":"ListCreatedArtifactsResult"}, 227 "errors":[ 228 {"shape":"AccessDeniedException"}, 229 {"shape":"ThrottlingException"}, 230 {"shape":"InternalServerError"}, 231 {"shape":"ServiceUnavailableException"}, 232 {"shape":"InvalidInputException"}, 233 {"shape":"ResourceNotFoundException"}, 234 {"shape":"HomeRegionNotSetException"} 235 ], 236 "documentation":"<p>Lists the created artifacts attached to a given migration task in an update stream. This API has the following traits:</p> <ul> <li> <p>Gets the list of the created artifacts while migration is taking place.</p> </li> <li> <p>Shows the artifacts created by the migration tool that was associated by the <code>AssociateCreatedArtifact</code> API. </p> </li> <li> <p>Lists created artifacts in a paginated interface. </p> </li> </ul>" 237 }, 238 "ListDiscoveredResources":{ 239 "name":"ListDiscoveredResources", 240 "http":{ 241 "method":"POST", 242 "requestUri":"/" 243 }, 244 "input":{"shape":"ListDiscoveredResourcesRequest"}, 245 "output":{"shape":"ListDiscoveredResourcesResult"}, 246 "errors":[ 247 {"shape":"AccessDeniedException"}, 248 {"shape":"ThrottlingException"}, 249 {"shape":"InternalServerError"}, 250 {"shape":"ServiceUnavailableException"}, 251 {"shape":"InvalidInputException"}, 252 {"shape":"ResourceNotFoundException"}, 253 {"shape":"HomeRegionNotSetException"} 254 ], 255 "documentation":"<p>Lists discovered resources associated with the given <code>MigrationTask</code>.</p>" 256 }, 257 "ListMigrationTasks":{ 258 "name":"ListMigrationTasks", 259 "http":{ 260 "method":"POST", 261 "requestUri":"/" 262 }, 263 "input":{"shape":"ListMigrationTasksRequest"}, 264 "output":{"shape":"ListMigrationTasksResult"}, 265 "errors":[ 266 {"shape":"AccessDeniedException"}, 267 {"shape":"ThrottlingException"}, 268 {"shape":"InternalServerError"}, 269 {"shape":"ServiceUnavailableException"}, 270 {"shape":"InvalidInputException"}, 271 {"shape":"PolicyErrorException"}, 272 {"shape":"ResourceNotFoundException"}, 273 {"shape":"HomeRegionNotSetException"} 274 ], 275 "documentation":"<p>Lists all, or filtered by resource name, migration tasks associated with the user account making this call. This API has the following traits:</p> <ul> <li> <p>Can show a summary list of the most recent migration tasks.</p> </li> <li> <p>Can show a summary list of migration tasks associated with a given discovered resource.</p> </li> <li> <p>Lists migration tasks in a paginated interface.</p> </li> </ul>" 276 }, 277 "ListProgressUpdateStreams":{ 278 "name":"ListProgressUpdateStreams", 279 "http":{ 280 "method":"POST", 281 "requestUri":"/" 282 }, 283 "input":{"shape":"ListProgressUpdateStreamsRequest"}, 284 "output":{"shape":"ListProgressUpdateStreamsResult"}, 285 "errors":[ 286 {"shape":"AccessDeniedException"}, 287 {"shape":"ThrottlingException"}, 288 {"shape":"InternalServerError"}, 289 {"shape":"ServiceUnavailableException"}, 290 {"shape":"InvalidInputException"}, 291 {"shape":"HomeRegionNotSetException"} 292 ], 293 "documentation":"<p>Lists progress update streams associated with the user account making this call.</p>" 294 }, 295 "NotifyApplicationState":{ 296 "name":"NotifyApplicationState", 297 "http":{ 298 "method":"POST", 299 "requestUri":"/" 300 }, 301 "input":{"shape":"NotifyApplicationStateRequest"}, 302 "output":{"shape":"NotifyApplicationStateResult"}, 303 "errors":[ 304 {"shape":"AccessDeniedException"}, 305 {"shape":"ThrottlingException"}, 306 {"shape":"InternalServerError"}, 307 {"shape":"ServiceUnavailableException"}, 308 {"shape":"DryRunOperation"}, 309 {"shape":"UnauthorizedOperation"}, 310 {"shape":"InvalidInputException"}, 311 {"shape":"PolicyErrorException"}, 312 {"shape":"ResourceNotFoundException"}, 313 {"shape":"HomeRegionNotSetException"} 314 ], 315 "documentation":"<p>Sets the migration state of an application. For a given application identified by the value passed to <code>ApplicationId</code>, its status is set or updated by passing one of three values to <code>Status</code>: <code>NOT_STARTED | IN_PROGRESS | COMPLETED</code>.</p>" 316 }, 317 "NotifyMigrationTaskState":{ 318 "name":"NotifyMigrationTaskState", 319 "http":{ 320 "method":"POST", 321 "requestUri":"/" 322 }, 323 "input":{"shape":"NotifyMigrationTaskStateRequest"}, 324 "output":{"shape":"NotifyMigrationTaskStateResult"}, 325 "errors":[ 326 {"shape":"AccessDeniedException"}, 327 {"shape":"ThrottlingException"}, 328 {"shape":"InternalServerError"}, 329 {"shape":"ServiceUnavailableException"}, 330 {"shape":"DryRunOperation"}, 331 {"shape":"UnauthorizedOperation"}, 332 {"shape":"InvalidInputException"}, 333 {"shape":"ResourceNotFoundException"}, 334 {"shape":"HomeRegionNotSetException"} 335 ], 336 "documentation":"<p>Notifies Migration Hub of the current status, progress, or other detail regarding a migration task. This API has the following traits:</p> <ul> <li> <p>Migration tools will call the <code>NotifyMigrationTaskState</code> API to share the latest progress and status.</p> </li> <li> <p> <code>MigrationTaskName</code> is used for addressing updates to the correct target.</p> </li> <li> <p> <code>ProgressUpdateStream</code> is used for access control and to provide a namespace for each migration tool.</p> </li> </ul>" 337 }, 338 "PutResourceAttributes":{ 339 "name":"PutResourceAttributes", 340 "http":{ 341 "method":"POST", 342 "requestUri":"/" 343 }, 344 "input":{"shape":"PutResourceAttributesRequest"}, 345 "output":{"shape":"PutResourceAttributesResult"}, 346 "errors":[ 347 {"shape":"AccessDeniedException"}, 348 {"shape":"ThrottlingException"}, 349 {"shape":"InternalServerError"}, 350 {"shape":"ServiceUnavailableException"}, 351 {"shape":"DryRunOperation"}, 352 {"shape":"UnauthorizedOperation"}, 353 {"shape":"InvalidInputException"}, 354 {"shape":"ResourceNotFoundException"}, 355 {"shape":"HomeRegionNotSetException"} 356 ], 357 "documentation":"<p>Provides identifying details of the resource being migrated so that it can be associated in the Application Discovery Service repository. This association occurs asynchronously after <code>PutResourceAttributes</code> returns.</p> <important> <ul> <li> <p>Keep in mind that subsequent calls to PutResourceAttributes will override previously stored attributes. For example, if it is first called with a MAC address, but later, it is desired to <i>add</i> an IP address, it will then be required to call it with <i>both</i> the IP and MAC addresses to prevent overriding the MAC address.</p> </li> <li> <p>Note the instructions regarding the special use case of the <a href=\"https://docs.aws.amazon.com/migrationhub/latest/ug/API_PutResourceAttributes.html#migrationhub-PutResourceAttributes-request-ResourceAttributeList\"> <code>ResourceAttributeList</code> </a> parameter when specifying any \"VM\" related value.</p> </li> </ul> </important> <note> <p>Because this is an asynchronous call, it will always return 200, whether an association occurs or not. To confirm if an association was found based on the provided details, call <code>ListDiscoveredResources</code>.</p> </note>" 358 } 359 }, 360 "shapes":{ 361 "AccessDeniedException":{ 362 "type":"structure", 363 "members":{ 364 "Message":{"shape":"ErrorMessage"} 365 }, 366 "documentation":"<p>You do not have sufficient access to perform this action.</p>", 367 "exception":true 368 }, 369 "ApplicationId":{ 370 "type":"string", 371 "max":1600, 372 "min":1, 373 "pattern":"^.{1,1600}$" 374 }, 375 "ApplicationIds":{ 376 "type":"list", 377 "member":{"shape":"ApplicationId"}, 378 "max":100, 379 "min":1 380 }, 381 "ApplicationState":{ 382 "type":"structure", 383 "members":{ 384 "ApplicationId":{ 385 "shape":"ApplicationId", 386 "documentation":"<p>The configurationId from the Application Discovery Service that uniquely identifies an application.</p>" 387 }, 388 "ApplicationStatus":{ 389 "shape":"ApplicationStatus", 390 "documentation":"<p>The current status of an application.</p>" 391 }, 392 "LastUpdatedTime":{ 393 "shape":"UpdateDateTime", 394 "documentation":"<p>The timestamp when the application status was last updated.</p>" 395 } 396 }, 397 "documentation":"<p>The state of an application discovered through Migration Hub import, the AWS Agentless Discovery Connector, or the AWS Application Discovery Agent.</p>" 398 }, 399 "ApplicationStateList":{ 400 "type":"list", 401 "member":{"shape":"ApplicationState"}, 402 "max":1000, 403 "min":0 404 }, 405 "ApplicationStatus":{ 406 "type":"string", 407 "enum":[ 408 "NOT_STARTED", 409 "IN_PROGRESS", 410 "COMPLETED" 411 ] 412 }, 413 "AssociateCreatedArtifactRequest":{ 414 "type":"structure", 415 "required":[ 416 "ProgressUpdateStream", 417 "MigrationTaskName", 418 "CreatedArtifact" 419 ], 420 "members":{ 421 "ProgressUpdateStream":{ 422 "shape":"ProgressUpdateStream", 423 "documentation":"<p>The name of the ProgressUpdateStream. </p>" 424 }, 425 "MigrationTaskName":{ 426 "shape":"MigrationTaskName", 427 "documentation":"<p>Unique identifier that references the migration task. <i>Do not store personal data in this field.</i> </p>" 428 }, 429 "CreatedArtifact":{ 430 "shape":"CreatedArtifact", 431 "documentation":"<p>An ARN of the AWS resource related to the migration (e.g., AMI, EC2 instance, RDS instance, etc.) </p>" 432 }, 433 "DryRun":{ 434 "shape":"DryRun", 435 "documentation":"<p>Optional boolean flag to indicate whether any effect should take place. Used to test if the caller has permission to make the call.</p>" 436 } 437 } 438 }, 439 "AssociateCreatedArtifactResult":{ 440 "type":"structure", 441 "members":{ 442 } 443 }, 444 "AssociateDiscoveredResourceRequest":{ 445 "type":"structure", 446 "required":[ 447 "ProgressUpdateStream", 448 "MigrationTaskName", 449 "DiscoveredResource" 450 ], 451 "members":{ 452 "ProgressUpdateStream":{ 453 "shape":"ProgressUpdateStream", 454 "documentation":"<p>The name of the ProgressUpdateStream.</p>" 455 }, 456 "MigrationTaskName":{ 457 "shape":"MigrationTaskName", 458 "documentation":"<p>The identifier given to the MigrationTask. <i>Do not store personal data in this field.</i> </p>" 459 }, 460 "DiscoveredResource":{ 461 "shape":"DiscoveredResource", 462 "documentation":"<p>Object representing a Resource.</p>" 463 }, 464 "DryRun":{ 465 "shape":"DryRun", 466 "documentation":"<p>Optional boolean flag to indicate whether any effect should take place. Used to test if the caller has permission to make the call.</p>" 467 } 468 } 469 }, 470 "AssociateDiscoveredResourceResult":{ 471 "type":"structure", 472 "members":{ 473 } 474 }, 475 "ConfigurationId":{ 476 "type":"string", 477 "max":1600, 478 "min":1, 479 "pattern":"^.{1,1600}$" 480 }, 481 "CreateProgressUpdateStreamRequest":{ 482 "type":"structure", 483 "required":["ProgressUpdateStreamName"], 484 "members":{ 485 "ProgressUpdateStreamName":{ 486 "shape":"ProgressUpdateStream", 487 "documentation":"<p>The name of the ProgressUpdateStream. <i>Do not store personal data in this field.</i> </p>" 488 }, 489 "DryRun":{ 490 "shape":"DryRun", 491 "documentation":"<p>Optional boolean flag to indicate whether any effect should take place. Used to test if the caller has permission to make the call.</p>" 492 } 493 } 494 }, 495 "CreateProgressUpdateStreamResult":{ 496 "type":"structure", 497 "members":{ 498 } 499 }, 500 "CreatedArtifact":{ 501 "type":"structure", 502 "required":["Name"], 503 "members":{ 504 "Name":{ 505 "shape":"CreatedArtifactName", 506 "documentation":"<p>An ARN that uniquely identifies the result of a migration task.</p>" 507 }, 508 "Description":{ 509 "shape":"CreatedArtifactDescription", 510 "documentation":"<p>A description that can be free-form text to record additional detail about the artifact for clarity or for later reference.</p>" 511 } 512 }, 513 "documentation":"<p>An ARN of the AWS cloud resource target receiving the migration (e.g., AMI, EC2 instance, RDS instance, etc.).</p>" 514 }, 515 "CreatedArtifactDescription":{ 516 "type":"string", 517 "max":500, 518 "min":0, 519 "pattern":"^.{0,500}$" 520 }, 521 "CreatedArtifactList":{ 522 "type":"list", 523 "member":{"shape":"CreatedArtifact"} 524 }, 525 "CreatedArtifactName":{ 526 "type":"string", 527 "max":1600, 528 "min":1, 529 "pattern":"arn:[a-z-]+:[a-z0-9-]+:(?:[a-z0-9-]+|):(?:[0-9]{12}|):.*" 530 }, 531 "DeleteProgressUpdateStreamRequest":{ 532 "type":"structure", 533 "required":["ProgressUpdateStreamName"], 534 "members":{ 535 "ProgressUpdateStreamName":{ 536 "shape":"ProgressUpdateStream", 537 "documentation":"<p>The name of the ProgressUpdateStream. <i>Do not store personal data in this field.</i> </p>" 538 }, 539 "DryRun":{ 540 "shape":"DryRun", 541 "documentation":"<p>Optional boolean flag to indicate whether any effect should take place. Used to test if the caller has permission to make the call.</p>" 542 } 543 } 544 }, 545 "DeleteProgressUpdateStreamResult":{ 546 "type":"structure", 547 "members":{ 548 } 549 }, 550 "DescribeApplicationStateRequest":{ 551 "type":"structure", 552 "required":["ApplicationId"], 553 "members":{ 554 "ApplicationId":{ 555 "shape":"ApplicationId", 556 "documentation":"<p>The configurationId in Application Discovery Service that uniquely identifies the grouped application.</p>" 557 } 558 } 559 }, 560 "DescribeApplicationStateResult":{ 561 "type":"structure", 562 "members":{ 563 "ApplicationStatus":{ 564 "shape":"ApplicationStatus", 565 "documentation":"<p>Status of the application - Not Started, In-Progress, Complete.</p>" 566 }, 567 "LastUpdatedTime":{ 568 "shape":"UpdateDateTime", 569 "documentation":"<p>The timestamp when the application status was last updated.</p>" 570 } 571 } 572 }, 573 "DescribeMigrationTaskRequest":{ 574 "type":"structure", 575 "required":[ 576 "ProgressUpdateStream", 577 "MigrationTaskName" 578 ], 579 "members":{ 580 "ProgressUpdateStream":{ 581 "shape":"ProgressUpdateStream", 582 "documentation":"<p>The name of the ProgressUpdateStream. </p>" 583 }, 584 "MigrationTaskName":{ 585 "shape":"MigrationTaskName", 586 "documentation":"<p>The identifier given to the MigrationTask. <i>Do not store personal data in this field.</i> </p>" 587 } 588 } 589 }, 590 "DescribeMigrationTaskResult":{ 591 "type":"structure", 592 "members":{ 593 "MigrationTask":{ 594 "shape":"MigrationTask", 595 "documentation":"<p>Object encapsulating information about the migration task.</p>" 596 } 597 } 598 }, 599 "DisassociateCreatedArtifactRequest":{ 600 "type":"structure", 601 "required":[ 602 "ProgressUpdateStream", 603 "MigrationTaskName", 604 "CreatedArtifactName" 605 ], 606 "members":{ 607 "ProgressUpdateStream":{ 608 "shape":"ProgressUpdateStream", 609 "documentation":"<p>The name of the ProgressUpdateStream. </p>" 610 }, 611 "MigrationTaskName":{ 612 "shape":"MigrationTaskName", 613 "documentation":"<p>Unique identifier that references the migration task to be disassociated with the artifact. <i>Do not store personal data in this field.</i> </p>" 614 }, 615 "CreatedArtifactName":{ 616 "shape":"CreatedArtifactName", 617 "documentation":"<p>An ARN of the AWS resource related to the migration (e.g., AMI, EC2 instance, RDS instance, etc.)</p>" 618 }, 619 "DryRun":{ 620 "shape":"DryRun", 621 "documentation":"<p>Optional boolean flag to indicate whether any effect should take place. Used to test if the caller has permission to make the call.</p>" 622 } 623 } 624 }, 625 "DisassociateCreatedArtifactResult":{ 626 "type":"structure", 627 "members":{ 628 } 629 }, 630 "DisassociateDiscoveredResourceRequest":{ 631 "type":"structure", 632 "required":[ 633 "ProgressUpdateStream", 634 "MigrationTaskName", 635 "ConfigurationId" 636 ], 637 "members":{ 638 "ProgressUpdateStream":{ 639 "shape":"ProgressUpdateStream", 640 "documentation":"<p>The name of the ProgressUpdateStream.</p>" 641 }, 642 "MigrationTaskName":{ 643 "shape":"MigrationTaskName", 644 "documentation":"<p>The identifier given to the MigrationTask. <i>Do not store personal data in this field.</i> </p>" 645 }, 646 "ConfigurationId":{ 647 "shape":"ConfigurationId", 648 "documentation":"<p>ConfigurationId of the Application Discovery Service resource to be disassociated.</p>" 649 }, 650 "DryRun":{ 651 "shape":"DryRun", 652 "documentation":"<p>Optional boolean flag to indicate whether any effect should take place. Used to test if the caller has permission to make the call.</p>" 653 } 654 } 655 }, 656 "DisassociateDiscoveredResourceResult":{ 657 "type":"structure", 658 "members":{ 659 } 660 }, 661 "DiscoveredResource":{ 662 "type":"structure", 663 "required":["ConfigurationId"], 664 "members":{ 665 "ConfigurationId":{ 666 "shape":"ConfigurationId", 667 "documentation":"<p>The configurationId in Application Discovery Service that uniquely identifies the on-premise resource.</p>" 668 }, 669 "Description":{ 670 "shape":"DiscoveredResourceDescription", 671 "documentation":"<p>A description that can be free-form text to record additional detail about the discovered resource for clarity or later reference.</p>" 672 } 673 }, 674 "documentation":"<p>Object representing the on-premises resource being migrated.</p>" 675 }, 676 "DiscoveredResourceDescription":{ 677 "type":"string", 678 "max":500, 679 "min":0, 680 "pattern":"^.{0,500}$" 681 }, 682 "DiscoveredResourceList":{ 683 "type":"list", 684 "member":{"shape":"DiscoveredResource"} 685 }, 686 "DryRun":{"type":"boolean"}, 687 "DryRunOperation":{ 688 "type":"structure", 689 "members":{ 690 "Message":{"shape":"ErrorMessage"} 691 }, 692 "documentation":"<p>Exception raised to indicate a successfully authorized action when the <code>DryRun</code> flag is set to \"true\".</p>", 693 "exception":true 694 }, 695 "ErrorMessage":{"type":"string"}, 696 "HomeRegionNotSetException":{ 697 "type":"structure", 698 "members":{ 699 "Message":{"shape":"ErrorMessage"} 700 }, 701 "documentation":"<p>The home region is not set. Set the home region to continue.</p>", 702 "exception":true 703 }, 704 "ImportMigrationTaskRequest":{ 705 "type":"structure", 706 "required":[ 707 "ProgressUpdateStream", 708 "MigrationTaskName" 709 ], 710 "members":{ 711 "ProgressUpdateStream":{ 712 "shape":"ProgressUpdateStream", 713 "documentation":"<p>The name of the ProgressUpdateStream. ></p>" 714 }, 715 "MigrationTaskName":{ 716 "shape":"MigrationTaskName", 717 "documentation":"<p>Unique identifier that references the migration task. <i>Do not store personal data in this field.</i> </p>" 718 }, 719 "DryRun":{ 720 "shape":"DryRun", 721 "documentation":"<p>Optional boolean flag to indicate whether any effect should take place. Used to test if the caller has permission to make the call.</p>" 722 } 723 } 724 }, 725 "ImportMigrationTaskResult":{ 726 "type":"structure", 727 "members":{ 728 } 729 }, 730 "InternalServerError":{ 731 "type":"structure", 732 "members":{ 733 "Message":{"shape":"ErrorMessage"} 734 }, 735 "documentation":"<p>Exception raised when an internal, configuration, or dependency error is encountered.</p>", 736 "exception":true, 737 "fault":true 738 }, 739 "InvalidInputException":{ 740 "type":"structure", 741 "members":{ 742 "Message":{"shape":"ErrorMessage"} 743 }, 744 "documentation":"<p>Exception raised when the provided input violates a policy constraint or is entered in the wrong format or data type.</p>", 745 "exception":true 746 }, 747 "LatestResourceAttributeList":{ 748 "type":"list", 749 "member":{"shape":"ResourceAttribute"}, 750 "max":100, 751 "min":0 752 }, 753 "ListApplicationStatesRequest":{ 754 "type":"structure", 755 "members":{ 756 "ApplicationIds":{ 757 "shape":"ApplicationIds", 758 "documentation":"<p>The configurationIds from the Application Discovery Service that uniquely identifies your applications.</p>" 759 }, 760 "NextToken":{ 761 "shape":"Token", 762 "documentation":"<p>If a <code>NextToken</code> was returned by a previous call, there are more results available. To retrieve the next page of results, make the call again using the returned token in <code>NextToken</code>.</p>" 763 }, 764 "MaxResults":{ 765 "shape":"MaxResults", 766 "documentation":"<p>Maximum number of results to be returned per page.</p>" 767 } 768 } 769 }, 770 "ListApplicationStatesResult":{ 771 "type":"structure", 772 "members":{ 773 "ApplicationStateList":{ 774 "shape":"ApplicationStateList", 775 "documentation":"<p>A list of Applications that exist in Application Discovery Service.</p>" 776 }, 777 "NextToken":{ 778 "shape":"Token", 779 "documentation":"<p>If a <code>NextToken</code> was returned by a previous call, there are more results available. To retrieve the next page of results, make the call again using the returned token in <code>NextToken</code>.</p>" 780 } 781 } 782 }, 783 "ListCreatedArtifactsRequest":{ 784 "type":"structure", 785 "required":[ 786 "ProgressUpdateStream", 787 "MigrationTaskName" 788 ], 789 "members":{ 790 "ProgressUpdateStream":{ 791 "shape":"ProgressUpdateStream", 792 "documentation":"<p>The name of the ProgressUpdateStream. </p>" 793 }, 794 "MigrationTaskName":{ 795 "shape":"MigrationTaskName", 796 "documentation":"<p>Unique identifier that references the migration task. <i>Do not store personal data in this field.</i> </p>" 797 }, 798 "NextToken":{ 799 "shape":"Token", 800 "documentation":"<p>If a <code>NextToken</code> was returned by a previous call, there are more results available. To retrieve the next page of results, make the call again using the returned token in <code>NextToken</code>.</p>" 801 }, 802 "MaxResults":{ 803 "shape":"MaxResultsCreatedArtifacts", 804 "documentation":"<p>Maximum number of results to be returned per page.</p>" 805 } 806 } 807 }, 808 "ListCreatedArtifactsResult":{ 809 "type":"structure", 810 "members":{ 811 "NextToken":{ 812 "shape":"Token", 813 "documentation":"<p>If there are more created artifacts than the max result, return the next token to be passed to the next call as a bookmark of where to start from.</p>" 814 }, 815 "CreatedArtifactList":{ 816 "shape":"CreatedArtifactList", 817 "documentation":"<p>List of created artifacts up to the maximum number of results specified in the request.</p>" 818 } 819 } 820 }, 821 "ListDiscoveredResourcesRequest":{ 822 "type":"structure", 823 "required":[ 824 "ProgressUpdateStream", 825 "MigrationTaskName" 826 ], 827 "members":{ 828 "ProgressUpdateStream":{ 829 "shape":"ProgressUpdateStream", 830 "documentation":"<p>The name of the ProgressUpdateStream.</p>" 831 }, 832 "MigrationTaskName":{ 833 "shape":"MigrationTaskName", 834 "documentation":"<p>The name of the MigrationTask. <i>Do not store personal data in this field.</i> </p>" 835 }, 836 "NextToken":{ 837 "shape":"Token", 838 "documentation":"<p>If a <code>NextToken</code> was returned by a previous call, there are more results available. To retrieve the next page of results, make the call again using the returned token in <code>NextToken</code>.</p>" 839 }, 840 "MaxResults":{ 841 "shape":"MaxResultsResources", 842 "documentation":"<p>The maximum number of results returned per page.</p>" 843 } 844 } 845 }, 846 "ListDiscoveredResourcesResult":{ 847 "type":"structure", 848 "members":{ 849 "NextToken":{ 850 "shape":"Token", 851 "documentation":"<p>If there are more discovered resources than the max result, return the next token to be passed to the next call as a bookmark of where to start from.</p>" 852 }, 853 "DiscoveredResourceList":{ 854 "shape":"DiscoveredResourceList", 855 "documentation":"<p>Returned list of discovered resources associated with the given MigrationTask.</p>" 856 } 857 } 858 }, 859 "ListMigrationTasksRequest":{ 860 "type":"structure", 861 "members":{ 862 "NextToken":{ 863 "shape":"Token", 864 "documentation":"<p>If a <code>NextToken</code> was returned by a previous call, there are more results available. To retrieve the next page of results, make the call again using the returned token in <code>NextToken</code>.</p>" 865 }, 866 "MaxResults":{ 867 "shape":"MaxResults", 868 "documentation":"<p>Value to specify how many results are returned per page.</p>" 869 }, 870 "ResourceName":{ 871 "shape":"ResourceName", 872 "documentation":"<p>Filter migration tasks by discovered resource name.</p>" 873 } 874 } 875 }, 876 "ListMigrationTasksResult":{ 877 "type":"structure", 878 "members":{ 879 "NextToken":{ 880 "shape":"Token", 881 "documentation":"<p>If there are more migration tasks than the max result, return the next token to be passed to the next call as a bookmark of where to start from.</p>" 882 }, 883 "MigrationTaskSummaryList":{ 884 "shape":"MigrationTaskSummaryList", 885 "documentation":"<p>Lists the migration task's summary which includes: <code>MigrationTaskName</code>, <code>ProgressPercent</code>, <code>ProgressUpdateStream</code>, <code>Status</code>, and the <code>UpdateDateTime</code> for each task.</p>" 886 } 887 } 888 }, 889 "ListProgressUpdateStreamsRequest":{ 890 "type":"structure", 891 "members":{ 892 "NextToken":{ 893 "shape":"Token", 894 "documentation":"<p>If a <code>NextToken</code> was returned by a previous call, there are more results available. To retrieve the next page of results, make the call again using the returned token in <code>NextToken</code>.</p>" 895 }, 896 "MaxResults":{ 897 "shape":"MaxResults", 898 "documentation":"<p>Filter to limit the maximum number of results to list per page.</p>" 899 } 900 } 901 }, 902 "ListProgressUpdateStreamsResult":{ 903 "type":"structure", 904 "members":{ 905 "ProgressUpdateStreamSummaryList":{ 906 "shape":"ProgressUpdateStreamSummaryList", 907 "documentation":"<p>List of progress update streams up to the max number of results passed in the input.</p>" 908 }, 909 "NextToken":{ 910 "shape":"Token", 911 "documentation":"<p>If there are more streams created than the max result, return the next token to be passed to the next call as a bookmark of where to start from.</p>" 912 } 913 } 914 }, 915 "MaxResults":{ 916 "type":"integer", 917 "box":true, 918 "max":100, 919 "min":1 920 }, 921 "MaxResultsCreatedArtifacts":{ 922 "type":"integer", 923 "box":true, 924 "max":10, 925 "min":1 926 }, 927 "MaxResultsResources":{ 928 "type":"integer", 929 "box":true, 930 "max":10, 931 "min":1 932 }, 933 "MigrationTask":{ 934 "type":"structure", 935 "members":{ 936 "ProgressUpdateStream":{ 937 "shape":"ProgressUpdateStream", 938 "documentation":"<p>A name that identifies the vendor of the migration tool being used.</p>" 939 }, 940 "MigrationTaskName":{ 941 "shape":"MigrationTaskName", 942 "documentation":"<p>Unique identifier that references the migration task. <i>Do not store personal data in this field.</i> </p>" 943 }, 944 "Task":{ 945 "shape":"Task", 946 "documentation":"<p>Task object encapsulating task information.</p>" 947 }, 948 "UpdateDateTime":{ 949 "shape":"UpdateDateTime", 950 "documentation":"<p>The timestamp when the task was gathered.</p>" 951 }, 952 "ResourceAttributeList":{ 953 "shape":"LatestResourceAttributeList", 954 "documentation":"<p>Information about the resource that is being migrated. This data will be used to map the task to a resource in the Application Discovery Service repository.</p>" 955 } 956 }, 957 "documentation":"<p>Represents a migration task in a migration tool.</p>" 958 }, 959 "MigrationTaskName":{ 960 "type":"string", 961 "max":256, 962 "min":1, 963 "pattern":"[^:|]+" 964 }, 965 "MigrationTaskSummary":{ 966 "type":"structure", 967 "members":{ 968 "ProgressUpdateStream":{ 969 "shape":"ProgressUpdateStream", 970 "documentation":"<p>An AWS resource used for access control. It should uniquely identify the migration tool as it is used for all updates made by the tool.</p>" 971 }, 972 "MigrationTaskName":{ 973 "shape":"MigrationTaskName", 974 "documentation":"<p>Unique identifier that references the migration task. <i>Do not store personal data in this field.</i> </p>" 975 }, 976 "Status":{ 977 "shape":"Status", 978 "documentation":"<p>Status of the task.</p>" 979 }, 980 "ProgressPercent":{ 981 "shape":"ProgressPercent", 982 "documentation":"<p>Indication of the percentage completion of the task.</p>" 983 }, 984 "StatusDetail":{ 985 "shape":"StatusDetail", 986 "documentation":"<p>Detail information of what is being done within the overall status state.</p>" 987 }, 988 "UpdateDateTime":{ 989 "shape":"UpdateDateTime", 990 "documentation":"<p>The timestamp when the task was gathered.</p>" 991 } 992 }, 993 "documentation":"<p>MigrationTaskSummary includes <code>MigrationTaskName</code>, <code>ProgressPercent</code>, <code>ProgressUpdateStream</code>, <code>Status</code>, and <code>UpdateDateTime</code> for each task.</p>" 994 }, 995 "MigrationTaskSummaryList":{ 996 "type":"list", 997 "member":{"shape":"MigrationTaskSummary"} 998 }, 999 "NextUpdateSeconds":{ 1000 "type":"integer", 1001 "min":0 1002 }, 1003 "NotifyApplicationStateRequest":{ 1004 "type":"structure", 1005 "required":[ 1006 "ApplicationId", 1007 "Status" 1008 ], 1009 "members":{ 1010 "ApplicationId":{ 1011 "shape":"ApplicationId", 1012 "documentation":"<p>The configurationId in Application Discovery Service that uniquely identifies the grouped application.</p>" 1013 }, 1014 "Status":{ 1015 "shape":"ApplicationStatus", 1016 "documentation":"<p>Status of the application - Not Started, In-Progress, Complete.</p>" 1017 }, 1018 "UpdateDateTime":{ 1019 "shape":"UpdateDateTime", 1020 "documentation":"<p>The timestamp when the application state changed.</p>" 1021 }, 1022 "DryRun":{ 1023 "shape":"DryRun", 1024 "documentation":"<p>Optional boolean flag to indicate whether any effect should take place. Used to test if the caller has permission to make the call.</p>" 1025 } 1026 } 1027 }, 1028 "NotifyApplicationStateResult":{ 1029 "type":"structure", 1030 "members":{ 1031 } 1032 }, 1033 "NotifyMigrationTaskStateRequest":{ 1034 "type":"structure", 1035 "required":[ 1036 "ProgressUpdateStream", 1037 "MigrationTaskName", 1038 "Task", 1039 "UpdateDateTime", 1040 "NextUpdateSeconds" 1041 ], 1042 "members":{ 1043 "ProgressUpdateStream":{ 1044 "shape":"ProgressUpdateStream", 1045 "documentation":"<p>The name of the ProgressUpdateStream. </p>" 1046 }, 1047 "MigrationTaskName":{ 1048 "shape":"MigrationTaskName", 1049 "documentation":"<p>Unique identifier that references the migration task. <i>Do not store personal data in this field.</i> </p>" 1050 }, 1051 "Task":{ 1052 "shape":"Task", 1053 "documentation":"<p>Information about the task's progress and status.</p>" 1054 }, 1055 "UpdateDateTime":{ 1056 "shape":"UpdateDateTime", 1057 "documentation":"<p>The timestamp when the task was gathered.</p>" 1058 }, 1059 "NextUpdateSeconds":{ 1060 "shape":"NextUpdateSeconds", 1061 "documentation":"<p>Number of seconds after the UpdateDateTime within which the Migration Hub can expect an update. If Migration Hub does not receive an update within the specified interval, then the migration task will be considered stale.</p>" 1062 }, 1063 "DryRun":{ 1064 "shape":"DryRun", 1065 "documentation":"<p>Optional boolean flag to indicate whether any effect should take place. Used to test if the caller has permission to make the call.</p>" 1066 } 1067 } 1068 }, 1069 "NotifyMigrationTaskStateResult":{ 1070 "type":"structure", 1071 "members":{ 1072 } 1073 }, 1074 "PolicyErrorException":{ 1075 "type":"structure", 1076 "members":{ 1077 "Message":{"shape":"ErrorMessage"} 1078 }, 1079 "documentation":"<p>Exception raised when there are problems accessing Application Discovery Service (Application Discovery Service); most likely due to a misconfigured policy or the <code>migrationhub-discovery</code> role is missing or not configured correctly.</p>", 1080 "exception":true 1081 }, 1082 "ProgressPercent":{ 1083 "type":"integer", 1084 "box":true, 1085 "max":100, 1086 "min":0 1087 }, 1088 "ProgressUpdateStream":{ 1089 "type":"string", 1090 "max":50, 1091 "min":1, 1092 "pattern":"[^/:|\\000-\\037]+" 1093 }, 1094 "ProgressUpdateStreamSummary":{ 1095 "type":"structure", 1096 "members":{ 1097 "ProgressUpdateStreamName":{ 1098 "shape":"ProgressUpdateStream", 1099 "documentation":"<p>The name of the ProgressUpdateStream. <i>Do not store personal data in this field.</i> </p>" 1100 } 1101 }, 1102 "documentation":"<p>Summary of the AWS resource used for access control that is implicitly linked to your AWS account.</p>" 1103 }, 1104 "ProgressUpdateStreamSummaryList":{ 1105 "type":"list", 1106 "member":{"shape":"ProgressUpdateStreamSummary"} 1107 }, 1108 "PutResourceAttributesRequest":{ 1109 "type":"structure", 1110 "required":[ 1111 "ProgressUpdateStream", 1112 "MigrationTaskName", 1113 "ResourceAttributeList" 1114 ], 1115 "members":{ 1116 "ProgressUpdateStream":{ 1117 "shape":"ProgressUpdateStream", 1118 "documentation":"<p>The name of the ProgressUpdateStream. </p>" 1119 }, 1120 "MigrationTaskName":{ 1121 "shape":"MigrationTaskName", 1122 "documentation":"<p>Unique identifier that references the migration task. <i>Do not store personal data in this field.</i> </p>" 1123 }, 1124 "ResourceAttributeList":{ 1125 "shape":"ResourceAttributeList", 1126 "documentation":"<p>Information about the resource that is being migrated. This data will be used to map the task to a resource in the Application Discovery Service repository.</p> <note> <p>Takes the object array of <code>ResourceAttribute</code> where the <code>Type</code> field is reserved for the following values: <code>IPV4_ADDRESS | IPV6_ADDRESS | MAC_ADDRESS | FQDN | VM_MANAGER_ID | VM_MANAGED_OBJECT_REFERENCE | VM_NAME | VM_PATH | BIOS_ID | MOTHERBOARD_SERIAL_NUMBER</code> where the identifying value can be a string up to 256 characters.</p> </note> <important> <ul> <li> <p>If any \"VM\" related value is set for a <code>ResourceAttribute</code> object, it is required that <code>VM_MANAGER_ID</code>, as a minimum, is always set. If <code>VM_MANAGER_ID</code> is not set, then all \"VM\" fields will be discarded and \"VM\" fields will not be used for matching the migration task to a server in Application Discovery Service repository. See the <a href=\"https://docs.aws.amazon.com/migrationhub/latest/ug/API_PutResourceAttributes.html#API_PutResourceAttributes_Examples\">Example</a> section below for a use case of specifying \"VM\" related values.</p> </li> <li> <p> If a server you are trying to match has multiple IP or MAC addresses, you should provide as many as you know in separate type/value pairs passed to the <code>ResourceAttributeList</code> parameter to maximize the chances of matching.</p> </li> </ul> </important>" 1127 }, 1128 "DryRun":{ 1129 "shape":"DryRun", 1130 "documentation":"<p>Optional boolean flag to indicate whether any effect should take place. Used to test if the caller has permission to make the call.</p>" 1131 } 1132 } 1133 }, 1134 "PutResourceAttributesResult":{ 1135 "type":"structure", 1136 "members":{ 1137 } 1138 }, 1139 "ResourceAttribute":{ 1140 "type":"structure", 1141 "required":[ 1142 "Type", 1143 "Value" 1144 ], 1145 "members":{ 1146 "Type":{ 1147 "shape":"ResourceAttributeType", 1148 "documentation":"<p>Type of resource.</p>" 1149 }, 1150 "Value":{ 1151 "shape":"ResourceAttributeValue", 1152 "documentation":"<p>Value of the resource type.</p>" 1153 } 1154 }, 1155 "documentation":"<p>Attribute associated with a resource.</p> <p>Note the corresponding format required per type listed below:</p> <dl> <dt>IPV4</dt> <dd> <p> <code>x.x.x.x</code> </p> <p> <i>where x is an integer in the range [0,255]</i> </p> </dd> <dt>IPV6</dt> <dd> <p> <code>y : y : y : y : y : y : y : y</code> </p> <p> <i>where y is a hexadecimal between 0 and FFFF. [0, FFFF]</i> </p> </dd> <dt>MAC_ADDRESS</dt> <dd> <p> <code>^([0-9A-Fa-f]{2}[:-]){5}([0-9A-Fa-f]{2})$</code> </p> </dd> <dt>FQDN</dt> <dd> <p> <code>^[^<>{}\\\\\\\\/?,=\\\\p{Cntrl}]{1,256}$</code> </p> </dd> </dl>" 1156 }, 1157 "ResourceAttributeList":{ 1158 "type":"list", 1159 "member":{"shape":"ResourceAttribute"}, 1160 "max":100, 1161 "min":1 1162 }, 1163 "ResourceAttributeType":{ 1164 "type":"string", 1165 "enum":[ 1166 "IPV4_ADDRESS", 1167 "IPV6_ADDRESS", 1168 "MAC_ADDRESS", 1169 "FQDN", 1170 "VM_MANAGER_ID", 1171 "VM_MANAGED_OBJECT_REFERENCE", 1172 "VM_NAME", 1173 "VM_PATH", 1174 "BIOS_ID", 1175 "MOTHERBOARD_SERIAL_NUMBER" 1176 ] 1177 }, 1178 "ResourceAttributeValue":{ 1179 "type":"string", 1180 "max":256, 1181 "min":1, 1182 "pattern":"^.{1,256}$" 1183 }, 1184 "ResourceName":{ 1185 "type":"string", 1186 "max":1600, 1187 "min":1, 1188 "pattern":"^.{1,1600}$" 1189 }, 1190 "ResourceNotFoundException":{ 1191 "type":"structure", 1192 "members":{ 1193 "Message":{"shape":"ErrorMessage"} 1194 }, 1195 "documentation":"<p>Exception raised when the request references a resource (Application Discovery Service configuration, update stream, migration task, etc.) that does not exist in Application Discovery Service (Application Discovery Service) or in Migration Hub's repository.</p>", 1196 "exception":true 1197 }, 1198 "RetryAfterSeconds":{"type":"integer"}, 1199 "ServiceUnavailableException":{ 1200 "type":"structure", 1201 "members":{ 1202 "Message":{"shape":"ErrorMessage"} 1203 }, 1204 "documentation":"<p>Exception raised when there is an internal, configuration, or dependency error encountered.</p>", 1205 "exception":true, 1206 "fault":true 1207 }, 1208 "Status":{ 1209 "type":"string", 1210 "enum":[ 1211 "NOT_STARTED", 1212 "IN_PROGRESS", 1213 "FAILED", 1214 "COMPLETED" 1215 ] 1216 }, 1217 "StatusDetail":{ 1218 "type":"string", 1219 "max":500, 1220 "min":0, 1221 "pattern":"^.{0,500}$" 1222 }, 1223 "Task":{ 1224 "type":"structure", 1225 "required":["Status"], 1226 "members":{ 1227 "Status":{ 1228 "shape":"Status", 1229 "documentation":"<p>Status of the task - Not Started, In-Progress, Complete.</p>" 1230 }, 1231 "StatusDetail":{ 1232 "shape":"StatusDetail", 1233 "documentation":"<p>Details of task status as notified by a migration tool. A tool might use this field to provide clarifying information about the status that is unique to that tool or that explains an error state.</p>" 1234 }, 1235 "ProgressPercent":{ 1236 "shape":"ProgressPercent", 1237 "documentation":"<p>Indication of the percentage completion of the task.</p>" 1238 } 1239 }, 1240 "documentation":"<p>Task object encapsulating task information.</p>" 1241 }, 1242 "ThrottlingException":{ 1243 "type":"structure", 1244 "required":["Message"], 1245 "members":{ 1246 "Message":{ 1247 "shape":"ErrorMessage", 1248 "documentation":"<p>A message that provides information about the exception.</p>" 1249 }, 1250 "RetryAfterSeconds":{ 1251 "shape":"RetryAfterSeconds", 1252 "documentation":"<p>The number of seconds the caller should wait before retrying.</p>" 1253 } 1254 }, 1255 "documentation":"<p>The request was denied due to request throttling.</p>", 1256 "exception":true 1257 }, 1258 "Token":{ 1259 "type":"string", 1260 "max":2048, 1261 "min":0, 1262 "pattern":"^[a-zA-Z0-9\\/\\+\\=]{0,2048}$" 1263 }, 1264 "UnauthorizedOperation":{ 1265 "type":"structure", 1266 "members":{ 1267 "Message":{"shape":"ErrorMessage"} 1268 }, 1269 "documentation":"<p>Exception raised to indicate a request was not authorized when the <code>DryRun</code> flag is set to \"true\".</p>", 1270 "exception":true 1271 }, 1272 "UpdateDateTime":{"type":"timestamp"} 1273 }, 1274 "documentation":"<p>The AWS Migration Hub API methods help to obtain server and application migration status and integrate your resource-specific migration tool by providing a programmatic interface to Migration Hub.</p> <p>Remember that you must set your AWS Migration Hub home region before you call any of these APIs, or a <code>HomeRegionNotSetException</code> error will be returned. Also, you must make the API calls while in your home region.</p>" 1275} 1276