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

io.vertx.ext.mail.MailAttachment Maven / Gradle / Ivy

There is a newer version: 5.0.0.CR3
Show newest version
/*
 *  Copyright (c) 2011-2015 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.mail;

import io.vertx.codegen.annotations.DataObject;
import io.vertx.codegen.annotations.GenIgnore;
import io.vertx.core.MultiMap;
import io.vertx.core.buffer.Buffer;
import io.vertx.core.http.CaseInsensitiveHeaders;
import io.vertx.core.json.JsonObject;

import java.util.Arrays;
import java.util.List;
import java.util.Objects;

/**
 * Represent a mail attachment that can be used in a MailMessage.
 *
 * @author Alexander Lehmann
 */

@DataObject
public class MailAttachment {

  private Buffer data;
  private String name;
  private String contentType;
  private String disposition;
  private String description;
  private String contentId;
  private MultiMap headers;

  /**
   * construct an empty MailAttachment object that can be filled with the
   * setters
   */
  public MailAttachment() {
  }

  /**
   * create a copy of a MailAttachment object
   *
   * @param other object to be copied
   */
  public MailAttachment(final MailAttachment other) {
    Objects.requireNonNull(other);
    this.data = other.data == null ? null : other.data.copy();
    this.name = other.name;
    this.contentType = other.contentType;
    this.disposition = other.disposition;
    this.description = other.description;
    this.description = other.description;
    this.contentId = other.contentId;
    this.headers = other.headers == null ? null : new CaseInsensitiveHeaders().addAll(other.headers);
  }

  /**
   * create a MailAttachment object from a JsonObject representation
   *
   * @param json object to be copied
   */
  public MailAttachment(final JsonObject json) {
    Objects.requireNonNull(json);
    this.data = json.getBinary("data") == null ? null : Buffer.buffer(json.getBinary("data"));
    this.name = json.getString("name");
    this.contentType = json.getString("contentType");
    this.disposition = json.getString("disposition");
    this.description = json.getString("description");
    this.contentId = json.getString("contentId");
    JsonObject headers = json.getJsonObject("headers");
    if (headers != null) {
      this.headers = Utils.jsonToMultiMap(headers);
    }
  }

  /**
   * get the data
   *
   * @return the data
   */
  public Buffer getData() {
    return data;
  }

  /**
   * set the data
   *
   * @param data Buffer of bytes to be used at attachment
   * @return this to be able to use it fluently
   */
  public MailAttachment setData(final Buffer data) {
    this.data = data;
    return this;
  }

  /**
   * get the name
   *
   * @return the name
   */
  public String getName() {
    return name;
  }

  /**
   * set the name
   * @param name name of the attachment file
   * @return this to be able to use it fluently
   * 

* name is the descriptive filename that will be put into the mail * i.e. usually a local filename without path * this can be set to "" to omit the filename attribute */ public MailAttachment setName(final String name) { this.name = name; return this; } /** * get the Content-Type * * @return the contentType */ public String getContentType() { return contentType; } /** * set the Content-Type * * @param contentType the contentType * @return this to be able to use it fluently */ public MailAttachment setContentType(final String contentType) { this.contentType = contentType; return this; } /** * get the disposition field * * @return the disposition */ public String getDisposition() { return disposition; } /** * set the disposition field to be used in the attachment * * @param disposition the disposition * @return this to be able to use it fluently */ public MailAttachment setDisposition(final String disposition) { this.disposition = disposition; return this; } /** * get the description field * * @return the description */ public String getDescription() { return description; } /** * set the description field to be used in the attachment * * @param description the description * @return this to be able to use it fluently */ public MailAttachment setDescription(final String description) { this.description = description; return this; } /** * get the Content-ID field * * @return the content id */ public String getContentId() { return contentId; } /** * set the Content-ID field to be used in the attachment * * @param contentId the content id * @return this to be able to use it fluently */ public MailAttachment setContentId(final String contentId) { this.contentId = contentId; return this; } /** * Add an header to this attachment. * * @param key the header key * @param value the header value * @return a reference to this, so the API can be used fluently */ public MailAttachment addHeader(String key, String value) { if (headers == null) { headers = new CaseInsensitiveHeaders(); } Objects.requireNonNull(key, "no null key accepted"); Objects.requireNonNull(value, "no null value accepted"); headers.add(key, value); return this; } /** * Get the headers to be added for this attachment. * * @return the headers */ @GenIgnore public MultiMap getHeaders() { return headers; } /** * Set the headers to be added for this attachment. * * @param headers the headers to be added * @return this to be able to use it fluently */ @GenIgnore public MailAttachment setHeaders(final MultiMap headers) { this.headers = headers; return this; } /** * convert this object to JSON representation * * @return the JSON object */ public JsonObject toJson() { JsonObject json = new JsonObject(); if (data != null) { json.put("data", data.getBytes()); } Utils.putIfNotNull(json, "name", name); Utils.putIfNotNull(json, "contentType", contentType); Utils.putIfNotNull(json, "disposition", disposition); Utils.putIfNotNull(json, "description", description); Utils.putIfNotNull(json, "contentId", contentId); if (headers != null) { json.put("headers", Utils.multiMapToJson(headers)); } return json; } private List getList() { return Arrays.asList(data, name, disposition, description, contentId, headers); } @Override public boolean equals(final Object o) { if (this == o) { return true; } if (o == null || !(o instanceof MailAttachment)) { return false; } final MailAttachment attachment = (MailAttachment) o; return getList().equals(attachment.getList()); } @Override public int hashCode() { return getList().hashCode(); } }