in src/main/java/com/amazonaws/kinesisvideo/internal/service/DefaultServiceCallbacksImpl.java [270:314]
public void getStreamingEndpoint(
@Nonnull final String streamName,
@Nonnull final String apiName,
final long callAfter,
final long timeout,
@Nullable final byte[] authData,
final int authType,
final long streamHandle,
final KinesisVideoProducerStream stream) throws ProducerException {
Preconditions.checkState(isInitialized(), "Service callbacks object should be initialized first");
final long delay = calculateRelativeServiceCallAfter(callAfter);
final Runnable task = new Runnable() {
@Override
public void run() {
final KinesisVideoCredentialsProvider credentialsProvider = getCredentialsProvider(authData, log);
final long timeoutInMillis = timeout / Time.HUNDREDS_OF_NANOS_IN_A_MILLISECOND;
int statusCode = HTTP_OK;
String endpoint = "";
try {
endpoint = kinesisVideoServiceClient.getDataEndpoint(streamName,
apiName,
timeoutInMillis,
credentialsProvider);
} catch (final KinesisVideoException e) {
log.error("Kinesis Video service client returned an error " + e.getMessage() + ". Reporting to Kinesis Video PIC.");
statusCode = getStatusCodeFromException(e);
}
if (statusCode != HTTP_OK && isBlank(endpoint)) {
// TODO: more URI validation
statusCode = HTTP_NOT_FOUND;
}
try {
kinesisVideoProducer.getStreamingEndpointResult(stream, streamHandle, endpoint, statusCode);
} catch (final ProducerException e) {
throw new RuntimeException(e);
}
}
};
executor.schedule(task, delay, TimeUnit.NANOSECONDS);
}