All Downloads are FREE. Search and download functionalities are using the official Maven repository.

io.vertx.core.http.HttpServerFileUpload Maven / Gradle / Ivy

/*
 * Copyright (c) 2011-2019 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.AsyncResult;
import io.vertx.core.Future;
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
 */
@VertxGen
public interface HttpServerFileUpload extends ReadStream {

  @Override
  HttpServerFileUpload exceptionHandler(Handler handler);

  @Override
  HttpServerFileUpload handler(Handler handler);

  @Override
  HttpServerFileUpload endHandler(Handler endHandler);

  @Override
  HttpServerFileUpload pause();

  @Override
  HttpServerFileUpload resume();

  @Override
  HttpServerFileUpload fetch(long amount);

  /**
   * Stream the content of this upload to the given file on storage.
   *
   * 

If the stream has a failure or is cancelled the created file will be deleted. * * @param filename the name of the file */ Future streamToFileSystem(String filename); /** * Try to cancel the file system streaming, the streamed file will be deleted. * * * @return {@code true} when the stream is cancelled, otherwise it means that stream is finished * @throws IllegalStateException when no stream is in progress */ boolean cancelStreamToFileSystem() throws IllegalStateException; /** * @return the filename which was used when upload the file. */ String filename(); /** * @return the name of the attribute */ String name(); /** * @return the content type for the upload */ String contentType(); /** * @return the contentTransferEncoding for the upload */ String contentTransferEncoding(); /** * @return the charset for the upload */ String charset(); /** * 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(); /** * @return {@code true} if the size of the upload can be retrieved via {@link #size()}. */ boolean isSizeAvailable(); /** * @return the async uploaded file when {@link #streamToFileSystem} has been used and the file is available */ AsyncFile file(); }





© 2015 - 2025 Weber Informatics LLC | Privacy Policy