All notable changes to the library will be documented in this file.
The format of the file is based on Keep a Changelog and this library adheres to Semantic Versioning as mentioned in README.md file.
[ 5.1.0 ] - 2024-12-16
- Support for Infobip Moments.
[ 5.0.0 ] - 2024-12-06
🎉 NEW Major Version of infobip-api-java-client
.
- Most recent feature set for:
- Infobip SMS API
- Introduced
/sms/3/messages (V3)
replacing the/sms/2/text/advanced (V2)
and/sms/2/binary/advanced (V2)
endpoints. - Introduced
/sms/3/reports (V3)
replacing/sms/1/reports (V1)
endpoint. - Introduced
/sms/3/logs (V3)
replacing/sms/1/logs (V1)
endpoint.
- Introduced
- Infobip Email API
- Infobip Voice API
- Infobip SMS API
- Fixes and changes
- Introduced the new SmsMessage class to replace
SmsTextualMessage
andSmsBinaryMessage
, providing a unified structure for SMS messaging. - Added a content field within
SmsMessage
to define the message content. This supports both textual and binary messages, which can be created using SmsTextContent or SmsBinaryContent, respectively. - Unified request classes by replacing
SmsAdvancedTextualRequest
andSmsAdvancedBinaryRequest
with the new SmsRequest class. - Consolidated sending functions: use
sendSmsMessages
instead of thesendSmsMessage
andsendBinarySmsMessage
functions. - Changed 'sentAt', 'doneAt' field type in MmsReport from String to OffsetDateTime since it didn't correspond to the state of the endpoint.
- Across all voice models, the 'applicationId' field has been removed and replaced with the 'platform' field, as it better reflects the state of the endpoint.
- Removed delivery time window configuration classes (
SmsDeliveryTimeWindow
,MmsDeliveryTimeWindow
,ViberDeliveryTimeWindow
,CallRoutingAllowedTimeWindow
,CallsDeliveryTimeWindow
,SmsDeliveryTimeWindow
,CallsTimeWindow
) in favor of a unified class: DeliveryTimeWindow - Removed delivery time configuration classes (
SmsDeliveryTimeFrom
,SmsDeliveryTimeTo
,MmsDeliveryTime
,ViberDeliveryTime
,CallsTimeWindowPoint
,WebRtcTimeOfDay
,CallRoutingAllowedTimeFrom
,CallRoutingAllowedTimeTo
,WebRtcTimeOfDay
) in favor of a unified class: DeliveryTime - Removed URL options configuration classes (
MessagesApiUrlOptions
,ViberUrlOptions
,WhatsAppUrlOptions
) in favor of a unified class: UrlOptions - Removed platform configuration class (
ViberPlatform
,MessagesApiPlatform
) in favor of a unified class: Platform - Removed TurkeyIys options configuration classes (
MessagesApiTurkeyIysOptions
,ViberTurkeyIysOptions
,SmsTurkeyIysOptions
) in favor of a unified class: TurkeyIysOptions - Removed delivery day enumeration classes (
SmsDeliveryDay
,MmsDeliveryDay
,CallsDeliveryDay
,CallRoutingAllowedDay
) in favor of a unified class: DeliveryDay - Removed recipient type enumeration classes (
SmsIysRecipientType
,ViberRecipientType
,MessagesApiRecipientType
) in favor of a unified class: IysRecipientType - Removed validity period configuration classes (
ViberValidityPeriod
,MessagesApiValidityPeriod
) in favor of a unified class: ValidityPeriod - Removed validity period time unit enumeration classes (
ViberValidityPeriodTimeUnit
,MessagesApiValidityPeriodTimeUnit
) in favor of a unified class: ValidityPeriodTimeUnit
- Introduced the new SmsMessage class to replace
[ 4.4.0 ] - 2024-11-19
- Most recent feature set for:
- Fixes and changes
- Changed 'description' field name in MessagesApiMessageListBody to 'subtext'.
- Removed 'messageCount' field in MessagesApiWebhookEventTextContent since it didn't correspond to the state of the endpoint.
- Documentation
- Fixed Javadoc.
[ 4.3.2 ] - 2024-08-22
- Added mock tests to verify the correctness of request payloads and response handling.
- Added
awaitility
andwiremock
test dependencies. snyk.yml
workflow, which serves the purpose of identifying and addressing dependency vulnerabilities in the project.sonar.yml
workflow to analyze the source code, enhancing code quality and maintainability.git-build-hook-maven-plugin
plugin into the project, providing support for Git hooks.pre-commit.sh
hook, which automatically executesmvn spotless:apply
prior to each commit, ensuring code formatting consistency.
- Bumped
jackson
version to2.17.0
- Bumped
slf4j-api
version to2.0.16
- Bumped
junit-jupiter
version to5.11.0
- Bumped
guava
version to33.3.0-jre
- Bumped
maven-gpg-plugin
version to3.2.5
- Bumped
spotless-maven-plugin
version to2.43.0
[ 4.3.1 ] - 2024-06-05
- Most recent Infobip SMS API feature set.
-
Fixes and changes
- Changed SmsTurkeyIysOptions model, previously nested enum 'RecipientTypeEnum' is now extracted to a separate class: SmsIysRecipientType.
- Expanded ApiExceptionDetailsResolver model with additional error response that the API might return.
-
Documentation
- Fixed Javadoc.
[ 4.3.0 ] - 2024-03-19
- Support for Infobip Messages API.
- Most recent feature set for:
- Removed classes and unified structures
- Removed basic url security configuration classes (
CallsBasicUrlSecurityConfig
,CallRoutingBasicUrlSecurityConfig
) in favor of a unified class: BasicSecurityConfig - Removed hmac algorithm class (
CallsHmacAlgorithm
) in favor of a unified class: HmacAlgorithm - Removed hmac url security configuration classes (
CallRoutingHmacUrlSecurityConfig
,CallsHmacUrlSecurityConfig
) in favor of a unified class: HmacSecurityConfig - Removed url security configuration classes (
CallRoutingUrlSecurityConfig
,CallsUrlSecurityConfig
) in favor of a unified class: SecurityConfig
- Removed basic url security configuration classes (
- Fixes and changes
- Changed CallRoutingRecording model, previously nested enum 'RecordingTypeEnum' is now extracted to a separate class: CallRoutingRecordingType.
- Changed 'endpoint' field type in CallsBulkCall from CallEndpoint to CallsBulkEndpoint since it didn't correspond to the state of the endpoint.
- Changed 'endpoint' field type in CallsBulkCallRequest from CallEndpoint to CallsBulkEndpoint since it didn't correspond to the state of the endpoint.
- Fixed some of the enum values in TfaLanguage since they didn't correspond to the state of the endpoint.
- Removed 'record' field in CallsClickToCallMessage since it is not supported on the API side.
- Removed 'values' field in ViberOutboundFileContent since it is not supported on the API side.
- Removed 'values' field in ViberOutboundImageContent since it is not supported on the API side.
- Removed 'values' field in ViberOutboundVideoContent since it is not supported on the API side.
- Changed 'reports' field name in ViberWebhookReportResponse to 'results'.
- Changed 'callbackData' field type in ViberWebhooks from Object to String since it didn't correspond to the state of the endpoint.
- Changed WhatsAppTemplateApiResponse by making it an abstract class, serving as a base for WhatsAppAuthenticationTemplateApiResponse, WhatsAppDefaultMarketingTemplateApiResponse, WhatsAppDefaultUtilityTemplateApiResponse.
- Changed 'results' field in WhatsAppWebhookInboundContactMessage to be initialized to an empty list rather than null.
- Changed 'results' field in WhatsAppWebhookInboundMessageResult to be initialized to an empty list rather than null.
- Removed 'contact' field in WhatsAppWebhookInboundMessageData since it didn't correspond to the state of the endpoint.
- Changed WhatsAppWebhookReferral model, previously nested enum 'SourceTypeEnum' is now extracted to a separate class: WhatsAppWebhookReferralSourceType.
- Changed WhatsAppWebhookReferralMedia by making it an abstract class, serving as a base for WhatsAppWebhookReferralMediaImage, WhatsAppWebhookReferralMediaVideo.
- Documentation
- Fixed Javadoc.
- Models for Receive WhatsApp Deleted Reports webhook since it is no longer part of Infobip's product stack.
- Unused model classes
[ 4.2.0 ] - 2024-03-07
[ 4.1.2 ] - 2024-03-07
- Issue that caused the number of query parameters for 'bulkId' & 'messageId' to be squared when making getOutboundSmsMessageLogsDefinition call in SmsApi.
- Issue that caused the number of query parameters for 'sender' to be squared when making getWhatsappSendersQualityDefinition call in WhatsAppApi.
[ 4.1.1 ] - 2024-01-03
guava
dependency to tagearly-access
endpoints with@Beta
annotation.- Most recent Infobip WhatsApp API feature set.
- Expanded WhatsAppTemplateDataContent model with additional field supporting
WhatsAppTemplateCarouselContent
that the API might return. - Early access endpoints in WhatsAppApi are tagged with
@Beta
annotation - Fixed Javadoc.
[ 4.1.0 ] - 2023-12-20
- Support for Infobip Call Routing API.
- Support for Infobip Call Link API.
- Most recent Infobip Email API feature set.
- Most recent Infobip SMS API feature set.
- Most recent Infobip MMS API feature set.
- Most recent Infobip Voice API feature set.
- Most recent Infobip WebRTC API feature set.
- Most recent Infobip Viber API feature set.
- Most recent Infobip WhatsApp API feature set.
- CPaaS-X support to more channels.
- Support for handling ApiError models:
- Removed classes and unified structures
- Removed pagination classes (
CallsPageInfo
,WebRtcPageInfo
) in favor of a unified class: PageInfo - Removed status-defining classes for messages by products (
EmailStatus
,MmsStatus
,SmsStatus
) and introduced a unified class: MessageStatus - Removed price-defining classes for messages by products (
EmailPrice
,MmsPrice
,SmsPrice
,EmailWebhookPrice
) and replaced with a unified class: MessagePrice - Removed error-defining classes for query execution by different products (
EmailReportError
,MmsError
,SmsError
) and introduced a unified class: MessageError
- Removed pagination classes (
- Fixes and changes
- Expanded ApiExceptionDetails model with additional fields supporting enriched error responses that the API might return.
- Changed
templateId
field type from Integer to Long in EmailApi's SendEmailRequest class because of reported issue. - Updated WhatsAppCategory enumeration values based on report and reported issue.
- Updated CallsErrorCode enumeration values to reflect changes on Hangup endpoint.
- Updated ViberValidityPeriodTimeUnit enumeration values since 'DAYS' is no longer supported, use 'HOURS' instead.
- Changed 'context' field name in CallsApplicationTransferRequest to 'customData'.
- Changed 'days' field type in CallsDeliveryTimeWindow from List to Set to avoid duplicates.
- Removed 'type' field in CallsDtmfTermination since it is not supported on the API side.
- Removed 'stopOn' field in CallsSayRequest since it is not supported on the API side.
- Removed 'sipTrunkGroupId' field in CallsSipEndpoint since it is not supported on the API side.
- Removed 'notifyContentType' field in MmsAdvancedMessage since it is not supported on the API side.
- Removed 'sendingSpeedLimit' field in MmsAdvancedRequest since it is not supported on the API side.
- Fixed Viber webhook report models.
- Changed 'results' field name in ViberWebhookReportResponse to reports.
- Replaced 'ios' and 'android' fields in WebRtcPushConfigurationResponse with 'androidConfigured' and 'iosConfigured' since they didn't correspond to the state of the endpoint.
- Changed 'structure' field type in WhatsAppTemplateApiResponse from 'WhatsAppTemplateStructureApiData' and 'WhatsAppDefaultTemplateStructureApiData'.
- Changed WhatsAppTemplatePublicApiRequest by making it an abstract class, serving as a base for WhatsAppAuthenticationTemplatePublicApiRequest, WhatsAppDefaultMarketingTemplatePublicApiRequest, WhatsAppDefaultUtilityTemplatePublicApiRequest.
- Documentation
- Fixed Javadoc.
- Dependencies
- Bumped
slf4j-api
version to2.0.9
- Bumped
jackson
version to2.15.2
- Bumped
okhttp
version to4.12.0
- Bumped
- Unused model classes
- Deprecated old error fields in ApiExceptionDetails
[ 4.0.0 ] - 2023-03-01
🎉 NEW Major Version of infobip-api-java-client
.
- Support for Infobip MMS API.
- Support for Infobip Voice API.
- Support for Infobip WebRTC API.
- Support for Infobip Viber API.
- Most recent Infobip SMS API feature set.
- Most recent Email feature set.
- Most recent WhatsApp feature set.
- Tests for the static parts of the auto-generated code. There are multiple tests phases implemented in our auto-generation pipeline. A part of the tests is now included as a library source code.
- Base URL abstraction.
- Api Key abstraction.
- Deprecation notice log if deprecated or gone endpoints are used (
slf4j-api
dependency). - Snyk and Java version badges to README.
- The library now requires Java 11 or above.
- OkHttp dependency was bumped to version 4.10.0.
- From this version, an
ApiClient
instance must be constructed and configured using the Builder pattern:The additional OkHttp client configuration was removed from the library. Please check the Removed section for details.ApiClient apiClient = ApiClient.forApiKey(givenApiKey) .withBaseUrl(givenBaseUrl) .withHttpClient(givenHttpClient) .withReadTimeout(givenReadTimeoutInSeconds) .withTempDirectoryPath(givenTempDirPath) .build();
- API classes were refactored in a way that all functionalities are grouped under the same product.
For example,
SendSmsApi
,ScheduledSmsApi
andReceiveSmsApi
classes are replaced with a singleSmsApi
class. - API class methods that trigger an API call were rewritten using a fluent style where all required parameters
must be passed to a request builder factory method.
On the other hand, optional parameters may be passed using a separate request builder methods.
The result can be fetched using
execute
orexecuteAsync
methods. That allows us to add optional parameters without introducing a breaking change to the library. For example, in the previous version, to send a TFA pin code, we could use something like this:In the new version, the following pattern applies:TfaStartAuthenticationResponse response = tfaApi.sendTfaPinCodeOverSms(false, request);
TfaStartAuthenticationResponse sendCodeResponse = tfaApi .sendTfaPinCodeOverSms(request) .ncNeeded(false) .execute();
- Jackson (version 2.14.2) serialization library is used instead of Gson.
The
JSON
serialization utility now uses a preconfigured Jackson'sObjectMapper
. Also, the support forInputStream
serialization was added. - All maven plugins were bumped to the most recent version. Both unneeded plugins and the obsolete configuration were removed.
- The API request and response processing was rewritten to increase maintainability and usability.
- The
ApiException
class was refactored to have fluent getters and a single accessible Builder. - From this version, the error response body is deserialized and stored in
details
property of theApiException
class. - The
palantir-java-format
is now used instead ofgoogle-java-format
to have the formatting closer to our internal coding style. See the Spotless README for details. - Some products like Email and WhatsApp contain a few breaking changes since a new version of a few of the API endpoints was released. If you have issues when migrating the existing implementation, please check the official API documentation or submit an issue.
- Basic, IBSSO Token Header and client credentials grant type OAuth2 authentication methods.
Use API Key Header authentication method instead.
The API Key should be injected into the
ApiClient
instance through the newly introducedforApiKey
factory method. Examples can be found in the README. Configuration
utility class. Having static default configuration is error-prone and provides an unnecessary overhead. AnApiClient
instance should always be injected in the given API class.SSL
settings configuration methods from theApiClient
. If you need to configure customSSL
related settings (custom client keys, disabled CA certificate and hostname verification, etc.), configure them on theOkHttpClient
instance directly and pass the instance to theApiClient
usingwithHttpClient
builder method.- Date format customization methods from the
ApiClient
. Only the default Infobip date format should be used. The date formatter instance to be used is available through theJSON
class. - Header and cookie manipulation through
ApiClient
public interface. However, it can still be achieved using OkHttp interceptors if needed. Feel free to configure anOkHttpClient
instance with appropriate interceptors and pass the instance to theApiClient
usingwithHttpClient
builder method. - Explicit debugging option for
ApiClient
. HttpLoggingInterceptor can always be included by providing a preconfigured HTTP client as described above. - Explicit gzip support for requests. The support should be provided by the client itself like explained here.
- Unused generated classes.
- Default network interceptor used for tracking upload and download progress. The functionality can be re-added by using the official OkHttp recipe.
...WithHttpInfo
methods from API client classes. If an additional info like response headers or the response code is needed, theexecuteAsync
method should be used. The required information is injected in the callback....buildCall
methods from API client classes. The OkHttpCall
abstraction can be obtained by using theexecuteAsync
method. We don't allow calling the API without processing the response internally anymore.
[ 3.2.0 ] - 2022-01-19
- Support for Infobip WhatsApp API
whatsapp.md
containing quick start guide for WhatsApp API
- Email sending API to match the latest version of the API.
- Signature changed: getEmailLogs()
- Renamed some email API models to be consistent across multiple products
- EmailError -> EmailReportError
- EmailLogsResult -> EmailLogsResponse
- Minor SMS API changes (some field became readonly)
- Improved Javadoc comments
[ 3.1.0 ] - 2021-06-16
- Support for Infobip Email API
email.md
which contains basic example of Email API usage
[ 3.0.1 ] - 2021-02-16
README.md
which now contains more details about supported authentication methods & updated examples of library usage for webhooks
- Unused model classes
- Unused utility classes
- Unused dependency
- Supported date formats as specified in Integration Best Practices
[ 3.0.0 ] - 2021-02-03
🎉 NEW Major Version of infobip-api-java-client
.
In this release the infobip-api-java-client library is updated and modernized. It is auto-generated and completely different from the previous version.
- Support for async execution
CONTRIBUTING.md
which contains guidelines for creating GitHub issues- Support for Infobip Two-factor Authentication API
- Models, structure, examples, etc. for Infobip SMS API
- Library dependencies
README.md
which contains necessary data and examples for quickstart as well as some other important pieces of information on versioning, licensing, etc.
- Support for Infobip Omni API (to be included back in one of the next releases)