001/* 002 * Copyright (c) 2011-2017 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.voice; 023 024import com.fasterxml.jackson.annotation.JsonProperty; 025import com.fasterxml.jackson.core.JsonProcessingException; 026import com.fasterxml.jackson.databind.ObjectMapper; 027import com.nexmo.client.NexmoUnexpectedException; 028 029/** 030 * The JSON payload that will be sent in a {@link StreamRequest}. 031 * <p> 032 * {@code streamUrl}: An array containing a single URL to an mp3 or wav (16-bit) audio file. 033 * {@code loop}: The number of times the audio file at {@code streamUrl} is repeated before the stream ends. Set to 0 to loop infinitely 034 */ 035 036public class StreamPayload { 037 private String[] streamUrl; 038 private int loop; 039 040 public StreamPayload(String streamUrl, int loop) { 041 this.streamUrl = new String[]{streamUrl}; 042 this.loop = loop; 043 } 044 045 public int getLoop() { 046 return loop; 047 } 048 049 @JsonProperty("stream_url") 050 public String[] getStreamUrl() { 051 return streamUrl; 052 } 053 054 public String toJson(){ 055 try { 056 ObjectMapper mapper = new ObjectMapper(); 057 return mapper.writeValueAsString(this); 058 } catch (JsonProcessingException jpe) { 059 throw new NexmoUnexpectedException("Failed to produce json from StreamPayload object.", jpe); 060 } 061 } 062}