use of com.emc.atmos.api.ObjectPath in project camel by apache.
the class AtmosAPIFacade method downloadSingleFile.
private void downloadSingleFile(String path, Map<String, ByteArrayOutputStream> resultEntries) throws AtmosException {
ByteArrayOutputStream baos = new ByteArrayOutputStream();
byte[] content = null;
try {
content = AtmosAPIFacade.client.readObject(new ObjectPath(path), byte[].class);
baos.write(content);
} catch (IOException e) {
throw new AtmosException(path + " cannot obtain a stream", e);
}
if (content != null) {
resultEntries.put(path, baos);
LOG.debug("Downloaded path: {} size:", path, baos.size());
}
}
use of com.emc.atmos.api.ObjectPath in project camel by apache.
the class AtmosAPIFacade method del.
/**
* Delete every files and subdirectories inside the remote directory. In
* case the remotePath is a file, delete the file.
*
* @param remotePath the remote location to delete
* @return a AtmosResult object with the result of the delete operation.
* @throws AtmosException
*/
public AtmosResult del(String remotePath) throws AtmosException {
AtmosResult result = null;
ObjectPath op = new ObjectPath(remotePath);
AtmosAPIFacade.client.delete(op);
result = new AtmosDelResult();
result.setResultEntries(remotePath);
return result;
}
use of com.emc.atmos.api.ObjectPath in project camel by apache.
the class AtmosAPIFacade method downloadFilesInFolder.
private void downloadFilesInFolder(String atmosPath, Map<String, ByteArrayOutputStream> resultEntries) throws AtmosException {
ObjectPath atmosEntry = new ObjectPath(atmosPath);
if (AtmosAPIFacade.client.getSystemMetadata(atmosEntry) == null) {
throw new AtmosException(atmosPath + " does not exist or cannot obtain metadata");
}
if (!atmosEntry.isDirectory()) {
LOG.debug("downloading a single file...");
downloadSingleFile(atmosPath, resultEntries);
return;
}
ListDirectoryRequest listRequest = new ListDirectoryRequest().path(atmosEntry);
AtmosAPIFacade.client.listDirectory(listRequest);
for (DirectoryEntry entry : AtmosAPIFacade.client.listDirectory(listRequest).getEntries()) {
if (!entry.isDirectory()) {
try {
//get the baos of the file
downloadSingleFile(atmosEntry.getPath().concat(entry.getFilename()), resultEntries);
} catch (AtmosException e) {
LOG.warn("Cannot download from " + entry.getFilename());
}
} else {
//iterate on folder
downloadFilesInFolder(atmosEntry.getPath().concat(entry.getFilename()), resultEntries);
}
}
}
use of com.emc.atmos.api.ObjectPath 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;
}
}
use of com.emc.atmos.api.ObjectPath in project camel by apache.
the class AtmosAPIFacade method move.
/**
* Rename a remote path with the new path location.
*
* @param remotePath the existing remote path to be renamed
* @param newRemotePath the new remote path substituting the old one
* @return a AtmosResult object with the result of the move operation.
* @throws AtmosException
*/
public AtmosResult move(String remotePath, String newRemotePath) throws AtmosException {
AtmosResult result = null;
AtmosAPIFacade.client.move(new ObjectPath(remotePath), new ObjectPath(newRemotePath), true);
result = new AtmosMoveResult();
result.setResultEntries(remotePath + "-" + newRemotePath);
return result;
}
Aggregations