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

com.messagebird.objects.Message Maven / Gradle / Ivy

package com.messagebird.objects;

import java.io.Serializable;
import java.math.BigInteger;
import java.net.URL;
import java.util.Date;
import java.util.LinkedHashMap;
import java.util.List;
import java.util.Map;

/**
 * Class to hold's a Voice message that can be send
 * 

* Created by rvt on 1/7/15. */ public class Message implements MessageBase, Serializable { private static final long serialVersionUID = -2110297078875657480L; private static final String EMPTY = ""; private String originator; private String body; private String recipients; private MsgType type; private String reference; private Integer validity; private Integer gateway; private Map typeDetails; private DataCodingType datacoding = DataCodingType.plain; private MClassType mclass; private Date scheduledDatetime; /** * Optional URL for the status report. If not set uses URL from account settings. */ private URL reportUrl; public Message(String originator, String body, String recipients) { if (recipients == null || recipients.trim().length() == 0) { throw new IllegalArgumentException("Recipients must be specified"); } if (body == null || body.trim().length() == 0) { throw new IllegalArgumentException("Body must be specified"); } if (originator == null || originator.trim().length() == 0) { throw new IllegalArgumentException("Originator must be specified"); } this.recipients = recipients.trim(); this.originator = originator.trim(); this.originator = this.originator.substring(0, Math.min(17, this.originator.length())); this.body = body.trim(); } public Message(String originator, String body, List recipients) { this(originator, body, receipientsAsCommaSeperated(recipients)); } /** * Factory to create Binary SMS message * * @param originator * @param header * @param body * @param recipients * @return */ static public Message createBinarySMS(String originator, String header, String body, String recipients) { Message msg = new Message(originator, body, recipients); final Map binarySMS = new LinkedHashMap(4); binarySMS.put("udh", header); msg.setTypeDetails(binarySMS); msg.setType(MsgType.binary); return msg; } /** * Factory to create Binary SMS message * * @param originator * @param header * @param body * @param recipients * @return */ static public Message createBinarySMS(String originator, String header, String body, List recipients) { return Message.createBinarySMS(originator, header, body, receipientsAsCommaSeperated(recipients)); } /** * generates a string from List * * @param recipients * @return */ protected static String receipientsAsCommaSeperated(final List recipients) { // Note: I didn't opt for using apache commons to reduce the number of includes // Let me know if you want to have this changed... if (recipients == null) { return null; } if (recipients.size() == 0) { return EMPTY; } final StringBuilder sb = new StringBuilder(recipients.size() * 10); for (final BigInteger s : recipients) { sb.append(s.toString()).append(","); } return sb.substring(0, sb.length() - 1); } @Override public String toString() { return "Message{" + "originator='" + originator + '\'' + ", body='" + body + '\'' + ", recipients='" + recipients + '\'' + ", type=" + type + ", reference='" + reference + '\'' + ", validity=" + validity + ", gateway=" + gateway + ", reportUrl=" + reportUrl + ", typeDetails='" + typeDetails + '\'' + ", datacoding=" + datacoding + ", mclass=" + mclass + ", scheduledDatetime=" + scheduledDatetime + '}'; } /** * The sender of the message. This can be a telephone number (including country code) or an alphanumeric string. In case of an alphanumeric string, the maximum length is 11 characters. * * @return originator of the message */ public String getOriginator() { return originator; } @Override public String getBody() { return body; } @Override public String getRecipients() { return recipients; } /** * The configured message type. Values can be: sms, binary, premium, or flash. * * @return MsgType that has been configured */ public MsgType getType() { return type; } /** * The type of message. Values can be: sms, binary, premium, or flash. * Default: sms (set by MessageBird and will not be send) * * @param type Message Type */ public void setType(MsgType type) { this.type = type; if (type == MsgType.flash) { this.mclass = MClassType.flash; } else { this.mclass = MClassType.normal; } } @Override public String getReference() { return reference; } /** * @param reference The client reference */ public void setReference(String reference) { this.reference = reference; } /** * The configured validity * The amount of seconds that the message is valid. If a message is not delivered within this time, the message will be discarded. * * @return validity value */ public Integer getValidity() { return validity; } /** * The amount of seconds that the message is valid. If a message is not delivered within this time, the message will be discarded. * * @param validity */ public void setValidity(Integer validity) { if (validity < 0) { throw new IllegalArgumentException("validity must be >= 0"); } this.validity = validity; } /** * The configured SMS route that is used to send the message. * * @return routing number */ public Integer getGateway() { return gateway; } /** * The SMS route that is used to send the message. * * @param gateway */ public void setGateway(Integer gateway) { this.gateway = gateway; } /** * An hash with extra information. Is only used when a binary or premium message is sent. *

* Note: Interface might change in feature * * @return Map with specific items for that request */ public Map getTypeDetails() { return typeDetails; } /** * An hash with extra information. Is only used when a binary or premium message is sent. *

* Note: Interface might change in feature * * @return */ public void setTypeDetails(Map typeDetails) { this.typeDetails = typeDetails; } /** * The datacoding used, can be plain or unicode * * @return returns plain or unicode */ public DataCodingType getDatacoding() { return datacoding; } /** * The datacoding used, can be plain or unicode * * @param datacoding */ public void setDatacoding(DataCodingType datacoding) { this.datacoding = datacoding; } /** * Indicated the message type. * * @return */ public MClassType getMclass() { return mclass; } @Override public Date getScheduledDatetime() { return scheduledDatetime; } /** * The scheduled date and time of the message. Allows to specify when MessageBird server send's the mesage. * * @param scheduledDatetime */ public void setScheduledDatetime(Date scheduledDatetime) { this.scheduledDatetime = scheduledDatetime; } /** * Setup premium SMS type * * @param shortcode * @param keyword * @param tariff * @param mid */ public void setPremiumSMS(Object shortcode, Object keyword, Object tariff, Object mid) { final Map premiumSMSConfig = new LinkedHashMap(4); premiumSMSConfig.put("shortcode", shortcode); premiumSMSConfig.put("keyword", keyword); premiumSMSConfig.put("tariff", tariff); premiumSMSConfig.put("mid", mid); this.typeDetails = premiumSMSConfig; this.type = MsgType.premium; } public URL getReportUrl() { return reportUrl; } public void setReportUrl(URL reportUrl) { this.reportUrl = reportUrl; } }





© 2015 - 2025 Weber Informatics LLC | Privacy Policy