increaseStreamRetentionPeriod method

Future<void> increaseStreamRetentionPeriod({
  1. required int retentionPeriodHours,
  2. required String streamName,
})

Increases the Kinesis data stream's retention period, which is the length of time data records are accessible after they are added to the stream. The maximum value of a stream's retention period is 168 hours (7 days).

If you choose a longer stream retention period, this operation increases the time period during which records that have not yet expired are accessible. However, it does not make previous, expired data (older than the stream's previous retention period) accessible after the operation has been called. For example, if a stream's retention period is set to 24 hours and is increased to 168 hours, any data that is older than 24 hours remains inaccessible to consumer applications.

May throw ResourceInUseException. May throw ResourceNotFoundException. May throw LimitExceededException. May throw InvalidArgumentException.

Parameter retentionPeriodHours : The new retention period of the stream, in hours. Must be more than the current retention period.

Parameter streamName : The name of the stream to modify.

Implementation

Future<void> increaseStreamRetentionPeriod({
  required int retentionPeriodHours,
  required String streamName,
}) async {
  ArgumentError.checkNotNull(retentionPeriodHours, 'retentionPeriodHours');
  ArgumentError.checkNotNull(streamName, 'streamName');
  _s.validateStringLength(
    'streamName',
    streamName,
    1,
    128,
    isRequired: true,
  );
  final headers = <String, String>{
    'Content-Type': 'application/x-amz-json-1.1',
    'X-Amz-Target': 'Kinesis_20131202.IncreaseStreamRetentionPeriod'
  };
  await _protocol.send(
    method: 'POST',
    requestUri: '/',
    exceptionFnMap: _exceptionFns,
    // TODO queryParams
    headers: headers,
    payload: {
      'RetentionPeriodHours': retentionPeriodHours,
      'StreamName': streamName,
    },
  );
}