startDataSourceSyncJob method

Future<StartDataSourceSyncJobResponse> startDataSourceSyncJob({
  1. required String id,
  2. required String indexId,
})

Starts a synchronization job for a data source. If a synchronization job is already in progress, Amazon Kendra returns a ResourceInUseException exception.

May throw ValidationException. May throw ResourceNotFoundException. May throw ResourceInUseException. May throw ThrottlingException. May throw AccessDeniedException. May throw ConflictException. May throw InternalServerException.

Parameter id : The identifier of the data source to synchronize.

Parameter indexId : The identifier of the index that contains the data source.

Implementation

Future<StartDataSourceSyncJobResponse> startDataSourceSyncJob({
  required String id,
  required String indexId,
}) async {
  ArgumentError.checkNotNull(id, 'id');
  _s.validateStringLength(
    'id',
    id,
    1,
    100,
    isRequired: true,
  );
  ArgumentError.checkNotNull(indexId, 'indexId');
  _s.validateStringLength(
    'indexId',
    indexId,
    36,
    36,
    isRequired: true,
  );
  final headers = <String, String>{
    'Content-Type': 'application/x-amz-json-1.1',
    'X-Amz-Target': 'AWSKendraFrontendService.StartDataSourceSyncJob'
  };
  final jsonResponse = await _protocol.send(
    method: 'POST',
    requestUri: '/',
    exceptionFnMap: _exceptionFns,
    // TODO queryParams
    headers: headers,
    payload: {
      'Id': id,
      'IndexId': indexId,
    },
  );

  return StartDataSourceSyncJobResponse.fromJson(jsonResponse.body);
}