/*
* Copyright (c) 2011-2017 Contributors to the Eclipse Foundation
*
* This program and the accompanying materials are made available under the
* terms of the Eclipse Public License 2.0 which is available at
* http://www.eclipse.org/legal/epl-2.0, or the Apache License, Version 2.0
* which is available at https://www.apache.org/licenses/LICENSE-2.0.
*
* SPDX-License-Identifier: EPL-2.0 OR Apache-2.0
*/
package io.vertx.core.http;
import io.vertx.codegen.annotations.Fluent;
import io.vertx.codegen.annotations.VertxGen;
import io.vertx.core.Handler;
import io.vertx.core.buffer.Buffer;
import io.vertx.core.file.AsyncFile;
import io.vertx.core.streams.ReadStream;
Represents an file upload from an HTML FORM.
Author: Norman Maurer
/**
* Represents an file upload from an HTML FORM.
*
* @author <a href="mailto:nmaurer@redhat.com">Norman Maurer</a>
*/
@VertxGen
public interface HttpServerFileUpload extends ReadStream<Buffer> {
@Override
HttpServerFileUpload exceptionHandler(Handler<Throwable> handler);
@Override
HttpServerFileUpload handler(Handler<Buffer> handler);
@Override
HttpServerFileUpload endHandler(Handler<Void> endHandler);
@Override
HttpServerFileUpload pause();
@Override
HttpServerFileUpload resume();
@Override
HttpServerFileUpload fetch(long amount);
Stream the content of this upload to the given file on storage.
Params: - filename – the name of the file
/**
* Stream the content of this upload to the given file on storage.
*
* @param filename the name of the file
*/
@Fluent
HttpServerFileUpload streamToFileSystem(String filename);
Returns: the filename which was used when upload the file.
/**
* @return the filename which was used when upload the file.
*/
String filename();
Returns: the name of the attribute
/**
* @return the name of the attribute
*/
String name();
Returns: the content type for the upload
/**
* @return the content type for the upload
*/
String contentType();
Returns: the contentTransferEncoding for the upload
/**
* @return the contentTransferEncoding for the upload
*/
String contentTransferEncoding();
Returns: the charset for the upload
/**
* @return the charset for the upload
*/
String charset();
The size of the upload may not be available until it is all read. Check isSizeAvailable
to determine this Returns: the size of the upload (in bytes)
/**
* The size of the upload may not be available until it is all read.
* Check {@link #isSizeAvailable} to determine this
*
* @return the size of the upload (in bytes)
*/
long size();
Returns: true
if the size of the upload can be retrieved via size()
.
/**
* @return {@code true} if the size of the upload can be retrieved via {@link #size()}.
*/
boolean isSizeAvailable();
Returns: the async uploaded file when streamToFileSystem
has been used
/**
* @return the async uploaded file when {@link #streamToFileSystem} has been used
*/
AsyncFile file();
}