/* * Copyright 2013-2016 Amazon.com, Inc. or its affiliates. All Rights Reserved. * * Licensed under the Apache License, Version 2.0 (the "License"). * You may not use this file except in compliance with the License. * A copy of the License is located at * * http://aws.amazon.com/apache2.0 * * or in the "license" file accompanying this file. This file is distributed * on an "AS IS" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either * express or implied. See the License for the specific language governing * permissions and limitations under the License. */ package com.amazonaws.mobileconnectors.s3.transfermanager.internal; import com.amazonaws.event.ProgressListener; import com.amazonaws.event.ProgressListenerCallbackExecutor; import com.amazonaws.mobileconnectors.s3.transfermanager.PersistableTransfer; import java.util.concurrent.Future; /** * Used to publish transfer events. */ public class S3ProgressPublisher extends ProgressListenerCallbackExecutor { /** * Used to submit a task to publish the availability of a persistable * transfer to the given listener. * * @return the future of the submitted task; or null if there is no * listener. */ public static Future<?> publishTransferPersistable( final ProgressListener listener, final PersistableTransfer persistableTransfer) { if (persistableTransfer == null || !(listener instanceof S3ProgressListener)) return null; final S3ProgressListener s3listener = (S3ProgressListener) listener; return getExecutorService().submit(new Runnable() { @Override public void run() { s3listener.onPersistableTransfer(persistableTransfer); } }); } }