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

io.vertx.ext.web.codec.BodyCodec Maven / Gradle / Ivy

The newest version!
/*
 * Copyright (c) 2011-2013 The original author or authors
 * ------------------------------------------------------
 * All rights reserved. This program and the accompanying materials
 * are made available under the terms of the Eclipse Public License v1.0
 * and Apache License v2.0 which accompanies this distribution.
 *
 *     The Eclipse Public License is available at
 *     http://www.eclipse.org/legal/epl-v10.html
 *
 *     The Apache License v2.0 is available at
 *     http://www.opensource.org/licenses/apache2.0.php
 *
 * You may elect to redistribute this code under either of these licenses.
 */
package io.vertx.ext.web.codec;

import io.vertx.codegen.annotations.GenIgnore;
import io.vertx.codegen.annotations.VertxGen;
import io.vertx.core.AsyncResult;
import io.vertx.core.Handler;
import io.vertx.core.buffer.Buffer;
import io.vertx.core.json.JsonArray;
import io.vertx.core.json.JsonObject;
import io.vertx.core.parsetools.JsonParser;
import io.vertx.core.streams.WriteStream;
import io.vertx.ext.web.codec.impl.BodyCodecImpl;
import io.vertx.ext.web.codec.impl.JsonStreamBodyCodec;
import io.vertx.ext.web.codec.impl.StreamingBodyCodec;
import io.vertx.ext.web.codec.spi.BodyStream;

import java.util.function.Function;

/**
 * A codec for encoding and decoding HTTP bodies.
 *
 * @author Julien Viet
 */
@VertxGen
public interface BodyCodec {

  /**
   * @return the UTF-8 string codec
   */
  static BodyCodec string() {
    return BodyCodecImpl.STRING;
  }

  /**
   * A codec for strings using a specific {@code encoding}.
   *
   * @param encoding the encoding
   * @return the codec
   */
  static BodyCodec string(String encoding) {
    return BodyCodecImpl.string(encoding);
  }

  /**
   * @return the {@link Buffer} codec
   */
  static BodyCodec buffer() {
    return BodyCodecImpl.BUFFER;
  }

  /**
   * @return the {@link JsonObject} codec
   */
  static BodyCodec jsonObject() {
    return BodyCodecImpl.JSON_OBJECT;
  }

  /**
   * @return the {@link JsonArray} codec
   */
  static BodyCodec jsonArray() {
    return BodyCodecImpl.JSON_ARRAY;
  }

  /**
   * Create and return a codec for Java objects encoded using Jackson mapper.
   *
   * @return a codec for mapping POJO to Json
   */
  static  BodyCodec json(Class type) {
    return BodyCodecImpl.json(type);
  }

  /**
   * @return a codec that simply discards the response
   */
  static BodyCodec none() {
    return BodyCodecImpl.NONE;
  }

  /**
   * Create a codec that buffers the entire body and then apply the {@code decode} function and returns the result.
   *
   * @param decode the decode function
   * @return the created codec
   */
  static  BodyCodec create(Function decode) {
    return new BodyCodecImpl<>(decode);
  }

  /**
   * A body codec that pipes the body to a write stream.
   * 

* Same as pipe(stream, true). * * @param stream the destination stream * @return the body codec for a write stream */ static BodyCodec pipe(WriteStream stream) { return pipe(stream, true); } /** * A body codec that pipes the body to a write stream. * * @param stream the destination stream * @param close whether the destination stream should be closed * @return the body codec for a write stream */ static BodyCodec pipe(WriteStream stream, boolean close) { StreamingBodyCodec bodyCodec = new StreamingBodyCodec(stream, close); bodyCodec.init(); return bodyCodec; } /** * A body codec that parse the response as a JSON stream. * * @param parser the non-null JSON parser to emits the JSON object. The parser must be configured for the stream. Not * e that you need to keep a reference on the parser to retrieved the JSON events. * @return the body codec for a write stream */ static BodyCodec jsonStream(JsonParser parser) { return new JsonStreamBodyCodec(parser); } /** * Create the {@link BodyStream}. *

* This method is usually called for creating the pump for the HTTP response and should not be called directly. */ @GenIgnore void create(Handler>> handler); }





© 2015 - 2025 Weber Informatics LLC | Privacy Policy