CreateChatThreadOptions.java

// Copyright (c) Microsoft Corporation. All rights reserved.
// Licensed under the MIT License.

package com.azure.communication.chat.models;

import com.azure.core.annotation.Fluent;

import java.util.ArrayList;
import java.util.List;
import java.util.UUID;

/** The CreateChatThreadOptions model. */
@Fluent
public final class CreateChatThreadOptions {
    /*
     * The chat thread topic.
     */
    private final String topic;

    /*
     * Members to be added to the chat thread.
     */
    private List<ChatParticipant> participants = new ArrayList<>();

    private String idempotencyToken;

    /**
     * Get the topic property: The chat thread topic.
     *
     * @return the topic value.
     */
    public String getTopic() {
        return this.topic;
    }

    /**
     * Get the participants property: Participants to be added to the chat thread.
     *
     * @return the participants value.
     */
    public List<ChatParticipant> getParticipants() {
        return this.participants;
    }

    /**
     * Set the participants property: Participants to be added to the chat thread.
     *
     * @param participants the participants value to set.
     * @return the CreateChatThreadOptions object itself.
     */
    public CreateChatThreadOptions setParticipants(List<ChatParticipant> participants) {
        this.participants = participants;
        return this;
    }

    /**
     * Adds another participant to the list of participants to create the chat thread with
     *
     * @param participant The participant to add
     * @return the CreateChatThreadOptions object itself
     */
    public CreateChatThreadOptions addParticipant(ChatParticipant participant) {
        this.participants.add(participant);
        return this;
    }

    /**
     * Get the idempotencyToken property
     *
     * @return the idempotencyToken.
     */
    public String getIdempotencyToken() {
        return this.idempotencyToken;
    }

    /**
     * Set the idempotencyToken property:
     * If specified, the client directs that the request is repeatable; that is, that the
     * client can make the request multiple times with the same idempotencyToken and get back an appropriate
     * response without the server executing the request multiple times. The value of the idempotencyToken
     * is an opaque string representing a client-generated, globally unique for all time, identifier for the
     * request. It is recommended to use version 4 (random) UUIDs.
     *
     * @param idempotencyToken the idempotencyToken.
     * @return the CreateChatThreadOptions object itself.
     */
    public CreateChatThreadOptions setIdempotencyToken(String idempotencyToken) {
        this.idempotencyToken = idempotencyToken;
        return this;
    }

    /**
     * Creates a new instance of CreateChatThreadOptions
     * @param topic the topic value to set.
     */
    public CreateChatThreadOptions(String topic) {
        this.topic = topic;
        this.idempotencyToken = UUID.randomUUID().toString();
    }
}