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

com.hellosign.openapi.model.SignatureRequestSendRequest Maven / Gradle / Ivy

Go to download

Use the HelloSign Java SDK to connect your Java app to HelloSign's service in microseconds!

The newest version!
/*
 * HelloSign API
 * HelloSign v3 API
 *
 * The version of the OpenAPI document: 3.0.0
 * Contact: [email protected]
 *
 * NOTE: This class is auto generated by OpenAPI Generator (https://openapi-generator.tech).
 * https://openapi-generator.tech
 * Do not edit the class manually.
 */


package com.hellosign.openapi.model;

import java.util.Objects;
import java.util.Arrays;
import java.util.Map;
import java.util.HashMap;
import com.fasterxml.jackson.annotation.JsonInclude;
import com.fasterxml.jackson.annotation.JsonProperty;
import com.fasterxml.jackson.annotation.JsonCreator;
import com.fasterxml.jackson.annotation.JsonTypeName;
import com.fasterxml.jackson.annotation.JsonValue;
import com.hellosign.openapi.model.SubAttachment;
import com.hellosign.openapi.model.SubCustomField;
import com.hellosign.openapi.model.SubFieldOptions;
import com.hellosign.openapi.model.SubFormFieldGroup;
import com.hellosign.openapi.model.SubFormFieldRule;
import com.hellosign.openapi.model.SubFormFieldsPerDocumentBase;
import com.hellosign.openapi.model.SubSignatureRequestSigner;
import com.hellosign.openapi.model.SubSigningOptions;
import io.swagger.annotations.ApiModel;
import io.swagger.annotations.ApiModelProperty;
import java.io.File;
import java.util.ArrayList;
import java.util.HashMap;
import java.util.List;
import java.util.Map;
import com.fasterxml.jackson.annotation.JsonPropertyOrder;
import com.hellosign.openapi.JSON;


import com.hellosign.openapi.ApiException;
/**
 * SignatureRequestSendRequest
 */
@JsonPropertyOrder({
    SignatureRequestSendRequest.JSON_PROPERTY_SIGNERS,
    SignatureRequestSendRequest.JSON_PROPERTY_FILE,
    SignatureRequestSendRequest.JSON_PROPERTY_FILE_URL,
    SignatureRequestSendRequest.JSON_PROPERTY_ALLOW_DECLINE,
    SignatureRequestSendRequest.JSON_PROPERTY_ALLOW_REASSIGN,
    SignatureRequestSendRequest.JSON_PROPERTY_ATTACHMENTS,
    SignatureRequestSendRequest.JSON_PROPERTY_CC_EMAIL_ADDRESSES,
    SignatureRequestSendRequest.JSON_PROPERTY_CLIENT_ID,
    SignatureRequestSendRequest.JSON_PROPERTY_CUSTOM_FIELDS,
    SignatureRequestSendRequest.JSON_PROPERTY_FIELD_OPTIONS,
    SignatureRequestSendRequest.JSON_PROPERTY_FORM_FIELD_GROUPS,
    SignatureRequestSendRequest.JSON_PROPERTY_FORM_FIELD_RULES,
    SignatureRequestSendRequest.JSON_PROPERTY_FORM_FIELDS_PER_DOCUMENT,
    SignatureRequestSendRequest.JSON_PROPERTY_HIDE_TEXT_TAGS,
    SignatureRequestSendRequest.JSON_PROPERTY_IS_QUALIFIED_SIGNATURE,
    SignatureRequestSendRequest.JSON_PROPERTY_MESSAGE,
    SignatureRequestSendRequest.JSON_PROPERTY_METADATA,
    SignatureRequestSendRequest.JSON_PROPERTY_SIGNING_OPTIONS,
    SignatureRequestSendRequest.JSON_PROPERTY_SIGNING_REDIRECT_URL,
    SignatureRequestSendRequest.JSON_PROPERTY_SUBJECT,
    SignatureRequestSendRequest.JSON_PROPERTY_TEST_MODE,
    SignatureRequestSendRequest.JSON_PROPERTY_TITLE,
    SignatureRequestSendRequest.JSON_PROPERTY_USE_TEXT_TAGS
})
@javax.annotation.Generated(value = "org.openapitools.codegen.languages.JavaClientCodegen")
public class SignatureRequestSendRequest {
  public static final String JSON_PROPERTY_SIGNERS = "signers";
  private List signers = new ArrayList<>();

  public static final String JSON_PROPERTY_FILE = "file";
  private List file = null;

  public static final String JSON_PROPERTY_FILE_URL = "file_url";
  private List fileUrl = null;

  public static final String JSON_PROPERTY_ALLOW_DECLINE = "allow_decline";
  private Boolean allowDecline = false;

  public static final String JSON_PROPERTY_ALLOW_REASSIGN = "allow_reassign";
  private Boolean allowReassign = false;

  public static final String JSON_PROPERTY_ATTACHMENTS = "attachments";
  private List attachments = null;

  public static final String JSON_PROPERTY_CC_EMAIL_ADDRESSES = "cc_email_addresses";
  private List ccEmailAddresses = null;

  public static final String JSON_PROPERTY_CLIENT_ID = "client_id";
  private String clientId;

  public static final String JSON_PROPERTY_CUSTOM_FIELDS = "custom_fields";
  private List customFields = null;

  public static final String JSON_PROPERTY_FIELD_OPTIONS = "field_options";
  private SubFieldOptions fieldOptions;

  public static final String JSON_PROPERTY_FORM_FIELD_GROUPS = "form_field_groups";
  private List formFieldGroups = null;

  public static final String JSON_PROPERTY_FORM_FIELD_RULES = "form_field_rules";
  private List formFieldRules = null;

  public static final String JSON_PROPERTY_FORM_FIELDS_PER_DOCUMENT = "form_fields_per_document";
  private List formFieldsPerDocument = null;

  public static final String JSON_PROPERTY_HIDE_TEXT_TAGS = "hide_text_tags";
  private Boolean hideTextTags = false;

  public static final String JSON_PROPERTY_IS_QUALIFIED_SIGNATURE = "is_qualified_signature";
  private Boolean isQualifiedSignature = false;

  public static final String JSON_PROPERTY_MESSAGE = "message";
  private String message;

  public static final String JSON_PROPERTY_METADATA = "metadata";
  private Map metadata = null;

  public static final String JSON_PROPERTY_SIGNING_OPTIONS = "signing_options";
  private SubSigningOptions signingOptions;

  public static final String JSON_PROPERTY_SIGNING_REDIRECT_URL = "signing_redirect_url";
  private String signingRedirectUrl;

  public static final String JSON_PROPERTY_SUBJECT = "subject";
  private String subject;

  public static final String JSON_PROPERTY_TEST_MODE = "test_mode";
  private Boolean testMode = false;

  public static final String JSON_PROPERTY_TITLE = "title";
  private String title;

  public static final String JSON_PROPERTY_USE_TEXT_TAGS = "use_text_tags";
  private Boolean useTextTags = false;

  public SignatureRequestSendRequest() { 
  }

  public SignatureRequestSendRequest signers(List signers) {
    this.signers = signers;
    return this;
  }

  public SignatureRequestSendRequest addSignersItem(SubSignatureRequestSigner signersItem) {
    this.signers.add(signersItem);
    return this;
  }

   /**
   * Add Signers to your Signature Request.
   * @return signers
  **/
  @javax.annotation.Nonnull
  @ApiModelProperty(required = true, value = "Add Signers to your Signature Request.")
  @JsonProperty(JSON_PROPERTY_SIGNERS)
  @JsonInclude(value = JsonInclude.Include.ALWAYS)

  public List getSigners() {
    return signers;
  }


  @JsonProperty(JSON_PROPERTY_SIGNERS)
  @JsonInclude(value = JsonInclude.Include.ALWAYS)
  public void setSigners(List signers) {
    this.signers = signers;
  }


  public SignatureRequestSendRequest file(List file) {
    this.file = file;
    return this;
  }

  public SignatureRequestSendRequest addFileItem(File fileItem) {
    if (this.file == null) {
      this.file = new ArrayList<>();
    }
    this.file.add(fileItem);
    return this;
  }

   /**
   * Use `file[]` to indicate the uploaded file(s) to send for signature.  This endpoint requires either **file** or **file_url[]**, but not both.
   * @return file
  **/
  @javax.annotation.Nullable
  @ApiModelProperty(value = "Use `file[]` to indicate the uploaded file(s) to send for signature.  This endpoint requires either **file** or **file_url[]**, but not both.")
  @JsonProperty(JSON_PROPERTY_FILE)
  @JsonInclude(value = JsonInclude.Include.USE_DEFAULTS)

  public List getFile() {
    return file;
  }


  @JsonProperty(JSON_PROPERTY_FILE)
  @JsonInclude(value = JsonInclude.Include.USE_DEFAULTS)
  public void setFile(List file) {
    this.file = file;
  }


  public SignatureRequestSendRequest fileUrl(List fileUrl) {
    this.fileUrl = fileUrl;
    return this;
  }

  public SignatureRequestSendRequest addFileUrlItem(String fileUrlItem) {
    if (this.fileUrl == null) {
      this.fileUrl = new ArrayList<>();
    }
    this.fileUrl.add(fileUrlItem);
    return this;
  }

   /**
   * Use `file_url[]` to have HelloSign download the file(s) to send for signature.  This endpoint requires either **file** or **file_url[]**, but not both.
   * @return fileUrl
  **/
  @javax.annotation.Nullable
  @ApiModelProperty(value = "Use `file_url[]` to have HelloSign download the file(s) to send for signature.  This endpoint requires either **file** or **file_url[]**, but not both.")
  @JsonProperty(JSON_PROPERTY_FILE_URL)
  @JsonInclude(value = JsonInclude.Include.USE_DEFAULTS)

  public List getFileUrl() {
    return fileUrl;
  }


  @JsonProperty(JSON_PROPERTY_FILE_URL)
  @JsonInclude(value = JsonInclude.Include.USE_DEFAULTS)
  public void setFileUrl(List fileUrl) {
    this.fileUrl = fileUrl;
  }


  public SignatureRequestSendRequest allowDecline(Boolean allowDecline) {
    this.allowDecline = allowDecline;
    return this;
  }

   /**
   * Allows signers to decline to sign a document if `true`. Defaults to `false`.
   * @return allowDecline
  **/
  @javax.annotation.Nullable
  @ApiModelProperty(value = "Allows signers to decline to sign a document if `true`. Defaults to `false`.")
  @JsonProperty(JSON_PROPERTY_ALLOW_DECLINE)
  @JsonInclude(value = JsonInclude.Include.USE_DEFAULTS)

  public Boolean getAllowDecline() {
    return allowDecline;
  }


  @JsonProperty(JSON_PROPERTY_ALLOW_DECLINE)
  @JsonInclude(value = JsonInclude.Include.USE_DEFAULTS)
  public void setAllowDecline(Boolean allowDecline) {
    this.allowDecline = allowDecline;
  }


  public SignatureRequestSendRequest allowReassign(Boolean allowReassign) {
    this.allowReassign = allowReassign;
    return this;
  }

   /**
   * Allows signers to reassign their signature requests to other signers if set to `true`. Defaults to `false`.  **Note**: Only available for Premium plan and higher.
   * @return allowReassign
  **/
  @javax.annotation.Nullable
  @ApiModelProperty(value = "Allows signers to reassign their signature requests to other signers if set to `true`. Defaults to `false`.  **Note**: Only available for Premium plan and higher.")
  @JsonProperty(JSON_PROPERTY_ALLOW_REASSIGN)
  @JsonInclude(value = JsonInclude.Include.USE_DEFAULTS)

  public Boolean getAllowReassign() {
    return allowReassign;
  }


  @JsonProperty(JSON_PROPERTY_ALLOW_REASSIGN)
  @JsonInclude(value = JsonInclude.Include.USE_DEFAULTS)
  public void setAllowReassign(Boolean allowReassign) {
    this.allowReassign = allowReassign;
  }


  public SignatureRequestSendRequest attachments(List attachments) {
    this.attachments = attachments;
    return this;
  }

  public SignatureRequestSendRequest addAttachmentsItem(SubAttachment attachmentsItem) {
    if (this.attachments == null) {
      this.attachments = new ArrayList<>();
    }
    this.attachments.add(attachmentsItem);
    return this;
  }

   /**
   * A list describing the attachments
   * @return attachments
  **/
  @javax.annotation.Nullable
  @ApiModelProperty(value = "A list describing the attachments")
  @JsonProperty(JSON_PROPERTY_ATTACHMENTS)
  @JsonInclude(value = JsonInclude.Include.USE_DEFAULTS)

  public List getAttachments() {
    return attachments;
  }


  @JsonProperty(JSON_PROPERTY_ATTACHMENTS)
  @JsonInclude(value = JsonInclude.Include.USE_DEFAULTS)
  public void setAttachments(List attachments) {
    this.attachments = attachments;
  }


  public SignatureRequestSendRequest ccEmailAddresses(List ccEmailAddresses) {
    this.ccEmailAddresses = ccEmailAddresses;
    return this;
  }

  public SignatureRequestSendRequest addCcEmailAddressesItem(String ccEmailAddressesItem) {
    if (this.ccEmailAddresses == null) {
      this.ccEmailAddresses = new ArrayList<>();
    }
    this.ccEmailAddresses.add(ccEmailAddressesItem);
    return this;
  }

   /**
   * The email addresses that should be CCed.
   * @return ccEmailAddresses
  **/
  @javax.annotation.Nullable
  @ApiModelProperty(value = "The email addresses that should be CCed.")
  @JsonProperty(JSON_PROPERTY_CC_EMAIL_ADDRESSES)
  @JsonInclude(value = JsonInclude.Include.USE_DEFAULTS)

  public List getCcEmailAddresses() {
    return ccEmailAddresses;
  }


  @JsonProperty(JSON_PROPERTY_CC_EMAIL_ADDRESSES)
  @JsonInclude(value = JsonInclude.Include.USE_DEFAULTS)
  public void setCcEmailAddresses(List ccEmailAddresses) {
    this.ccEmailAddresses = ccEmailAddresses;
  }


  public SignatureRequestSendRequest clientId(String clientId) {
    this.clientId = clientId;
    return this;
  }

   /**
   * The client id of the API App you want to associate with this request. Used to apply the branding and callback url defined for the app.
   * @return clientId
  **/
  @javax.annotation.Nullable
  @ApiModelProperty(value = "The client id of the API App you want to associate with this request. Used to apply the branding and callback url defined for the app.")
  @JsonProperty(JSON_PROPERTY_CLIENT_ID)
  @JsonInclude(value = JsonInclude.Include.USE_DEFAULTS)

  public String getClientId() {
    return clientId;
  }


  @JsonProperty(JSON_PROPERTY_CLIENT_ID)
  @JsonInclude(value = JsonInclude.Include.USE_DEFAULTS)
  public void setClientId(String clientId) {
    this.clientId = clientId;
  }


  public SignatureRequestSendRequest customFields(List customFields) {
    this.customFields = customFields;
    return this;
  }

  public SignatureRequestSendRequest addCustomFieldsItem(SubCustomField customFieldsItem) {
    if (this.customFields == null) {
      this.customFields = new ArrayList<>();
    }
    this.customFields.add(customFieldsItem);
    return this;
  }

   /**
   * When used together with merge fields, `custom_fields` allows users to add pre-filled data to their signature requests.  Pre-filled data can be used with \"send-once\" signature requests by adding merge fields with `form_fields_per_document` or [Text Tags](https://app.hellosign.com/api/textTagsWalkthrough#TextTagIntro) while passing values back with `custom_fields` together in one API call.  For using pre-filled on repeatable signature requests, merge fields are added to templates in the HelloSign UI or by calling [/template/create_embedded_draft](/api/reference/operation/templateCreateEmbeddedDraft) and then passing `custom_fields` on subsequent signature requests referencing that template.
   * @return customFields
  **/
  @javax.annotation.Nullable
  @ApiModelProperty(value = "When used together with merge fields, `custom_fields` allows users to add pre-filled data to their signature requests.  Pre-filled data can be used with \"send-once\" signature requests by adding merge fields with `form_fields_per_document` or [Text Tags](https://app.hellosign.com/api/textTagsWalkthrough#TextTagIntro) while passing values back with `custom_fields` together in one API call.  For using pre-filled on repeatable signature requests, merge fields are added to templates in the HelloSign UI or by calling [/template/create_embedded_draft](/api/reference/operation/templateCreateEmbeddedDraft) and then passing `custom_fields` on subsequent signature requests referencing that template.")
  @JsonProperty(JSON_PROPERTY_CUSTOM_FIELDS)
  @JsonInclude(value = JsonInclude.Include.USE_DEFAULTS)

  public List getCustomFields() {
    return customFields;
  }


  @JsonProperty(JSON_PROPERTY_CUSTOM_FIELDS)
  @JsonInclude(value = JsonInclude.Include.USE_DEFAULTS)
  public void setCustomFields(List customFields) {
    this.customFields = customFields;
  }


  public SignatureRequestSendRequest fieldOptions(SubFieldOptions fieldOptions) {
    this.fieldOptions = fieldOptions;
    return this;
  }

   /**
   * Get fieldOptions
   * @return fieldOptions
  **/
  @javax.annotation.Nullable
  @ApiModelProperty(value = "")
  @JsonProperty(JSON_PROPERTY_FIELD_OPTIONS)
  @JsonInclude(value = JsonInclude.Include.USE_DEFAULTS)

  public SubFieldOptions getFieldOptions() {
    return fieldOptions;
  }


  @JsonProperty(JSON_PROPERTY_FIELD_OPTIONS)
  @JsonInclude(value = JsonInclude.Include.USE_DEFAULTS)
  public void setFieldOptions(SubFieldOptions fieldOptions) {
    this.fieldOptions = fieldOptions;
  }


  public SignatureRequestSendRequest formFieldGroups(List formFieldGroups) {
    this.formFieldGroups = formFieldGroups;
    return this;
  }

  public SignatureRequestSendRequest addFormFieldGroupsItem(SubFormFieldGroup formFieldGroupsItem) {
    if (this.formFieldGroups == null) {
      this.formFieldGroups = new ArrayList<>();
    }
    this.formFieldGroups.add(formFieldGroupsItem);
    return this;
  }

   /**
   * Group information for fields defined in `form_fields_per_document`. String-indexed JSON array with `group_label` and `requirement` keys. `form_fields_per_document` must contain fields referencing a group defined in `form_field_groups`.
   * @return formFieldGroups
  **/
  @javax.annotation.Nullable
  @ApiModelProperty(value = "Group information for fields defined in `form_fields_per_document`. String-indexed JSON array with `group_label` and `requirement` keys. `form_fields_per_document` must contain fields referencing a group defined in `form_field_groups`.")
  @JsonProperty(JSON_PROPERTY_FORM_FIELD_GROUPS)
  @JsonInclude(value = JsonInclude.Include.USE_DEFAULTS)

  public List getFormFieldGroups() {
    return formFieldGroups;
  }


  @JsonProperty(JSON_PROPERTY_FORM_FIELD_GROUPS)
  @JsonInclude(value = JsonInclude.Include.USE_DEFAULTS)
  public void setFormFieldGroups(List formFieldGroups) {
    this.formFieldGroups = formFieldGroups;
  }


  public SignatureRequestSendRequest formFieldRules(List formFieldRules) {
    this.formFieldRules = formFieldRules;
    return this;
  }

  public SignatureRequestSendRequest addFormFieldRulesItem(SubFormFieldRule formFieldRulesItem) {
    if (this.formFieldRules == null) {
      this.formFieldRules = new ArrayList<>();
    }
    this.formFieldRules.add(formFieldRulesItem);
    return this;
  }

   /**
   * Conditional Logic rules for fields defined in `form_fields_per_document`.
   * @return formFieldRules
  **/
  @javax.annotation.Nullable
  @ApiModelProperty(value = "Conditional Logic rules for fields defined in `form_fields_per_document`.")
  @JsonProperty(JSON_PROPERTY_FORM_FIELD_RULES)
  @JsonInclude(value = JsonInclude.Include.USE_DEFAULTS)

  public List getFormFieldRules() {
    return formFieldRules;
  }


  @JsonProperty(JSON_PROPERTY_FORM_FIELD_RULES)
  @JsonInclude(value = JsonInclude.Include.USE_DEFAULTS)
  public void setFormFieldRules(List formFieldRules) {
    this.formFieldRules = formFieldRules;
  }


  public SignatureRequestSendRequest formFieldsPerDocument(List formFieldsPerDocument) {
    this.formFieldsPerDocument = formFieldsPerDocument;
    return this;
  }

  public SignatureRequestSendRequest addFormFieldsPerDocumentItem(SubFormFieldsPerDocumentBase formFieldsPerDocumentItem) {
    if (this.formFieldsPerDocument == null) {
      this.formFieldsPerDocument = new ArrayList<>();
    }
    this.formFieldsPerDocument.add(formFieldsPerDocumentItem);
    return this;
  }

   /**
   * The fields that should appear on the document, expressed as an array of objects. (We're currently fixing a bug where this property only accepts a two-dimensional array. You can read about it here: <a href=\"/docs/placing-fields/form-fields-per-document\" target=\"_blank\">Using Form Fields per Document</a>.)  **NOTE**: Fields like **text**, **dropdown**, **checkbox**, **radio**, and **hyperlink** have additional required and optional parameters. Check out the list of [additional parameters](/api/reference/constants/#form-fields-per-document) for these field types.  * Text Field use `SubFormFieldsPerDocumentText` * Dropdown Field use `SubFormFieldsPerDocumentDropdown` * Hyperlink Field use `SubFormFieldsPerDocumentHyperlink` * Checkbox Field use `SubFormFieldsPerDocumentCheckbox` * Radio Field use `SubFormFieldsPerDocumentRadio` * Signature Field use `SubFormFieldsPerDocumentSignature` * Date Signed Field use `SubFormFieldsPerDocumentDateSigned` * Initials Field use `SubFormFieldsPerDocumentInitials` * Text Merge Field use `SubFormFieldsPerDocumentTextMerge` * Checkbox Merge Field use `SubFormFieldsPerDocumentCheckboxMerge`
   * @return formFieldsPerDocument
  **/
  @javax.annotation.Nullable
  @ApiModelProperty(value = "The fields that should appear on the document, expressed as an array of objects. (We're currently fixing a bug where this property only accepts a two-dimensional array. You can read about it here: Using Form Fields per Document.)  **NOTE**: Fields like **text**, **dropdown**, **checkbox**, **radio**, and **hyperlink** have additional required and optional parameters. Check out the list of [additional parameters](/api/reference/constants/#form-fields-per-document) for these field types.  * Text Field use `SubFormFieldsPerDocumentText` * Dropdown Field use `SubFormFieldsPerDocumentDropdown` * Hyperlink Field use `SubFormFieldsPerDocumentHyperlink` * Checkbox Field use `SubFormFieldsPerDocumentCheckbox` * Radio Field use `SubFormFieldsPerDocumentRadio` * Signature Field use `SubFormFieldsPerDocumentSignature` * Date Signed Field use `SubFormFieldsPerDocumentDateSigned` * Initials Field use `SubFormFieldsPerDocumentInitials` * Text Merge Field use `SubFormFieldsPerDocumentTextMerge` * Checkbox Merge Field use `SubFormFieldsPerDocumentCheckboxMerge`")
  @JsonProperty(JSON_PROPERTY_FORM_FIELDS_PER_DOCUMENT)
  @JsonInclude(value = JsonInclude.Include.USE_DEFAULTS)

  public List getFormFieldsPerDocument() {
    return formFieldsPerDocument;
  }


  @JsonProperty(JSON_PROPERTY_FORM_FIELDS_PER_DOCUMENT)
  @JsonInclude(value = JsonInclude.Include.USE_DEFAULTS)
  public void setFormFieldsPerDocument(List formFieldsPerDocument) {
    this.formFieldsPerDocument = formFieldsPerDocument;
  }


  public SignatureRequestSendRequest hideTextTags(Boolean hideTextTags) {
    this.hideTextTags = hideTextTags;
    return this;
  }

   /**
   * Enables automatic Text Tag removal when set to true.  **NOTE**: Removing text tags this way can cause unwanted clipping. We recommend leaving this setting on `false` and instead hiding your text tags using white text or a similar approach. See the [Text Tags Walkthrough](https://app.hellosign.com/api/textTagsWalkthrough#TextTagIntro) for more information.
   * @return hideTextTags
  **/
  @javax.annotation.Nullable
  @ApiModelProperty(value = "Enables automatic Text Tag removal when set to true.  **NOTE**: Removing text tags this way can cause unwanted clipping. We recommend leaving this setting on `false` and instead hiding your text tags using white text or a similar approach. See the [Text Tags Walkthrough](https://app.hellosign.com/api/textTagsWalkthrough#TextTagIntro) for more information.")
  @JsonProperty(JSON_PROPERTY_HIDE_TEXT_TAGS)
  @JsonInclude(value = JsonInclude.Include.USE_DEFAULTS)

  public Boolean getHideTextTags() {
    return hideTextTags;
  }


  @JsonProperty(JSON_PROPERTY_HIDE_TEXT_TAGS)
  @JsonInclude(value = JsonInclude.Include.USE_DEFAULTS)
  public void setHideTextTags(Boolean hideTextTags) {
    this.hideTextTags = hideTextTags;
  }


  public SignatureRequestSendRequest isQualifiedSignature(Boolean isQualifiedSignature) {
    this.isQualifiedSignature = isQualifiedSignature;
    return this;
  }

   /**
   * Send with a value of `true` if you wish to enable [Qualified Electronic Signatures](https://www.hellosign.com/features/qualified-electronic-signatures) (QES), which requires a face-to-face call to verify the signer's identity.<br> **Note**: QES is only available on the Premium API plan as an add-on purchase. Cannot be used in `test_mode`. Only works on requests with one signer.
   * @return isQualifiedSignature
  **/
  @javax.annotation.Nullable
  @ApiModelProperty(value = "Send with a value of `true` if you wish to enable [Qualified Electronic Signatures](https://www.hellosign.com/features/qualified-electronic-signatures) (QES), which requires a face-to-face call to verify the signer's identity.
**Note**: QES is only available on the Premium API plan as an add-on purchase. Cannot be used in `test_mode`. Only works on requests with one signer.") @JsonProperty(JSON_PROPERTY_IS_QUALIFIED_SIGNATURE) @JsonInclude(value = JsonInclude.Include.USE_DEFAULTS) public Boolean getIsQualifiedSignature() { return isQualifiedSignature; } @JsonProperty(JSON_PROPERTY_IS_QUALIFIED_SIGNATURE) @JsonInclude(value = JsonInclude.Include.USE_DEFAULTS) public void setIsQualifiedSignature(Boolean isQualifiedSignature) { this.isQualifiedSignature = isQualifiedSignature; } public SignatureRequestSendRequest message(String message) { this.message = message; return this; } /** * The custom message in the email that will be sent to the signers. * @return message **/ @javax.annotation.Nullable @ApiModelProperty(value = "The custom message in the email that will be sent to the signers.") @JsonProperty(JSON_PROPERTY_MESSAGE) @JsonInclude(value = JsonInclude.Include.USE_DEFAULTS) public String getMessage() { return message; } @JsonProperty(JSON_PROPERTY_MESSAGE) @JsonInclude(value = JsonInclude.Include.USE_DEFAULTS) public void setMessage(String message) { this.message = message; } public SignatureRequestSendRequest metadata(Map metadata) { this.metadata = metadata; return this; } public SignatureRequestSendRequest putMetadataItem(String key, Object metadataItem) { if (this.metadata == null) { this.metadata = new HashMap<>(); } this.metadata.put(key, metadataItem); return this; } /** * Key-value data that should be attached to the signature request. This metadata is included in all API responses and events involving the signature request. For example, use the metadata field to store a signer's order number for look up when receiving events for the signature request. Each request can include up to 10 metadata keys (or 50 nested metadata keys), with key names up to 40 characters long and values up to 1000 characters long. * @return metadata **/ @javax.annotation.Nullable @ApiModelProperty(value = "Key-value data that should be attached to the signature request. This metadata is included in all API responses and events involving the signature request. For example, use the metadata field to store a signer's order number for look up when receiving events for the signature request. Each request can include up to 10 metadata keys (or 50 nested metadata keys), with key names up to 40 characters long and values up to 1000 characters long.") @JsonProperty(JSON_PROPERTY_METADATA) @JsonInclude(content = JsonInclude.Include.ALWAYS, value = JsonInclude.Include.USE_DEFAULTS) public Map getMetadata() { return metadata; } @JsonProperty(JSON_PROPERTY_METADATA) @JsonInclude(content = JsonInclude.Include.ALWAYS, value = JsonInclude.Include.USE_DEFAULTS) public void setMetadata(Map metadata) { this.metadata = metadata; } public SignatureRequestSendRequest signingOptions(SubSigningOptions signingOptions) { this.signingOptions = signingOptions; return this; } /** * Get signingOptions * @return signingOptions **/ @javax.annotation.Nullable @ApiModelProperty(value = "") @JsonProperty(JSON_PROPERTY_SIGNING_OPTIONS) @JsonInclude(value = JsonInclude.Include.USE_DEFAULTS) public SubSigningOptions getSigningOptions() { return signingOptions; } @JsonProperty(JSON_PROPERTY_SIGNING_OPTIONS) @JsonInclude(value = JsonInclude.Include.USE_DEFAULTS) public void setSigningOptions(SubSigningOptions signingOptions) { this.signingOptions = signingOptions; } public SignatureRequestSendRequest signingRedirectUrl(String signingRedirectUrl) { this.signingRedirectUrl = signingRedirectUrl; return this; } /** * The URL you want signers redirected to after they successfully sign. * @return signingRedirectUrl **/ @javax.annotation.Nullable @ApiModelProperty(value = "The URL you want signers redirected to after they successfully sign.") @JsonProperty(JSON_PROPERTY_SIGNING_REDIRECT_URL) @JsonInclude(value = JsonInclude.Include.USE_DEFAULTS) public String getSigningRedirectUrl() { return signingRedirectUrl; } @JsonProperty(JSON_PROPERTY_SIGNING_REDIRECT_URL) @JsonInclude(value = JsonInclude.Include.USE_DEFAULTS) public void setSigningRedirectUrl(String signingRedirectUrl) { this.signingRedirectUrl = signingRedirectUrl; } public SignatureRequestSendRequest subject(String subject) { this.subject = subject; return this; } /** * The subject in the email that will be sent to the signers. * @return subject **/ @javax.annotation.Nullable @ApiModelProperty(value = "The subject in the email that will be sent to the signers.") @JsonProperty(JSON_PROPERTY_SUBJECT) @JsonInclude(value = JsonInclude.Include.USE_DEFAULTS) public String getSubject() { return subject; } @JsonProperty(JSON_PROPERTY_SUBJECT) @JsonInclude(value = JsonInclude.Include.USE_DEFAULTS) public void setSubject(String subject) { this.subject = subject; } public SignatureRequestSendRequest testMode(Boolean testMode) { this.testMode = testMode; return this; } /** * Whether this is a test, the signature request will not be legally binding if set to `true`. Defaults to `false`. * @return testMode **/ @javax.annotation.Nullable @ApiModelProperty(value = "Whether this is a test, the signature request will not be legally binding if set to `true`. Defaults to `false`.") @JsonProperty(JSON_PROPERTY_TEST_MODE) @JsonInclude(value = JsonInclude.Include.USE_DEFAULTS) public Boolean getTestMode() { return testMode; } @JsonProperty(JSON_PROPERTY_TEST_MODE) @JsonInclude(value = JsonInclude.Include.USE_DEFAULTS) public void setTestMode(Boolean testMode) { this.testMode = testMode; } public SignatureRequestSendRequest title(String title) { this.title = title; return this; } /** * The title you want to assign to the SignatureRequest. * @return title **/ @javax.annotation.Nullable @ApiModelProperty(value = "The title you want to assign to the SignatureRequest.") @JsonProperty(JSON_PROPERTY_TITLE) @JsonInclude(value = JsonInclude.Include.USE_DEFAULTS) public String getTitle() { return title; } @JsonProperty(JSON_PROPERTY_TITLE) @JsonInclude(value = JsonInclude.Include.USE_DEFAULTS) public void setTitle(String title) { this.title = title; } public SignatureRequestSendRequest useTextTags(Boolean useTextTags) { this.useTextTags = useTextTags; return this; } /** * Send with a value of `true` if you wish to enable [Text Tags](https://app.hellosign.com/api/textTagsWalkthrough#TextTagIntro) parsing in your document. Defaults to disabled, or `false`. * @return useTextTags **/ @javax.annotation.Nullable @ApiModelProperty(value = "Send with a value of `true` if you wish to enable [Text Tags](https://app.hellosign.com/api/textTagsWalkthrough#TextTagIntro) parsing in your document. Defaults to disabled, or `false`.") @JsonProperty(JSON_PROPERTY_USE_TEXT_TAGS) @JsonInclude(value = JsonInclude.Include.USE_DEFAULTS) public Boolean getUseTextTags() { return useTextTags; } @JsonProperty(JSON_PROPERTY_USE_TEXT_TAGS) @JsonInclude(value = JsonInclude.Include.USE_DEFAULTS) public void setUseTextTags(Boolean useTextTags) { this.useTextTags = useTextTags; } /** * Return true if this SignatureRequestSendRequest object is equal to o. */ @Override public boolean equals(Object o) { if (this == o) { return true; } if (o == null || getClass() != o.getClass()) { return false; } SignatureRequestSendRequest signatureRequestSendRequest = (SignatureRequestSendRequest) o; return Objects.equals(this.signers, signatureRequestSendRequest.signers) && Objects.equals(this.file, signatureRequestSendRequest.file) && Objects.equals(this.fileUrl, signatureRequestSendRequest.fileUrl) && Objects.equals(this.allowDecline, signatureRequestSendRequest.allowDecline) && Objects.equals(this.allowReassign, signatureRequestSendRequest.allowReassign) && Objects.equals(this.attachments, signatureRequestSendRequest.attachments) && Objects.equals(this.ccEmailAddresses, signatureRequestSendRequest.ccEmailAddresses) && Objects.equals(this.clientId, signatureRequestSendRequest.clientId) && Objects.equals(this.customFields, signatureRequestSendRequest.customFields) && Objects.equals(this.fieldOptions, signatureRequestSendRequest.fieldOptions) && Objects.equals(this.formFieldGroups, signatureRequestSendRequest.formFieldGroups) && Objects.equals(this.formFieldRules, signatureRequestSendRequest.formFieldRules) && Objects.equals(this.formFieldsPerDocument, signatureRequestSendRequest.formFieldsPerDocument) && Objects.equals(this.hideTextTags, signatureRequestSendRequest.hideTextTags) && Objects.equals(this.isQualifiedSignature, signatureRequestSendRequest.isQualifiedSignature) && Objects.equals(this.message, signatureRequestSendRequest.message) && Objects.equals(this.metadata, signatureRequestSendRequest.metadata) && Objects.equals(this.signingOptions, signatureRequestSendRequest.signingOptions) && Objects.equals(this.signingRedirectUrl, signatureRequestSendRequest.signingRedirectUrl) && Objects.equals(this.subject, signatureRequestSendRequest.subject) && Objects.equals(this.testMode, signatureRequestSendRequest.testMode) && Objects.equals(this.title, signatureRequestSendRequest.title) && Objects.equals(this.useTextTags, signatureRequestSendRequest.useTextTags); } @Override public int hashCode() { return Objects.hash(signers, file, fileUrl, allowDecline, allowReassign, attachments, ccEmailAddresses, clientId, customFields, fieldOptions, formFieldGroups, formFieldRules, formFieldsPerDocument, hideTextTags, isQualifiedSignature, message, metadata, signingOptions, signingRedirectUrl, subject, testMode, title, useTextTags); } @Override public String toString() { StringBuilder sb = new StringBuilder(); sb.append("class SignatureRequestSendRequest {\n"); sb.append(" signers: ").append(toIndentedString(signers)).append("\n"); sb.append(" file: ").append(toIndentedString(file)).append("\n"); sb.append(" fileUrl: ").append(toIndentedString(fileUrl)).append("\n"); sb.append(" allowDecline: ").append(toIndentedString(allowDecline)).append("\n"); sb.append(" allowReassign: ").append(toIndentedString(allowReassign)).append("\n"); sb.append(" attachments: ").append(toIndentedString(attachments)).append("\n"); sb.append(" ccEmailAddresses: ").append(toIndentedString(ccEmailAddresses)).append("\n"); sb.append(" clientId: ").append(toIndentedString(clientId)).append("\n"); sb.append(" customFields: ").append(toIndentedString(customFields)).append("\n"); sb.append(" fieldOptions: ").append(toIndentedString(fieldOptions)).append("\n"); sb.append(" formFieldGroups: ").append(toIndentedString(formFieldGroups)).append("\n"); sb.append(" formFieldRules: ").append(toIndentedString(formFieldRules)).append("\n"); sb.append(" formFieldsPerDocument: ").append(toIndentedString(formFieldsPerDocument)).append("\n"); sb.append(" hideTextTags: ").append(toIndentedString(hideTextTags)).append("\n"); sb.append(" isQualifiedSignature: ").append(toIndentedString(isQualifiedSignature)).append("\n"); sb.append(" message: ").append(toIndentedString(message)).append("\n"); sb.append(" metadata: ").append(toIndentedString(metadata)).append("\n"); sb.append(" signingOptions: ").append(toIndentedString(signingOptions)).append("\n"); sb.append(" signingRedirectUrl: ").append(toIndentedString(signingRedirectUrl)).append("\n"); sb.append(" subject: ").append(toIndentedString(subject)).append("\n"); sb.append(" testMode: ").append(toIndentedString(testMode)).append("\n"); sb.append(" title: ").append(toIndentedString(title)).append("\n"); sb.append(" useTextTags: ").append(toIndentedString(useTextTags)).append("\n"); sb.append("}"); return sb.toString(); } public Map createFormData() throws ApiException { Map map = new HashMap<>(); boolean fileTypeFound = false; try { if (signers != null) { if (isFileTypeOrListOfFiles(signers)) { fileTypeFound = true; } if (signers.getClass().equals(java.io.File.class) || signers.getClass().equals(Integer.class) || signers.getClass().equals(String.class) ) { map.put("signers", signers); } else if (isListOfFile(signers)) { for(int i = 0; i< getListSize(signers); i++) { map.put("signers[" + i + "]", getFromList(signers, i)); } } else { map.put("signers", JSON.getDefault().getMapper().writeValueAsString(signers)); } } if (file != null) { if (isFileTypeOrListOfFiles(file)) { fileTypeFound = true; } if (file.getClass().equals(java.io.File.class) || file.getClass().equals(Integer.class) || file.getClass().equals(String.class) ) { map.put("file", file); } else if (isListOfFile(file)) { for(int i = 0; i< getListSize(file); i++) { map.put("file[" + i + "]", getFromList(file, i)); } } else { map.put("file", JSON.getDefault().getMapper().writeValueAsString(file)); } } if (fileUrl != null) { if (isFileTypeOrListOfFiles(fileUrl)) { fileTypeFound = true; } if (fileUrl.getClass().equals(java.io.File.class) || fileUrl.getClass().equals(Integer.class) || fileUrl.getClass().equals(String.class) ) { map.put("file_url", fileUrl); } else if (isListOfFile(fileUrl)) { for(int i = 0; i< getListSize(fileUrl); i++) { map.put("file_url[" + i + "]", getFromList(fileUrl, i)); } } else { map.put("file_url", JSON.getDefault().getMapper().writeValueAsString(fileUrl)); } } if (allowDecline != null) { if (isFileTypeOrListOfFiles(allowDecline)) { fileTypeFound = true; } if (allowDecline.getClass().equals(java.io.File.class) || allowDecline.getClass().equals(Integer.class) || allowDecline.getClass().equals(String.class) ) { map.put("allow_decline", allowDecline); } else if (isListOfFile(allowDecline)) { for(int i = 0; i< getListSize(allowDecline); i++) { map.put("allow_decline[" + i + "]", getFromList(allowDecline, i)); } } else { map.put("allow_decline", JSON.getDefault().getMapper().writeValueAsString(allowDecline)); } } if (allowReassign != null) { if (isFileTypeOrListOfFiles(allowReassign)) { fileTypeFound = true; } if (allowReassign.getClass().equals(java.io.File.class) || allowReassign.getClass().equals(Integer.class) || allowReassign.getClass().equals(String.class) ) { map.put("allow_reassign", allowReassign); } else if (isListOfFile(allowReassign)) { for(int i = 0; i< getListSize(allowReassign); i++) { map.put("allow_reassign[" + i + "]", getFromList(allowReassign, i)); } } else { map.put("allow_reassign", JSON.getDefault().getMapper().writeValueAsString(allowReassign)); } } if (attachments != null) { if (isFileTypeOrListOfFiles(attachments)) { fileTypeFound = true; } if (attachments.getClass().equals(java.io.File.class) || attachments.getClass().equals(Integer.class) || attachments.getClass().equals(String.class) ) { map.put("attachments", attachments); } else if (isListOfFile(attachments)) { for(int i = 0; i< getListSize(attachments); i++) { map.put("attachments[" + i + "]", getFromList(attachments, i)); } } else { map.put("attachments", JSON.getDefault().getMapper().writeValueAsString(attachments)); } } if (ccEmailAddresses != null) { if (isFileTypeOrListOfFiles(ccEmailAddresses)) { fileTypeFound = true; } if (ccEmailAddresses.getClass().equals(java.io.File.class) || ccEmailAddresses.getClass().equals(Integer.class) || ccEmailAddresses.getClass().equals(String.class) ) { map.put("cc_email_addresses", ccEmailAddresses); } else if (isListOfFile(ccEmailAddresses)) { for(int i = 0; i< getListSize(ccEmailAddresses); i++) { map.put("cc_email_addresses[" + i + "]", getFromList(ccEmailAddresses, i)); } } else { map.put("cc_email_addresses", JSON.getDefault().getMapper().writeValueAsString(ccEmailAddresses)); } } if (clientId != null) { if (isFileTypeOrListOfFiles(clientId)) { fileTypeFound = true; } if (clientId.getClass().equals(java.io.File.class) || clientId.getClass().equals(Integer.class) || clientId.getClass().equals(String.class) ) { map.put("client_id", clientId); } else if (isListOfFile(clientId)) { for(int i = 0; i< getListSize(clientId); i++) { map.put("client_id[" + i + "]", getFromList(clientId, i)); } } else { map.put("client_id", JSON.getDefault().getMapper().writeValueAsString(clientId)); } } if (customFields != null) { if (isFileTypeOrListOfFiles(customFields)) { fileTypeFound = true; } if (customFields.getClass().equals(java.io.File.class) || customFields.getClass().equals(Integer.class) || customFields.getClass().equals(String.class) ) { map.put("custom_fields", customFields); } else if (isListOfFile(customFields)) { for(int i = 0; i< getListSize(customFields); i++) { map.put("custom_fields[" + i + "]", getFromList(customFields, i)); } } else { map.put("custom_fields", JSON.getDefault().getMapper().writeValueAsString(customFields)); } } if (fieldOptions != null) { if (isFileTypeOrListOfFiles(fieldOptions)) { fileTypeFound = true; } if (fieldOptions.getClass().equals(java.io.File.class) || fieldOptions.getClass().equals(Integer.class) || fieldOptions.getClass().equals(String.class) ) { map.put("field_options", fieldOptions); } else if (isListOfFile(fieldOptions)) { for(int i = 0; i< getListSize(fieldOptions); i++) { map.put("field_options[" + i + "]", getFromList(fieldOptions, i)); } } else { map.put("field_options", JSON.getDefault().getMapper().writeValueAsString(fieldOptions)); } } if (formFieldGroups != null) { if (isFileTypeOrListOfFiles(formFieldGroups)) { fileTypeFound = true; } if (formFieldGroups.getClass().equals(java.io.File.class) || formFieldGroups.getClass().equals(Integer.class) || formFieldGroups.getClass().equals(String.class) ) { map.put("form_field_groups", formFieldGroups); } else if (isListOfFile(formFieldGroups)) { for(int i = 0; i< getListSize(formFieldGroups); i++) { map.put("form_field_groups[" + i + "]", getFromList(formFieldGroups, i)); } } else { map.put("form_field_groups", JSON.getDefault().getMapper().writeValueAsString(formFieldGroups)); } } if (formFieldRules != null) { if (isFileTypeOrListOfFiles(formFieldRules)) { fileTypeFound = true; } if (formFieldRules.getClass().equals(java.io.File.class) || formFieldRules.getClass().equals(Integer.class) || formFieldRules.getClass().equals(String.class) ) { map.put("form_field_rules", formFieldRules); } else if (isListOfFile(formFieldRules)) { for(int i = 0; i< getListSize(formFieldRules); i++) { map.put("form_field_rules[" + i + "]", getFromList(formFieldRules, i)); } } else { map.put("form_field_rules", JSON.getDefault().getMapper().writeValueAsString(formFieldRules)); } } if (formFieldsPerDocument != null) { if (isFileTypeOrListOfFiles(formFieldsPerDocument)) { fileTypeFound = true; } if (formFieldsPerDocument.getClass().equals(java.io.File.class) || formFieldsPerDocument.getClass().equals(Integer.class) || formFieldsPerDocument.getClass().equals(String.class) ) { map.put("form_fields_per_document", formFieldsPerDocument); } else if (isListOfFile(formFieldsPerDocument)) { for(int i = 0; i< getListSize(formFieldsPerDocument); i++) { map.put("form_fields_per_document[" + i + "]", getFromList(formFieldsPerDocument, i)); } } else { map.put("form_fields_per_document", JSON.getDefault().getMapper().writeValueAsString(formFieldsPerDocument)); } } if (hideTextTags != null) { if (isFileTypeOrListOfFiles(hideTextTags)) { fileTypeFound = true; } if (hideTextTags.getClass().equals(java.io.File.class) || hideTextTags.getClass().equals(Integer.class) || hideTextTags.getClass().equals(String.class) ) { map.put("hide_text_tags", hideTextTags); } else if (isListOfFile(hideTextTags)) { for(int i = 0; i< getListSize(hideTextTags); i++) { map.put("hide_text_tags[" + i + "]", getFromList(hideTextTags, i)); } } else { map.put("hide_text_tags", JSON.getDefault().getMapper().writeValueAsString(hideTextTags)); } } if (isQualifiedSignature != null) { if (isFileTypeOrListOfFiles(isQualifiedSignature)) { fileTypeFound = true; } if (isQualifiedSignature.getClass().equals(java.io.File.class) || isQualifiedSignature.getClass().equals(Integer.class) || isQualifiedSignature.getClass().equals(String.class) ) { map.put("is_qualified_signature", isQualifiedSignature); } else if (isListOfFile(isQualifiedSignature)) { for(int i = 0; i< getListSize(isQualifiedSignature); i++) { map.put("is_qualified_signature[" + i + "]", getFromList(isQualifiedSignature, i)); } } else { map.put("is_qualified_signature", JSON.getDefault().getMapper().writeValueAsString(isQualifiedSignature)); } } if (message != null) { if (isFileTypeOrListOfFiles(message)) { fileTypeFound = true; } if (message.getClass().equals(java.io.File.class) || message.getClass().equals(Integer.class) || message.getClass().equals(String.class) ) { map.put("message", message); } else if (isListOfFile(message)) { for(int i = 0; i< getListSize(message); i++) { map.put("message[" + i + "]", getFromList(message, i)); } } else { map.put("message", JSON.getDefault().getMapper().writeValueAsString(message)); } } if (metadata != null) { if (isFileTypeOrListOfFiles(metadata)) { fileTypeFound = true; } if (metadata.getClass().equals(java.io.File.class) || metadata.getClass().equals(Integer.class) || metadata.getClass().equals(String.class) ) { map.put("metadata", metadata); } else if (isListOfFile(metadata)) { for(int i = 0; i< getListSize(metadata); i++) { map.put("metadata[" + i + "]", getFromList(metadata, i)); } } else { map.put("metadata", JSON.getDefault().getMapper().writeValueAsString(metadata)); } } if (signingOptions != null) { if (isFileTypeOrListOfFiles(signingOptions)) { fileTypeFound = true; } if (signingOptions.getClass().equals(java.io.File.class) || signingOptions.getClass().equals(Integer.class) || signingOptions.getClass().equals(String.class) ) { map.put("signing_options", signingOptions); } else if (isListOfFile(signingOptions)) { for(int i = 0; i< getListSize(signingOptions); i++) { map.put("signing_options[" + i + "]", getFromList(signingOptions, i)); } } else { map.put("signing_options", JSON.getDefault().getMapper().writeValueAsString(signingOptions)); } } if (signingRedirectUrl != null) { if (isFileTypeOrListOfFiles(signingRedirectUrl)) { fileTypeFound = true; } if (signingRedirectUrl.getClass().equals(java.io.File.class) || signingRedirectUrl.getClass().equals(Integer.class) || signingRedirectUrl.getClass().equals(String.class) ) { map.put("signing_redirect_url", signingRedirectUrl); } else if (isListOfFile(signingRedirectUrl)) { for(int i = 0; i< getListSize(signingRedirectUrl); i++) { map.put("signing_redirect_url[" + i + "]", getFromList(signingRedirectUrl, i)); } } else { map.put("signing_redirect_url", JSON.getDefault().getMapper().writeValueAsString(signingRedirectUrl)); } } if (subject != null) { if (isFileTypeOrListOfFiles(subject)) { fileTypeFound = true; } if (subject.getClass().equals(java.io.File.class) || subject.getClass().equals(Integer.class) || subject.getClass().equals(String.class) ) { map.put("subject", subject); } else if (isListOfFile(subject)) { for(int i = 0; i< getListSize(subject); i++) { map.put("subject[" + i + "]", getFromList(subject, i)); } } else { map.put("subject", JSON.getDefault().getMapper().writeValueAsString(subject)); } } if (testMode != null) { if (isFileTypeOrListOfFiles(testMode)) { fileTypeFound = true; } if (testMode.getClass().equals(java.io.File.class) || testMode.getClass().equals(Integer.class) || testMode.getClass().equals(String.class) ) { map.put("test_mode", testMode); } else if (isListOfFile(testMode)) { for(int i = 0; i< getListSize(testMode); i++) { map.put("test_mode[" + i + "]", getFromList(testMode, i)); } } else { map.put("test_mode", JSON.getDefault().getMapper().writeValueAsString(testMode)); } } if (title != null) { if (isFileTypeOrListOfFiles(title)) { fileTypeFound = true; } if (title.getClass().equals(java.io.File.class) || title.getClass().equals(Integer.class) || title.getClass().equals(String.class) ) { map.put("title", title); } else if (isListOfFile(title)) { for(int i = 0; i< getListSize(title); i++) { map.put("title[" + i + "]", getFromList(title, i)); } } else { map.put("title", JSON.getDefault().getMapper().writeValueAsString(title)); } } if (useTextTags != null) { if (isFileTypeOrListOfFiles(useTextTags)) { fileTypeFound = true; } if (useTextTags.getClass().equals(java.io.File.class) || useTextTags.getClass().equals(Integer.class) || useTextTags.getClass().equals(String.class) ) { map.put("use_text_tags", useTextTags); } else if (isListOfFile(useTextTags)) { for(int i = 0; i< getListSize(useTextTags); i++) { map.put("use_text_tags[" + i + "]", getFromList(useTextTags, i)); } } else { map.put("use_text_tags", JSON.getDefault().getMapper().writeValueAsString(useTextTags)); } } } catch (Exception e) { throw new ApiException(e); } return fileTypeFound ? map : new HashMap<>(); } private boolean isFileTypeOrListOfFiles(Object obj) throws Exception { return obj.getClass().equals(java.io.File.class) || isListOfFile(obj); } private boolean isListOfFile(Object obj) throws Exception { return obj instanceof java.util.List && !isListEmpty(obj) && getFromList(obj, 0) instanceof java.io.File; } private boolean isListEmpty(Object obj) throws Exception { return (boolean) Class.forName(java.util.List.class.getName()).getMethod("isEmpty").invoke(obj); } private Object getFromList(Object obj, int index) throws Exception { return Class.forName(java.util.List.class.getName()).getMethod("get", int.class).invoke(obj, index); } private int getListSize(Object obj) throws Exception { return (int) Class.forName(java.util.List.class.getName()).getMethod("size").invoke(obj); } /** * Convert the given object to string with each line indented by 4 spaces * (except the first line). */ private String toIndentedString(Object o) { if (o == null) { return "null"; } return o.toString().replace("\n", "\n "); } }




© 2015 - 2025 Weber Informatics LLC | Privacy Policy