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

com.vonage.client.conversations.AudioPlayEvent Maven / Gradle / Ivy

/*
 *   Copyright 2024 Vonage
 *
 *   Licensed under the Apache License, Version 2.0 (the "License");
 *   you may not use this file except in compliance with the License.
 *   You may obtain a copy of the License at
 *
 *        http://www.apache.org/licenses/LICENSE-2.0
 *
 *   Unless required by applicable law or agreed to in writing, software
 *   distributed under the License is distributed on an "AS IS" BASIS,
 *   WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
 *   See the License for the specific language governing permissions and
 *   limitations under the License.
 */
package com.vonage.client.conversations;

import com.fasterxml.jackson.annotation.JsonIgnore;
import java.net.URI;
import java.util.UUID;

/**
 * Represents an {@link EventType#AUDIO_PLAY} event.
 */
public final class AudioPlayEvent extends AudioOutEvent {

    AudioPlayEvent() {}

    private AudioPlayEvent(Builder builder) {
        super(builder);
        body = new AudioPlayEventBody(builder);
    }

    /**
     * Unique audio play identifier.
     *
     * @return The play ID, or {@code null} if unknown.
     */
    @JsonIgnore
    public UUID getPlayId() {
        return body != null ? body.playId : null;
    }

    /**
     * Source URL of the audio to play.
     *
     * @return The stream URL, or {@code null} if unspecified.
     */
    @JsonIgnore
    public URI getStreamUrl() {
        return body != null && body.streamUrl != null && body.streamUrl.length > 0 ? body.streamUrl[0] : null;
    }

    /**
     * Entry point for constructing an instance of this class.
     *
     * @return A new Builder.
     */
    public static Builder builder() {
        return new Builder();
    }

    public static final class Builder extends AudioOutEvent.Builder {
        URI[] streamUrl;

        Builder() {
            super(EventType.AUDIO_PLAY);
        }

        /**
         * Source URL of the audio to play.
         *
         * @param streamUrl The stream URL as a string.
         *
         * @return This builder.
         */
        public Builder streamUrl(String streamUrl) {
            return streamUrl(URI.create(streamUrl));
        }

        /**
         * Source URL of the audio to play.
         *
         * @param streamUrl The stream URL.
         *
         * @return This builder.
         */
        public Builder streamUrl(URI streamUrl) {
            this.streamUrl = new URI[]{streamUrl};
            return this;
        }

        @Override
        public AudioPlayEvent build() {
            return new AudioPlayEvent(this);
        }
    }
}




© 2015 - 2025 Weber Informatics LLC | Privacy Policy