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

com.github.twitch4j.eventsub.events.ChannelModerateEvent Maven / Gradle / Ivy

The newest version!
package com.github.twitch4j.eventsub.events;

import com.github.twitch4j.eventsub.domain.moderation.*;
import lombok.AccessLevel;
import lombok.Data;
import lombok.EqualsAndHashCode;
import lombok.NoArgsConstructor;
import lombok.Setter;
import lombok.ToString;
import org.jetbrains.annotations.NotNull;
import org.jetbrains.annotations.Nullable;

@Data
@Setter(AccessLevel.PRIVATE)
@NoArgsConstructor
@ToString(callSuper = true)
@EqualsAndHashCode(callSuper = true)
public class ChannelModerateEvent extends EventSubModeratorEvent {

    /**
     * The channel ID in which the action originally occurred.
     * Is null when the moderator action happens in the same channel as the broadcaster.
     * Is not null when in a shared chat session, and the action happens in the channel of a participant other than the broadcaster.
     */
    @Nullable
    private String sourceBroadcasterUserId;

    /**
     * The channel login name in which the action originally occurred.
     * Is null when the moderator action happens in the same channel as the broadcaster.
     * Is not null when in a shared chat session, and the action happens in the channel of a participant other than the broadcaster.
     */
    @Nullable
    private String sourceBroadcasterUserLogin;

    /**
     * The channel display name in which the action originally occurred.
     * Is null when the moderator action happens in the same channel as the broadcaster.
     * Is not null when in a shared chat session, and the action happens in the channel of a participant other than the broadcaster.
     */
    @Nullable
    private String sourceBroadcasterUserName;

    /**
     * The action performed.
     * 

* Note that the following actions do not have any associated metadata: * {@link Action#CLEAR}, {@link Action#EMOTEONLY}, {@link Action#EMOTEONLYOFF}, {@link Action#FOLLOWERSOFF}, * {@link Action#SLOWOFF}, {@link Action#SUBSCRIBERS}, {@link Action#SUBSCRIBERSOFF}, * {@link Action#UNIQUECHAT}, and {@link Action#UNIQUECHATOFF}. */ private @NotNull Action action; /** * Metadata associated with the followers command. *

* This is only populated when {@link #getAction()} is {@link Action#FOLLOWERS}. */ private @Nullable FollowersMode followers; /** * Metadata associated with the slow command. *

* This is only populated when {@link #getAction()} is {@link Action#SLOW}. */ private @Nullable SlowMode slow; /** * Metadata associated with the vip command. *

* This is only populated when {@link #getAction()} is {@link Action#VIP}. */ private @Nullable UserTarget vip; /** * Metadata associated with the unvip command. *

* This is only populated when {@link #getAction()} is {@link Action#UNVIP}. */ private @Nullable UserTarget unvip; /** * Metadata associated with the mod command. *

* This is only populated when {@link #getAction()} is {@link Action#MOD}. */ private @Nullable UserTarget mod; /** * Metadata associated with the unmod command. *

* This is only populated when {@link #getAction()} is {@link Action#UNMOD}. */ private @Nullable UserTarget unmod; /** * Metadata associated with the ban command. *

* This is only populated when {@link #getAction()} is {@link Action#BAN}. */ private @Nullable BanTarget ban; /** * Metadata associated with the ban command. * This field is for an action that happened for a channel in a shared chat session * other than the broadcaster in the subscription condition. *

* This is only populated when {@link #getAction()} is {@link Action#SHARED_CHAT_BAN}. */ private @Nullable BanTarget sharedChatBan; /** * Metadata associated with the unban command. *

* This is only populated when {@link #getAction()} is {@link Action#UNBAN}. */ private @Nullable UserTarget unban; /** * Metadata associated with the unban command. * This field is for an action that happened for a channel in a shared chat session * other than the broadcaster in the subscription condition. *

* This is only populated when {@link #getAction()} is {@link Action#SHARED_CHAT_UNBAN}. */ private @Nullable UserTarget sharedChatUnban; /** * Metadata associated with the timeout command. *

* This is only populated when {@link #getAction()} is {@link Action#TIMEOUT}. */ private @Nullable TimeoutTarget timeout; /** * Metadata associated with the timeout command. * This field is for an action that happened for a channel in a shared chat session * other than the broadcaster in the subscription condition. *

* This is only populated when {@link #getAction()} is {@link Action#SHARED_CHAT_TIMEOUT}. */ private @Nullable TimeoutTarget sharedChatTimeout; /** * Metadata associated with the untimeout command. *

* This is only populated when {@link #getAction()} is {@link Action#UNTIMEOUT}. */ private @Nullable UserTarget untimeout; /** * Metadata associated with the untimeout command. * This field is for an action that happened for a channel in a shared chat session * other than the broadcaster in the subscription condition. *

* This is only populated when {@link #getAction()} is {@link Action#SHARED_CHAT_UNTIMEOUT}. */ private @Nullable UserTarget sharedChatUntimeout; /** * Metadata associated with the raid command. *

* This is only populated when {@link #getAction()} is {@link Action#RAID}. */ private @Nullable RaidTarget raid; /** * Metadata associated with the unraid command. *

* This is only populated when {@link #getAction()} is {@link Action#UNRAID}. */ private @Nullable UserTarget unraid; /** * Metadata associated with the delete command. *

* This is only populated when {@link #getAction()} is {@link Action#DELETE}. */ private @Nullable DeleteTarget delete; /** * Metadata associated with the delete command. * This field is for an action that happened for a channel in a shared chat session * other than the broadcaster in the subscription condition. *

* This is only populated when {@link #getAction()} is {@link Action#SHARED_CHAT_DELETE}. */ private @Nullable DeleteTarget sharedChatDelete; /** * Metadata associated with automod terms changes. *

* This is only populated when {@link #getAction()} is * {@link Action#ADD_BLOCKED_TERM} or {@link Action#ADD_PERMITTED_TERM} or * {@link Action#DELETE_BLOCKED_TERM} or {@link Action#DELETE_PERMITTED_TERM}. */ private @Nullable AutomodTerms automodTerms; /** * Metadata associated with actioning an unban request. *

* This is only populated when {@link #getAction()} is * {@link Action#APPROVE_UNBAN_REQUEST} or {@link Action#DENY_UNBAN_REQUEST}. */ private @Nullable UnbanRequest unbanRequest; /** * Metadata associated with the warn command. *

* This is only populated when {@link #getAction()} is {@link Action#WARN}. */ private @Nullable Warning warn; }





© 2015 - 2025 Weber Informatics LLC | Privacy Policy