startImportTask method
Starts an import task, which allows you to import details of your on-premises environment directly into AWS Migration Hub without having to use the Application Discovery Service (ADS) tools such as the Discovery Connector or Discovery Agent. This gives you the option to perform migration assessment and planning directly from your imported data, including the ability to group your devices as applications and track their migration status.
To start an import request, do this:
- Download the specially formatted comma separated value (CSV) import template, which you can find here: https://s3-us-west-2.amazonaws.com/templates-7cffcf56-bd96-4b1c-b45b-a5b42f282e46/import_template.csv.
- Fill out the template with your server and application data.
- Upload your import file to an Amazon S3 bucket, and make a note of it's Object URL. Your import file must be in the CSV format.
-
Use the console or the
StartImportTask
command with the AWS CLI or one of the AWS SDKs to import the records from your file.
May throw ResourceInUseException. May throw AuthorizationErrorException. May throw InvalidParameterException. May throw InvalidParameterValueException. May throw ServerInternalErrorException. May throw HomeRegionNotSetException.
Parameter importUrl
:
The URL for your import file that you've uploaded to Amazon S3.
Parameter name
:
A descriptive name for this request. You can use this name to filter
future requests related to this import task, such as identifying
applications and servers that were included in this import task. We
recommend that you use a meaningful name for each import task.
Parameter clientRequestToken
:
Optional. A unique token that you can provide to prevent the same import
request from occurring more than once. If you don't provide a token, a
token is automatically generated.
Sending more than one StartImportTask
request with the same
client request token will return information about the original import
task with that client request token.
Implementation
Future<StartImportTaskResponse> startImportTask({
required String importUrl,
required String name,
String? clientRequestToken,
}) async {
ArgumentError.checkNotNull(importUrl, 'importUrl');
_s.validateStringLength(
'importUrl',
importUrl,
1,
4000,
isRequired: true,
);
ArgumentError.checkNotNull(name, 'name');
_s.validateStringLength(
'name',
name,
1,
100,
isRequired: true,
);
_s.validateStringLength(
'clientRequestToken',
clientRequestToken,
1,
100,
);
final headers = <String, String>{
'Content-Type': 'application/x-amz-json-1.1',
'X-Amz-Target': 'AWSPoseidonService_V2015_11_01.StartImportTask'
};
final jsonResponse = await _protocol.send(
method: 'POST',
requestUri: '/',
exceptionFnMap: _exceptionFns,
// TODO queryParams
headers: headers,
payload: {
'importUrl': importUrl,
'name': name,
'clientRequestToken':
clientRequestToken ?? _s.generateIdempotencyToken(),
},
);
return StartImportTaskResponse.fromJson(jsonResponse.body);
}