/*
 * 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(); }