Search in sources :

Example 1 with ObjectId

use of com.emc.atmos.api.ObjectId in project camel by apache.

the class AtmosAPIFacade method put.

/**
     * Put or upload a new file or an entire directory to atmos
     *
     * @param localPath the file path or the dir path on the local filesystem
     * @param remotePath the remote path destination on atmos
     * the file already existing with the same name
     * will be overridden.
     * @return a AtmosResult object reporting for each remote path the result of
     * the operation.
     * @throws AtmosException
     */
public AtmosResult put(String localPath, String remotePath) throws AtmosException {
    AtmosResult result = new AtmosFileUploadResult();
    //a map representing for each path the result of the put operation
    Map<String, AtmosResultCode> resultEntries = null;
    //in case the remote path is not specified, the remotePath = localPath
    String atmosPath = remotePath == null ? localPath : remotePath;
    if (!atmosPath.endsWith(ATMOS_FILE_SEPARATOR)) {
        atmosPath += ATMOS_FILE_SEPARATOR;
    }
    ObjectPath atmosEntry = new ObjectPath(atmosPath);
    if (!atmosPath.equals(ATMOS_FILE_SEPARATOR)) {
        if (AtmosAPIFacade.client.getSystemMetadata(atmosEntry) == null) {
            throw new AtmosException(atmosPath + " does not exist or cannot obtain metadata");
        }
    }
    File fileLocalPath = new File(localPath);
    //verify uploading of a single file
    if (fileLocalPath.isFile()) {
        //check if atmos file exists
        if (atmosEntry != null && !atmosEntry.isDirectory()) {
            throw new AtmosException(atmosPath + " exists on atmos and is not a folder!");
        }
        atmosPath = atmosPath + fileLocalPath.getName();
        resultEntries = new HashMap<String, AtmosResultCode>(1);
        try {
            ObjectId uploadedFile = putSingleFile(fileLocalPath, atmosPath);
            if (uploadedFile == null) {
                resultEntries.put(atmosPath, AtmosResultCode.KO);
            } else {
                resultEntries.put(atmosPath, AtmosResultCode.OK);
            }
        } catch (Exception ex) {
            resultEntries.put(atmosPath, AtmosResultCode.KO);
        } finally {
            result.setResultEntries(resultEntries);
        }
        return result;
    } else {
        //verify uploading of a list of files inside a dir
        LOG.info("uploading a dir...");
        //check if atmos folder exists
        if (atmosEntry != null && !atmosEntry.isDirectory()) {
            throw new AtmosException(atmosPath + " exists on atmos and is not a folder!");
        }
        //revert to old path
        String oldAtmosPath = atmosPath;
        //list all files in a dir
        Collection<File> listFiles = FileUtils.listFiles(fileLocalPath, null, true);
        if (listFiles == null || listFiles.isEmpty()) {
            throw new AtmosException(localPath + " does not contain any files");
        }
        resultEntries = new HashMap<String, AtmosResultCode>(listFiles.size());
        for (File file : listFiles) {
            String absPath = file.getAbsolutePath();
            int indexRemainingPath = localPath.length();
            if (!localPath.endsWith("/")) {
                indexRemainingPath += 1;
            }
            String remainingPath = absPath.substring(indexRemainingPath);
            atmosPath = atmosPath + remainingPath;
            try {
                LOG.debug("uploading: {} to {}", fileLocalPath, atmosPath);
                ObjectId uploadedFile = putSingleFile(file, atmosPath);
                if (uploadedFile == null) {
                    resultEntries.put(atmosPath, AtmosResultCode.KO);
                } else {
                    resultEntries.put(atmosPath, AtmosResultCode.OK);
                }
            } catch (Exception ex) {
                resultEntries.put(atmosPath, AtmosResultCode.KO);
            }
            atmosPath = oldAtmosPath;
        }
        result.setResultEntries(resultEntries);
        return result;
    }
}
Also used : ObjectPath(com.emc.atmos.api.ObjectPath) ObjectId(com.emc.atmos.api.ObjectId) AtmosResult(org.apache.camel.component.atmos.dto.AtmosResult) AtmosFileUploadResult(org.apache.camel.component.atmos.dto.AtmosFileUploadResult) AtmosException(org.apache.camel.component.atmos.util.AtmosException) IOException(java.io.IOException) AtmosException(org.apache.camel.component.atmos.util.AtmosException) File(java.io.File) AtmosResultCode(org.apache.camel.component.atmos.util.AtmosResultCode)

Example 2 with ObjectId

use of com.emc.atmos.api.ObjectId in project camel by apache.

the class AtmosAPIFacade method putSingleFile.

private ObjectId putSingleFile(File inputFile, String atmosPath) throws Exception {
    FileInputStream inputStream = new FileInputStream(inputFile);
    ObjectId uploadedFile = null;
    try {
        ObjectPath op = new ObjectPath(atmosPath);
        CreateObjectRequest request = new CreateObjectRequest();
        request.identifier(op).content(inputStream).contentLength(inputFile.length());
        uploadedFile = AtmosAPIFacade.client.createObject(request).getObjectId();
        return uploadedFile;
    } finally {
        inputStream.close();
    }
}
Also used : ObjectPath(com.emc.atmos.api.ObjectPath) CreateObjectRequest(com.emc.atmos.api.request.CreateObjectRequest) ObjectId(com.emc.atmos.api.ObjectId) FileInputStream(java.io.FileInputStream)

Aggregations

ObjectId (com.emc.atmos.api.ObjectId)2 ObjectPath (com.emc.atmos.api.ObjectPath)2 CreateObjectRequest (com.emc.atmos.api.request.CreateObjectRequest)1 File (java.io.File)1 FileInputStream (java.io.FileInputStream)1 IOException (java.io.IOException)1 AtmosFileUploadResult (org.apache.camel.component.atmos.dto.AtmosFileUploadResult)1 AtmosResult (org.apache.camel.component.atmos.dto.AtmosResult)1 AtmosException (org.apache.camel.component.atmos.util.AtmosException)1 AtmosResultCode (org.apache.camel.component.atmos.util.AtmosResultCode)1