com.github.twitch4j.extensions.TwitchExtensions Maven / Gradle / Ivy
package com.github.twitch4j.extensions;
import com.github.twitch4j.common.annotation.Unofficial;
import com.github.twitch4j.extensions.domain.ChannelList;
import com.github.twitch4j.extensions.domain.ConfigurationSegment;
import com.github.twitch4j.extensions.domain.ConfigurationSegmentType;
import com.github.twitch4j.extensions.domain.ExtensionConfigurationSegment;
import com.github.twitch4j.extensions.domain.ExtensionInformation;
import com.github.twitch4j.extensions.domain.ExtensionSecretList;
import com.github.twitch4j.common.feign.JsonStringExpander;
import com.netflix.hystrix.HystrixCommand;
import feign.Body;
import feign.Headers;
import feign.Param;
import feign.RequestLine;
import org.jetbrains.annotations.ApiStatus;
import java.util.Map;
/**
* Twitch - Extensions API
*
* @see Twitch Shutdown Announcement
* @deprecated the Extensions API traditionally uses the decommissioned Kraken API. While the module now forwards calls to Helix, please migrate to using Helix directly as this module will be removed in the future.
*/
@Deprecated
@ApiStatus.ScheduledForRemoval(inVersion = "2.0.0")
public interface TwitchExtensions {
/**
* Creates a new secret for a specified extension, identified by a client ID value assigned to the extension when it is created.
* Also rotates any current secrets out of service, with enough time for extension clients to gracefully switch over to the new secret.
*
* Use this function only when you are ready to install the new secret it returns.
*
* Note: You get the initial secret via the Twitch developer site. Use this endpoint to rotate the secret later, if desired.
*
* @param clientId The extension's client ID.
* @param jsonWebToken Signed JWT created by the EBS, following the requirements documented in “Signing the JWT” (in Building Extensions).
* @param activationDelaySeconds The delay period, between the generation of the new secret and its use by Twitch, is specified by this required parameter. Default (and minimum): 300 (5 minutes).
* @return ExtensionSecretList
*/
@RequestLine("POST /{client_id}/auth/secret")
@Headers({
"Client-Id: {client_id}",
"Authorization: Bearer {token}",
"Content-Type: application/json"
})
@Body("%7B\"activation_delay_secs\":{activation_delay_secs}%7D")
HystrixCommand createExtensionSecret(
@Param("client_id") String clientId,
@Param("token") String jsonWebToken,
@Param("activation_delay_secs") int activationDelaySeconds
);
/**
* Retrieves a specified extension’s secret data: a version and an array of secret objects.
*
* @param clientId The extension is identified by a client ID value assigned to the extension when it is created.
* @param jsonWebToken Signed JWT created by the EBS, following the requirements documented in “Signing the JWT” (in Building Extensions).
* @return ExtensionSecretList
*/
@RequestLine("GET /{client_id}/auth/secret")
@Headers({
"Client-Id: {client_id}",
"Authorization: Bearer {token}"
})
HystrixCommand getExtensionSecret(
@Param("client_id") String clientId,
@Param("token") String jsonWebToken
);
/**
* Deletes all secrets associated with a specified extension, identified by a client ID value assigned to the extension when it is created.
*
* This immediately breaks all clients until both a new Create Extension Secret is executed and the clients manually refresh themselves.
* Use this only if a secret is compromised and must be removed immediately from circulation.
*
* @param clientId The client ID identifying the extension when it is created.
* @param jsonWebToken Signed JWT created by the EBS, following the requirements documented in “Signing the JWT” (in Building Extensions)
* @return 204 No Content on a successful call
* @deprecated No migration path in the new Helix API.
*/
@RequestLine("DELETE /{client_id}/auth/secret")
@Headers({
"Client-Id: {client_id}",
"Authorization: Bearer {token}"
})
@Deprecated
HystrixCommand revokeExtensionSecrets(
@Param("client_id") String clientId,
@Param("token") String jsonWebToken
);
/**
* Returns one page of live channels that have installed and activated a specified extension.
*
* A channel that just went live may take a few minutes to appear in this list, and a channel may continue to appear on this list for a few minutes after it stops broadcasting.
*
* @param clientId The client ID value assigned to the extension when it is created.
* @param cursor Cursor for forward pagination.
* @return ChannelList
*/
@RequestLine("GET /{client_id}/live_activated_channels?cursor={cursor}")
@Headers("Client-Id: {client_id}")
HystrixCommand getLiveChannelsWithExtensionActivated(
@Param("client_id") String clientId,
@Param("cursor") String cursor
);
/**
* Returns one page of live channels that have installed and activated a specified extension.
*
* @param clientId The client ID value assigned to the extension when it is created.
* @return ChannelList
* @deprecated use {@link #getLiveChannelsWithExtensionActivated(String, String)} instead (can pass null for cursor)
*/
@Deprecated
default HystrixCommand getLiveChannelsWithExtensionActivated(String clientId) {
return getLiveChannelsWithExtensionActivated(clientId, null);
}
/**
* Enable activation of a specified extension, after any required broadcaster configuration is correct.
*
* This is for extensions that require broadcaster configuration before activation. Use this if, in extension Capabilities, you select Custom/My Own Service.
*
* You enforce required broadcaster configuration with a required_configuration string in the extension manifest.
* The contents of this string can be whatever you want.
* Once your EBS determines that the extension is correctly configured on a channel, use this endpoint to provide that same configuration string, which enables activation on the channel.
*
* If a future version of the extension requires a different configuration, change the required_configuration string in your manifest.
* When the new version is released, broadcasters will be required to re-configure that new version.
*
* @param clientId The extension is identified by a client ID value assigned to the extension when it is created.
* @param jsonWebToken Signed JWT created by the EBS, following the requirements documented in “Signing the JWT” (in Building Extensions).
* @param extensionVersion The extension version.
* @param channelId The channel id for the broadcaster.
* @param requiredConfiguration The required configuration.
* @return 204 No Content on a successful call
*/
@RequestLine("PUT /{client_id}/{extension_version}/required_configuration?channel_id={channel_id}")
@Headers({
"Client-Id: {client_id}",
"Authorization: Bearer {token}",
"Content-Type: application/json"
})
@Body("%7B\"required_configuration\":\"{required_configuration}\"%7D")
HystrixCommand setExtensionRequiredConfiguration(
@Param("client_id") String clientId,
@Param("token") String jsonWebToken,
@Param("extension_version") String extensionVersion,
@Param("channel_id") String channelId,
@Param(value = "required_configuration", expander = JsonStringExpander.class) String requiredConfiguration
);
/**
* Sets a single configuration segment (any type). The segment type is specified by a required body parameter.
*
* Each segment is limited to 5 KB and can be set at most 20 times per minute. Updates to this data are not delivered to Extensions that have already rendered.
*
* Note: Your signed JWT must include the exp, user_id, and role fields, documented in JWT Schema. The role value must be external.
*
* @param clientId The client ID identifying the extension when it is created.
* @param jsonWebToken Signed JWT created by the EBS, following the requirements documented in “Signing the JWT” (in Building Extensions).
* @param configurationSegment The updated configuration segment.
* @return 204 No Content on a successful call
*/
@RequestLine("PUT /{client_id}/configurations")
@Headers({
"Client-Id: {client_id}",
"Authorization: Bearer {token}",
"Content-Type: application/json"
})
HystrixCommand setExtensionConfigurationSegment(
@Param("client_id") String clientId,
@Param("token") String jsonWebToken,
ExtensionConfigurationSegment configurationSegment
);
/**
* Gets the developer and broadcaster configuration segments for a specified channel.
*
* Each channel can be retrieved at most 20 times per minute.
*
* Note: Your signed JWT must include the exp, user_id, and role fields, documented in JWT Schema. The role value must be external.
*
* @param clientId The client ID identifying the extension when it is created.
* @param jsonWebToken Signed JWT created by the EBS, following the requirements documented in “Signing the JWT” (in Building Extensions).
* @param channelId The channel id of the broadcaster.
* @return Map
*/
@RequestLine("GET /{client_id}/configurations/channels/{channel_id}")
@Headers({
"Client-Id: {client_id}",
"Authorization: Bearer {token}"
})
HystrixCommand