001/* 002 * Copyright (c) 2011-2018 Nexmo Inc 003 * 004 * Permission is hereby granted, free of charge, to any person obtaining a copy 005 * of this software and associated documentation files (the "Software"), to deal 006 * in the Software without restriction, including without limitation the rights 007 * to use, copy, modify, merge, publish, distribute, sublicense, and/or sell 008 * copies of the Software, and to permit persons to whom the Software is 009 * furnished to do so, subject to the following conditions: 010 * 011 * The above copyright notice and this permission notice shall be included in 012 * all copies or substantial portions of the Software. 013 * 014 * THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR 015 * IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY, 016 * FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE 017 * AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER 018 * LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, 019 * OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN 020 * THE SOFTWARE. 021 */ 022package com.nexmo.client.conversion; 023 024import com.nexmo.client.*; 025 026import java.util.Date; 027 028/** 029 * A client for talking to the Nexmo Conversion API. The standard way to obtain an instance of this class is to use 030 * {@link NexmoClient#getConversionClient()}. 031 * <p> 032 * Allows you to tell Nexmo about the reliability of your 2FA communications. 033 * <p> 034 * More information on method parameters can be found at Nexmo website: 035 * <a href="https://developer.nexmo.com/messaging/conversion-api/overview">https://developer.nexmo.com/messaging/conversion-api/overview</a> 036 */ 037public class ConversionClient extends AbstractClient { 038 private ConversionEndpoint conversionEndpoint; 039 040 public ConversionClient(HttpWrapper httpWrapper) { 041 super(httpWrapper); 042 043 this.conversionEndpoint = new ConversionEndpoint(httpWrapper); 044 } 045 046 /** 047 * Submit a request to the Conversion API indicating whether or not a message was delivered. 048 * 049 * @param type The {@link ConversionRequest.Type} type of com.nexmo.client.conversion. 050 * @param messageId The id of the message that was sent. 051 * @param delivered A boolean indicating whether or not it was delivered. 052 * @param timestamp A timestamp of when it was known to be delivered. 053 * 054 * @throws NexmoClientException if there was a problem with the Nexmo request or response objects. 055 * @throws NexmoResponseParseException if the response from the API could not be parsed. 056 */ 057 public void submitConversion(ConversionRequest.Type type, 058 String messageId, 059 boolean delivered, 060 Date timestamp) throws NexmoResponseParseException, NexmoClientException { 061 this.conversionEndpoint.submitConversion(new ConversionRequest(type, messageId, delivered, timestamp)); 062 } 063}