All Downloads are FREE. Search and download functionalities are using the official Maven repository.

com.ibm.cloud.objectstorage.services.aspera.transfer.AsperaFaspManagerWrapper Maven / Gradle / Ivy

/*
* Copyright 2018 IBM Corp. 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. You may obtain a copy of the License at
*
* http://www.apache.org/licenses/LICENSE-2.0
*
* Unless required by applicable law or agreed to in writing, software distributed under the License 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.ibm.cloud.objectstorage.services.aspera.transfer;

import com.ibm.aspera.faspmanager2.faspmanager2;
import com.ibm.cloud.objectstorage.services.aspera.transfer.internal.AsperaTransferManagerUtils;

import org.apache.commons.logging.Log;
import org.apache.commons.logging.LogFactory;


/**
 * Wrapper Class which provides logging around the faspmanager2 calls
 */
public class AsperaFaspManagerWrapper {
	private AsperaTransaction asperaTransaction;

    protected Log log = LogFactory.getLog(AsperaFaspManagerWrapper.class);
   
    /**
     * Load in native libraries once
     */
    static {
    	String location = AsperaLibraryLoader.load();
    	faspmanager2.configureAsperaLocation(location);
    	faspmanager2.configureLogLocation(location);
    }
    
    public AsperaFaspManagerWrapper() {}
    
    public AsperaFaspManagerWrapper(AsperaTransaction asperaTransaction) {
    	this.asperaTransaction = asperaTransaction;
    }
	
	public long startTransfer(final String xferId, final String transferSpecStr) {
		log.info("Starting transfer with xferId [" + xferId + "]");
    
		if (log.isDebugEnabled()) {
			log.debug("Transfer Spec for Session with xferId [" + xferId + "]");
			log.debug(AsperaTransferManagerUtils.getRedactedJsonString(
					transferSpecStr, 
					"token"));
		}
		
		log.trace("Calling method [startTransfer] with parameters [\"" + xferId + "\", null, transferSpecStr, transferListener]");
		long rtn = faspmanager2.startTransfer(xferId, null, transferSpecStr, asperaTransaction.getTransferListener());
		log.trace("Method [startTransfer] returned for xferId [\"" + xferId + "\"] with result: [" + rtn + "]");
		return rtn;
	}

	public boolean pause(final String xferId) {
		log.info("Pausing transfer with xferId [" + xferId + "]");
		log.trace("Calling method [modifyTransfer] with parameters [\"" + xferId + "\", 4, 0]");
		boolean rtn = faspmanager2.modifyTransfer(xferId, 4, 0);
		log.trace("Method [modifyTransfer] returned for xferId [\"" + xferId + "\"] with result: [" + rtn + "]");
		return rtn;
	}

	public boolean resume(final String xferId) {
		log.info("Resuming transfer with xferId [" + xferId + "]");
		log.trace("Calling method [modifyTransfer] with parameters [\"" + xferId + "\", 5, 0]");
		boolean rtn = faspmanager2.modifyTransfer(xferId, 5, 0);
		log.trace("Method [modifyTransfer] returned for xferId [\"" + xferId + "\"] with result: [" + rtn + "]");
		return rtn;
	}

    public boolean cancel(final String xferId) {
        log.info("Cancel transfer with xferId [" + xferId + "]");
		log.trace("Calling method [stopTransfer] with parameters [\"" + xferId + "\", 8, 0]");
        boolean rtn = faspmanager2.stopTransfer(xferId);
		log.trace("Method [stopTransfer] returned for xferId [\"" + xferId + "\"] with result: [" + rtn + "]");
		return rtn;
    }

	public boolean isRunning(final String xferId) {
		log.trace("Calling method [isRunning] with parameters [\"" + xferId + "\"]");
		boolean rtn = faspmanager2.isRunning(xferId);
		log.trace("Method [isRunning] returned for xferId [\"" + xferId + "\"] with result: [" + rtn + "]");
		return rtn;
	}

	public boolean configureLogLocation(final String ascpLogPath) {
		log.trace("Calling method [configureLogLocation] with parameters [\"" + ascpLogPath + "\"]");
		boolean rtn =  faspmanager2.configureLogLocation(ascpLogPath);
		log.trace("Method [configureLogLocation] returned for ascpLogPath [\"" + ascpLogPath + "\"] with result: [" + rtn + "]");
		return rtn;
	}

	public void setAsperaTransaction(AsperaTransaction asperaTransaction) {
		this.asperaTransaction = asperaTransaction;
	}

}




© 2015 - 2025 Weber Informatics LLC | Privacy Policy