2024-01-01 16:52:18 +00:00
// Package clip contains an actor to create clips on behalf of a
// channels owner
2023-08-14 00:52:51 +00:00
package clip
import (
"context"
"fmt"
"github.com/pkg/errors"
2023-09-11 17:51:38 +00:00
"gopkg.in/irc.v4"
2023-08-14 00:52:51 +00:00
2024-04-03 19:00:28 +00:00
"github.com/Luzifer/go_helpers/v2/fieldcollection"
"github.com/Luzifer/twitch-bot/v3/internal/helpers"
2023-08-14 00:52:51 +00:00
"github.com/Luzifer/twitch-bot/v3/pkg/twitch"
"github.com/Luzifer/twitch-bot/v3/plugins"
)
const actorName = "clip"
var (
formatMessage plugins . MsgFormatter
hasPerm plugins . ChannelPermissionCheckFunc
tcGetter func ( string ) ( * twitch . Client , error )
)
2024-01-01 16:52:18 +00:00
// Register provides the plugins.RegisterFunc
2023-08-14 00:52:51 +00:00
func Register ( args plugins . RegistrationArguments ) error {
formatMessage = args . FormatMessage
hasPerm = args . HasPermissionForChannel
tcGetter = args . GetTwitchClientForChannel
args . RegisterActor ( actorName , func ( ) plugins . Actor { return & actor { } } )
args . RegisterActorDocumentation ( plugins . ActionDocumentation {
Description : "Triggers the creation of a Clip from the given channel owned by the creator (subsequent actions can use variables `create_clip_slug` and `create_clip_edit_url`)" ,
Name : "Create Clip" ,
Type : actorName ,
Fields : [ ] plugins . ActionDocumentationField {
{
Description : "Channel to create the clip from, defaults to the channel of the event / message" ,
Key : "channel" ,
Name : "Channel" ,
Optional : true ,
SupportTemplate : true ,
Type : plugins . ActionDocumentationFieldTypeString ,
} ,
{
Description : fmt . Sprintf ( "User which should trigger and therefore own the clip (must have given %s permission to the bot in extended permissions!), defaults to the value of `channel`" , twitch . ScopeClipsEdit ) ,
Key : "creator" ,
Name : "Creator" ,
Optional : true ,
SupportTemplate : true ,
Type : plugins . ActionDocumentationFieldTypeString ,
} ,
{
Default : "false" ,
Description : "Whether to add an artificial delay before creating the clip" ,
Key : "add_delay" ,
Name : "Add Delay" ,
Optional : true ,
SupportTemplate : false ,
Type : plugins . ActionDocumentationFieldTypeBool ,
} ,
} ,
} )
return nil
}
type actor struct { }
2024-04-03 19:00:28 +00:00
func ( actor ) Execute ( _ * irc . Client , m * irc . Message , r * plugins . Rule , eventData * fieldcollection . FieldCollection , attrs * fieldcollection . FieldCollection ) ( preventCooldown bool , err error ) {
2023-08-14 00:52:51 +00:00
channel := plugins . DeriveChannel ( m , eventData )
if channel , err = formatMessage ( attrs . MustString ( "channel" , & channel ) , m , r , eventData ) ; err != nil {
return false , errors . Wrap ( err , "parsing channel" )
}
creator := channel
if creator , err = formatMessage ( attrs . MustString ( "creator" , & creator ) , m , r , eventData ) ; err != nil {
return false , errors . Wrap ( err , "parsing creator" )
}
canCreate , err := hasPerm ( creator , twitch . ScopeClipsEdit )
if err != nil {
return false , errors . Wrap ( err , "checking for required permission" )
}
if ! canCreate {
return false , errors . Errorf ( "creator has not given %s permission" , twitch . ScopeClipsEdit )
}
tc , err := tcGetter ( creator )
if err != nil {
return false , errors . Wrapf ( err , "getting Twitch client for %q" , creator )
}
2024-04-03 19:00:28 +00:00
clipInfo , err := tc . CreateClip ( context . TODO ( ) , channel , attrs . MustBool ( "add_delay" , helpers . Ptr ( false ) ) )
2023-08-14 00:52:51 +00:00
if err != nil {
return false , errors . Wrap ( err , "creating clip" )
}
eventData . Set ( "create_clip_slug" , clipInfo . ID )
eventData . Set ( "create_clip_edit_url" , clipInfo . EditURL )
return false , nil
}
func ( actor ) IsAsync ( ) bool { return false }
func ( actor ) Name ( ) string { return actorName }
2024-04-03 19:00:28 +00:00
func ( actor ) Validate ( tplValidator plugins . TemplateValidatorFunc , attrs * fieldcollection . FieldCollection ) ( err error ) {
if err = attrs . ValidateSchema (
2024-04-03 23:28:43 +00:00
fieldcollection . CanHaveField ( fieldcollection . SchemaField { Name : "channel" , NonEmpty : true , Type : fieldcollection . SchemaFieldTypeString } ) ,
fieldcollection . CanHaveField ( fieldcollection . SchemaField { Name : "creator" , NonEmpty : true , Type : fieldcollection . SchemaFieldTypeString } ) ,
2024-04-03 19:00:28 +00:00
helpers . SchemaValidateTemplateField ( tplValidator , "channel" , "creator" ) ,
) ; err != nil {
return fmt . Errorf ( "validating attributes: %w" , err )
2023-08-14 00:52:51 +00:00
}
return nil
}