use of java.io.PipedOutputStream in project accumulo by apache.
the class PasswordConverterTest method setup.
@Before
public void setup() throws IOException {
argv = new String[] { "--password", "" };
password = new Password();
PipedInputStream in = new PipedInputStream();
PipedOutputStream out = new PipedOutputStream(in);
OutputStreamWriter osw = new OutputStreamWriter(out);
osw.write("secret");
osw.close();
System.setIn(in);
}
use of java.io.PipedOutputStream in project smarthome by eclipse.
the class JSONResponse method createResponse.
private Response createResponse(Status status, Object entity) {
ResponseBuilder rp = responseBuilder(status);
if (entity == null) {
return rp.build();
}
// The PipedOutputStream will only be closed by the writing thread
// since closing it during this method call would be too early.
// The receiver of the response will read from the pipe after this method returns.
PipedOutputStream out = new PipedOutputStream();
try {
// we will not actively close the PipedInputStream since it is read by the receiving end
// and will be GC'ed once the response is consumed.
PipedInputStream in = new PipedInputStream(out);
rp.entity(in);
} catch (IOException e) {
throw new RuntimeException(e);
}
Thread writerThread = new Thread(() -> {
try (JsonWriter jsonWriter = new JsonWriter(new BufferedWriter(new OutputStreamWriter(out)))) {
if (entity != null) {
gson.toJson(entity, entity.getClass(), jsonWriter);
jsonWriter.flush();
}
} catch (IOException | JsonIOException e) {
logger.error("Error streaming JSON through PipedInpuStream/PipedOutputStream: ", e);
}
});
// daemonize thread to permit the JVM shutdown even if we stream JSON.
writerThread.setDaemon(true);
writerThread.start();
return rp.build();
}
use of java.io.PipedOutputStream in project data-prep by Talend.
the class DataSetService method updateRawDataSet.
/**
* Updates a data set content and metadata. If no data set exists for given id, data set is silently created.
*
* @param dataSetId The id of data set to be updated.
* @param name The new name for the data set. Empty name (or <code>null</code>) does not update dataset name.
* @param dataSetContent The new content for the data set. If empty, existing content will <b>not</b> be replaced.
* For delete operation, look at {@link #delete(String)}.
*/
@RequestMapping(value = "/datasets/{id}/raw", method = PUT)
@ApiOperation(value = "Update a data set by id", notes = "Update a data set content based on provided id and PUT body. Id should be a UUID returned by the list operation. Not valid or non existing data set id returns empty content. For documentation purposes, body is typed as 'text/plain' but operation accepts binary content too.")
@Timed
@VolumeMetered
public String updateRawDataSet(//
@PathVariable(value = "id") @ApiParam(name = "id", value = "Id of the data set to update") String dataSetId, //
@RequestParam(value = "name", required = false) @ApiParam(name = "name", value = "New value for the data set name") String name, //
@RequestParam(value = "size", required = false) @ApiParam(name = "size", value = "The size of the dataSet") Long size, @ApiParam(value = "content") InputStream dataSetContent) {
LOG.debug("updating dataset content #{}", dataSetId);
if (name != null) {
checkDataSetName(name);
}
DataSetMetadata currentDataSetMetadata = dataSetMetadataRepository.get(dataSetId);
if (currentDataSetMetadata == null) {
return create(name, null, size, TEXT_PLAIN_VALUE, dataSetContent);
} else {
// just like the creation, let's make sure invalid size forbids dataset creation
if (size != null && size < 0) {
LOG.warn("invalid size provided {}", size);
throw new TDPException(UNSUPPORTED_CONTENT);
}
final UpdateDataSetCacheKey cacheKey = new UpdateDataSetCacheKey(currentDataSetMetadata.getId());
final DistributedLock lock = dataSetMetadataRepository.createDatasetMetadataLock(currentDataSetMetadata.getId());
try {
lock.lock();
// check the size if it's available (quick win)
if (size != null && size > 0) {
quotaService.checkIfAddingSizeExceedsAvailableStorage(Math.abs(size - currentDataSetMetadata.getDataSetSize()));
}
final DataSetMetadataBuilder datasetBuilder = metadataBuilder.metadata().id(currentDataSetMetadata.getId());
datasetBuilder.copyNonContentRelated(currentDataSetMetadata);
datasetBuilder.modified(System.currentTimeMillis());
if (!StringUtils.isEmpty(name)) {
datasetBuilder.name(name);
}
final DataSetMetadata updatedDataSetMetadata = datasetBuilder.build();
// Save data set content into cache to make sure there's enough space in the content store
final long maxDataSetSizeAllowed = getMaxDataSetSizeAllowed();
final StrictlyBoundedInputStream sizeCalculator = new StrictlyBoundedInputStream(dataSetContent, maxDataSetSizeAllowed);
try (OutputStream cacheEntry = cacheManager.put(cacheKey, TimeToLive.DEFAULT)) {
IOUtils.copy(sizeCalculator, cacheEntry);
}
// once fully copied to the cache, we know for sure that the content store has enough space, so let's copy
// from the cache to the content store
PipedInputStream toContentStore = new PipedInputStream();
PipedOutputStream fromCache = new PipedOutputStream(toContentStore);
Runnable r = () -> {
try (final InputStream input = cacheManager.get(cacheKey)) {
IOUtils.copy(input, fromCache);
// it's important to close this stream, otherwise the piped stream will never close
fromCache.close();
} catch (IOException e) {
throw new TDPException(UNABLE_TO_CREATE_OR_UPDATE_DATASET, e);
}
};
executor.execute(r);
contentStore.storeAsRaw(updatedDataSetMetadata, toContentStore);
// update the dataset metadata with its new size
updatedDataSetMetadata.setDataSetSize(sizeCalculator.getTotal());
dataSetMetadataRepository.save(updatedDataSetMetadata);
// publishing update event
publisher.publishEvent(new DatasetUpdatedEvent(updatedDataSetMetadata));
} catch (StrictlyBoundedInputStream.InputStreamTooLargeException e) {
LOG.warn("Dataset update {} cannot be done, new content is too big", currentDataSetMetadata.getId());
throw new TDPException(MAX_STORAGE_MAY_BE_EXCEEDED, e, build().put("limit", e.getMaxSize()));
} catch (IOException e) {
LOG.error("Error updating the dataset", e);
throw new TDPException(UNABLE_TO_CREATE_OR_UPDATE_DATASET, e);
} finally {
dataSetContentToNull(dataSetContent);
// whatever the outcome the cache needs to be cleaned
if (cacheManager.has(cacheKey)) {
cacheManager.evict(cacheKey);
}
lock.unlock();
}
// Content was changed, so queue events (format analysis, content indexing for search...)
analyzeDataSet(currentDataSetMetadata.getId(), true, emptyList());
return currentDataSetMetadata.getId();
}
}
use of java.io.PipedOutputStream in project org.csstudio.display.builder by kasemir.
the class WorkspaceResourceHelperImpl method writeWorkspaceResource.
@Override
public OutputStream writeWorkspaceResource(final String resource_name) throws Exception {
final IWorkspaceRoot root = ResourcesPlugin.getWorkspace().getRoot();
final IFile file = root.getFile(new Path(resource_name));
// IFile API requires an InputStream for the content.
// That content, however, doesn't exist at this time, because
// it's about to be written to an OutputStream by the caller
// of this function.
// -> Provide pipe, with background job to read from pipe and write the file
final PipedOutputStream buf = new PipedOutputStream();
final PipedInputStream input = new PipedInputStream(buf);
final IJobFunction writer = monitor -> {
try {
if (file.exists())
file.setContents(input, true, false, monitor);
else
file.create(input, true, monitor);
} catch (Exception ex) {
logger.log(Level.WARNING, "Cannot write to " + resource_name, ex);
}
return Status.OK_STATUS;
};
Job.create("Workspace Writer", writer).schedule();
// Provide caller with output end of pipe to fill
return buf;
}
use of java.io.PipedOutputStream in project oozie by apache.
the class TestCLIParser method readCommandOutput.
private String readCommandOutput(CLIParser parser, CLIParser.Command c) throws IOException {
ByteArrayOutputStream outBytes = new ByteArrayOutputStream();
PipedOutputStream pipeOut = new PipedOutputStream();
PipedInputStream pipeIn = new PipedInputStream(pipeOut, 1024 * 10);
System.setOut(new PrintStream(pipeOut));
parser.showHelp(c.getCommandLine());
pipeOut.close();
ByteStreams.copy(pipeIn, outBytes);
pipeIn.close();
return new String(outBytes.toByteArray());
}
Aggregations