public interface ITransferWorker
MaxConcurrency | Maximum number of concurrent tasks to use during parallel transfers. For serial transfers, this property must return 1. |
State | Managed by TransferDriver. The implementation should initialize this property to null. The driver injects a valid instance before execution starts. After execution, the instance may be inspected for errors. |
FinalizeAsync | Finalizes the worker by computing the verification hash and disposing of any previously acquired resources. Failure must be signaled by throwing an exception. This method is always invoked, once per transfer. It is invoked regardless of whether the worker encountered an error or not (Exception). IMPORTANT: Resources should be disposed even if cancellation is requested. |
InitializeAsync | Initializes the worker for the next transfer, acquiring any needed resources. Failure must be signaled by throwing an exception. This method is always invoked, once per transfer. |