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