2023-01-27 03:22:44 -08:00
import type { INodeProperties } from 'n8n-workflow' ;
2020-08-09 14:39:28 -07:00
2021-12-03 00:44:16 -08:00
export const playlistOperations : INodeProperties [ ] = [
2020-08-09 14:39:28 -07:00
{
displayName : 'Operation' ,
name : 'operation' ,
type : 'options' ,
2022-05-20 14:47:24 -07:00
noDataExpression : true ,
2020-08-09 14:39:28 -07:00
displayOptions : {
show : {
2022-08-17 08:50:24 -07:00
resource : [ 'playlist' ] ,
2020-08-09 14:39:28 -07:00
} ,
} ,
options : [
{
name : 'Create' ,
value : 'create' ,
description : 'Create a playlist' ,
2022-07-10 13:50:51 -07:00
action : 'Create a playlist' ,
2020-08-09 14:39:28 -07:00
} ,
{
name : 'Delete' ,
value : 'delete' ,
description : 'Delete a playlist' ,
2022-07-10 13:50:51 -07:00
action : 'Delete a playlist' ,
2020-08-09 14:39:28 -07:00
} ,
2020-08-11 13:07:23 -07:00
{
name : 'Get' ,
value : 'get' ,
description : 'Get a playlist' ,
2022-07-10 13:50:51 -07:00
action : 'Get a playlist' ,
2020-08-11 13:07:23 -07:00
} ,
2020-08-09 14:39:28 -07:00
{
2022-09-07 07:51:14 -07:00
name : 'Get Many' ,
2020-08-09 14:39:28 -07:00
value : 'getAll' ,
2022-09-13 03:36:36 -07:00
description : 'Retrieve many playlists' ,
2022-09-08 08:10:13 -07:00
action : 'Get many playlists' ,
2020-08-09 14:39:28 -07:00
} ,
{
name : 'Update' ,
value : 'update' ,
description : 'Update a playlist' ,
2022-07-10 13:50:51 -07:00
action : 'Update a playlist' ,
2020-08-09 14:39:28 -07:00
} ,
] ,
default : 'getAll' ,
2020-10-22 06:46:03 -07:00
} ,
2021-12-03 00:44:16 -08:00
] ;
2020-08-09 14:39:28 -07:00
2021-12-03 00:44:16 -08:00
export const playlistFields : INodeProperties [ ] = [
2020-08-09 14:39:28 -07:00
/* -------------------------------------------------------------------------- */
/* playlist:create */
/* -------------------------------------------------------------------------- */
{
displayName : 'Title' ,
name : 'title' ,
type : 'string' ,
required : true ,
displayOptions : {
show : {
2022-08-17 08:50:24 -07:00
operation : [ 'create' ] ,
resource : [ 'playlist' ] ,
2020-08-09 14:39:28 -07:00
} ,
} ,
default : '' ,
2022-08-17 08:50:24 -07:00
description : "The playlist's title" ,
2020-08-09 14:39:28 -07:00
} ,
{
displayName : 'Options' ,
name : 'options' ,
type : 'collection' ,
2024-07-29 05:27:23 -07:00
placeholder : 'Add option' ,
2020-08-09 14:39:28 -07:00
default : { } ,
displayOptions : {
show : {
2022-08-17 08:50:24 -07:00
operation : [ 'create' ] ,
resource : [ 'playlist' ] ,
2020-08-09 14:39:28 -07:00
} ,
} ,
options : [
{
displayName : 'Description' ,
name : 'description' ,
type : 'string' ,
default : '' ,
2022-08-17 08:50:24 -07:00
description : "The playlist's description" ,
2020-08-09 14:39:28 -07:00
} ,
{
displayName : 'Privacy Status' ,
name : 'privacyStatus' ,
type : 'options' ,
options : [
{
name : 'Private' ,
value : 'private' ,
} ,
{
name : 'Public' ,
value : 'public' ,
} ,
{
name : 'Unlisted' ,
2020-11-18 14:30:43 -08:00
value : 'unlisted' ,
2020-08-09 14:39:28 -07:00
} ,
] ,
default : '' ,
2022-08-17 08:50:24 -07:00
description : "The playlist's privacy status" ,
2020-08-09 14:39:28 -07:00
} ,
{
displayName : 'Tags' ,
name : 'tags' ,
type : 'string' ,
default : '' ,
2022-08-17 08:50:24 -07:00
description :
'Keyword tags associated with the playlist. Mulplie can be defined separated by comma.' ,
2020-08-09 14:39:28 -07:00
} ,
{
2022-06-03 10:23:49 -07:00
displayName : 'Default Language Name or ID' ,
2020-08-09 14:39:28 -07:00
name : 'defaultLanguage' ,
2020-08-11 13:07:23 -07:00
type : 'options' ,
typeOptions : {
loadOptionsMethod : 'getLanguages' ,
} ,
2020-08-09 14:39:28 -07:00
default : '' ,
2022-08-17 08:50:24 -07:00
description :
'The language of the text in the playlist resource\'s title and description properties. Choose from the list, or specify an ID using an <a href="https://docs.n8n.io/code-examples/expressions/">expression</a>.' ,
2020-08-09 14:39:28 -07:00
} ,
{
displayName : 'On Behalf Of Content Owner Channel' ,
name : 'onBehalfOfContentOwnerChannel' ,
type : 'string' ,
default : '' ,
2022-08-17 08:50:24 -07:00
description :
'The onBehalfOfContentOwnerChannel parameter specifies the YouTube channel ID of the channel to which a video is being added. This parameter is required when a request specifies a value for the onBehalfOfContentOwner parameter, and it can only be used in conjunction with that parameter.' ,
2020-08-09 14:39:28 -07:00
} ,
{
displayName : 'On Behalf Of Content Owner' ,
name : 'onBehalfOfContentOwner' ,
type : 'string' ,
default : '' ,
2022-08-17 08:50:24 -07:00
description :
"The onBehalfOfContentOwner parameter indicates that the request's authorization credentials identify a YouTube CMS user who is acting on behalf of the content owner specified in the parameter value" ,
2020-08-09 14:39:28 -07:00
} ,
] ,
} ,
/* -------------------------------------------------------------------------- */
2020-08-11 13:07:23 -07:00
/* playlist:get */
/* -------------------------------------------------------------------------- */
{
displayName : 'Playlist ID' ,
name : 'playlistId' ,
type : 'string' ,
required : true ,
displayOptions : {
show : {
2022-08-17 08:50:24 -07:00
operation : [ 'get' ] ,
resource : [ 'playlist' ] ,
2020-08-11 13:07:23 -07:00
} ,
} ,
default : '' ,
} ,
{
displayName : 'Fields' ,
name : 'part' ,
type : 'multiOptions' ,
options : [
2020-08-14 15:36:47 -07:00
{
name : '*' ,
value : '*' ,
} ,
2020-08-11 13:07:23 -07:00
{
name : 'Content Details' ,
value : 'contentDetails' ,
} ,
{
name : 'ID' ,
value : 'id' ,
} ,
{
name : 'Localizations' ,
value : 'localizations' ,
} ,
{
name : 'Player' ,
value : 'player' ,
} ,
{
name : 'Snippet' ,
value : 'snippet' ,
} ,
{
name : 'Status' ,
value : 'status' ,
} ,
] ,
required : true ,
displayOptions : {
show : {
2022-08-17 08:50:24 -07:00
operation : [ 'get' ] ,
resource : [ 'playlist' ] ,
2020-08-11 13:07:23 -07:00
} ,
} ,
2022-08-17 08:50:24 -07:00
description :
'The fields parameter specifies a comma-separated list of one or more playlist resource properties that the API response will include' ,
2020-08-15 19:36:11 -07:00
default : [ '*' ] ,
2020-08-11 13:07:23 -07:00
} ,
{
displayName : 'Options' ,
name : 'options' ,
type : 'collection' ,
2024-07-29 05:27:23 -07:00
placeholder : 'Add option' ,
2020-08-11 13:07:23 -07:00
default : { } ,
displayOptions : {
show : {
2022-08-17 08:50:24 -07:00
operation : [ 'get' ] ,
resource : [ 'playlist' ] ,
2020-08-11 13:07:23 -07:00
} ,
} ,
options : [
{
displayName : 'On Behalf Of Content Owner' ,
name : 'onBehalfOfContentOwner' ,
type : 'string' ,
default : '' ,
2022-08-17 08:50:24 -07:00
description :
"The onBehalfOfContentOwner parameter indicates that the request's authorization credentials identify a YouTube CMS user who is acting on behalf of the content owner specified in the parameter value" ,
2020-08-11 13:07:23 -07:00
} ,
{
displayName : 'On Behalf Of Content Owner Channel' ,
name : 'onBehalfOfContentOwnerChannel' ,
type : 'string' ,
default : '' ,
2022-08-17 08:50:24 -07:00
description :
'The onBehalfOfContentOwnerChannel parameter specifies the YouTube channel ID of the channel to which a video is being added' ,
2020-08-11 13:07:23 -07:00
} ,
] ,
} ,
/* -------------------------------------------------------------------------- */
2020-08-09 14:39:28 -07:00
/* playlist:delete */
/* -------------------------------------------------------------------------- */
{
displayName : 'Playlist ID' ,
name : 'playlistId' ,
type : 'string' ,
required : true ,
displayOptions : {
show : {
2022-08-17 08:50:24 -07:00
operation : [ 'delete' ] ,
resource : [ 'playlist' ] ,
2020-08-09 14:39:28 -07:00
} ,
} ,
default : '' ,
} ,
{
displayName : 'Options' ,
name : 'options' ,
type : 'collection' ,
2024-07-29 05:27:23 -07:00
placeholder : 'Add option' ,
2020-08-09 14:39:28 -07:00
default : { } ,
displayOptions : {
show : {
2022-08-17 08:50:24 -07:00
operation : [ 'delete' ] ,
resource : [ 'playlist' ] ,
2020-08-09 14:39:28 -07:00
} ,
} ,
options : [
{
displayName : 'On Behalf Of Content Owner' ,
name : 'onBehalfOfContentOwner' ,
type : 'string' ,
default : '' ,
2022-08-17 08:50:24 -07:00
description :
"The onBehalfOfContentOwner parameter indicates that the request's authorization credentials identify a YouTube CMS user who is acting on behalf of the content owner specified in the parameter value" ,
2020-08-09 14:39:28 -07:00
} ,
] ,
} ,
/* -------------------------------------------------------------------------- */
/* playlist:getAll */
/* -------------------------------------------------------------------------- */
{
displayName : 'Fields' ,
name : 'part' ,
type : 'multiOptions' ,
options : [
2020-08-14 15:36:47 -07:00
{
name : '*' ,
value : '*' ,
} ,
2020-08-09 14:39:28 -07:00
{
name : 'Content Details' ,
value : 'contentDetails' ,
} ,
{
name : 'ID' ,
value : 'id' ,
} ,
{
name : 'Localizations' ,
value : 'localizations' ,
} ,
{
name : 'Player' ,
value : 'player' ,
} ,
{
name : 'Snippet' ,
value : 'snippet' ,
} ,
{
name : 'Status' ,
value : 'status' ,
} ,
] ,
required : true ,
displayOptions : {
show : {
2022-08-17 08:50:24 -07:00
operation : [ 'getAll' ] ,
resource : [ 'playlist' ] ,
2020-08-09 14:39:28 -07:00
} ,
} ,
2022-08-17 08:50:24 -07:00
description :
'The fields parameter specifies a comma-separated list of one or more playlist resource properties that the API response will include' ,
2020-08-15 19:36:11 -07:00
default : [ '*' ] ,
2020-08-09 14:39:28 -07:00
} ,
{
displayName : 'Return All' ,
name : 'returnAll' ,
type : 'boolean' ,
displayOptions : {
show : {
2022-08-17 08:50:24 -07:00
operation : [ 'getAll' ] ,
resource : [ 'playlist' ] ,
2020-08-09 14:39:28 -07:00
} ,
} ,
default : false ,
2022-05-06 14:01:25 -07:00
description : 'Whether to return all results or only up to a given limit' ,
2020-08-09 14:39:28 -07:00
} ,
{
displayName : 'Limit' ,
name : 'limit' ,
type : 'number' ,
displayOptions : {
show : {
2022-08-17 08:50:24 -07:00
operation : [ 'getAll' ] ,
resource : [ 'playlist' ] ,
returnAll : [ false ] ,
2020-08-09 14:39:28 -07:00
} ,
} ,
typeOptions : {
minValue : 1 ,
2020-08-14 15:36:47 -07:00
maxValue : 50 ,
2020-08-09 14:39:28 -07:00
} ,
2020-08-14 15:36:47 -07:00
default : 25 ,
2022-05-06 14:01:25 -07:00
description : 'Max number of results to return' ,
2020-08-09 14:39:28 -07:00
} ,
{
displayName : 'Filters' ,
name : 'filters' ,
type : 'collection' ,
2024-07-29 05:27:23 -07:00
placeholder : 'Add option' ,
2020-08-09 14:39:28 -07:00
default : { } ,
displayOptions : {
show : {
2022-08-17 08:50:24 -07:00
operation : [ 'getAll' ] ,
resource : [ 'playlist' ] ,
2020-08-09 14:39:28 -07:00
} ,
} ,
options : [
{
displayName : 'Channel ID' ,
name : 'channelId' ,
type : 'string' ,
default : '' ,
2022-08-17 08:50:24 -07:00
description :
"This value indicates that the API should only return the specified channel's playlists" ,
2020-08-09 14:39:28 -07:00
} ,
{
displayName : 'ID' ,
name : 'id' ,
type : 'string' ,
default : '' ,
2022-08-17 08:50:24 -07:00
description :
"The ID parameter specifies a comma-separated list of the YouTube playlist ID(s) for the resource(s) that are being retrieved. In a playlist resource, the ID property specifies the playlist's YouTube playlist ID." ,
2020-08-09 14:39:28 -07:00
} ,
] ,
} ,
{
displayName : 'Options' ,
name : 'options' ,
type : 'collection' ,
2024-07-29 05:27:23 -07:00
placeholder : 'Add option' ,
2020-08-09 14:39:28 -07:00
default : { } ,
displayOptions : {
show : {
2022-08-17 08:50:24 -07:00
operation : [ 'getAll' ] ,
resource : [ 'playlist' ] ,
2020-08-09 14:39:28 -07:00
} ,
} ,
options : [
{
displayName : 'On Behalf Of Content Owner Channel' ,
name : 'onBehalfOfContentOwnerChannel' ,
type : 'string' ,
default : '' ,
2022-08-17 08:50:24 -07:00
description :
'The onBehalfOfContentOwnerChannel parameter specifies the YouTube channel ID of the channel to which a video is being added. This parameter is required when a request specifies a value for the onBehalfOfContentOwner parameter, and it can only be used in conjunction with that parameter.' ,
2020-08-09 14:39:28 -07:00
} ,
{
displayName : 'On Behalf Of Content Owner' ,
name : 'onBehalfOfContentOwner' ,
type : 'string' ,
default : '' ,
2022-08-17 08:50:24 -07:00
description :
"The onBehalfOfContentOwner parameter indicates that the request's authorization credentials identify a YouTube CMS user who is acting on behalf of the content owner specified in the parameter value" ,
2020-08-09 14:39:28 -07:00
} ,
] ,
} ,
/* -------------------------------------------------------------------------- */
/* playlist:update */
/* -------------------------------------------------------------------------- */
{
displayName : 'Playlist ID' ,
name : 'playlistId' ,
type : 'string' ,
required : true ,
displayOptions : {
show : {
2022-08-17 08:50:24 -07:00
operation : [ 'update' ] ,
resource : [ 'playlist' ] ,
2020-08-09 14:39:28 -07:00
} ,
} ,
default : '' ,
2022-08-17 08:50:24 -07:00
description : "The playlist's title" ,
2020-08-09 14:39:28 -07:00
} ,
2020-08-11 13:07:23 -07:00
{
displayName : 'Title' ,
name : 'title' ,
type : 'string' ,
required : true ,
displayOptions : {
show : {
2022-08-17 08:50:24 -07:00
operation : [ 'update' ] ,
resource : [ 'playlist' ] ,
2020-08-11 13:07:23 -07:00
} ,
} ,
default : '' ,
2022-08-17 08:50:24 -07:00
description : "The playlist's title" ,
2020-08-11 13:07:23 -07:00
} ,
2020-08-09 14:39:28 -07:00
{
displayName : 'Update Fields' ,
name : 'updateFields' ,
type : 'collection' ,
placeholder : 'Add Field' ,
default : { } ,
displayOptions : {
show : {
2022-08-17 08:50:24 -07:00
operation : [ 'update' ] ,
resource : [ 'playlist' ] ,
2020-08-09 14:39:28 -07:00
} ,
} ,
options : [
2020-08-11 13:07:23 -07:00
{
2022-06-03 10:23:49 -07:00
displayName : 'Default Language Name or ID' ,
2020-08-11 13:07:23 -07:00
name : 'defaultLanguage' ,
type : 'options' ,
typeOptions : {
loadOptionsMethod : 'getLanguages' ,
} ,
default : '' ,
2022-08-17 08:50:24 -07:00
description :
'The language of the text in the playlist resource\'s title and description properties. Choose from the list, or specify an ID using an <a href="https://docs.n8n.io/code-examples/expressions/">expression</a>.' ,
2020-08-11 13:07:23 -07:00
} ,
2020-08-09 14:39:28 -07:00
{
displayName : 'Description' ,
name : 'description' ,
type : 'string' ,
default : '' ,
2022-08-17 08:50:24 -07:00
description : "The playlist's description" ,
2020-08-09 14:39:28 -07:00
} ,
2020-08-11 13:07:23 -07:00
{
displayName : 'On Behalf Of Content Owner' ,
name : 'onBehalfOfContentOwner' ,
type : 'string' ,
default : '' ,
2022-08-17 08:50:24 -07:00
description :
"The onBehalfOfContentOwner parameter indicates that the request's authorization credentials identify a YouTube CMS user who is acting on behalf of the content owner specified in the parameter value" ,
2020-08-11 13:07:23 -07:00
} ,
2020-08-09 14:39:28 -07:00
{
displayName : 'Privacy Status' ,
name : 'privacyStatus' ,
type : 'options' ,
options : [
{
name : 'Private' ,
value : 'private' ,
} ,
{
name : 'Public' ,
value : 'public' ,
} ,
{
name : 'Unlisted' ,
2020-11-18 14:30:43 -08:00
value : 'unlisted' ,
2020-08-09 14:39:28 -07:00
} ,
] ,
default : '' ,
2022-08-17 08:50:24 -07:00
description : "The playlist's privacy status" ,
2020-08-09 14:39:28 -07:00
} ,
{
displayName : 'Tags' ,
name : 'tags' ,
type : 'string' ,
default : '' ,
2022-08-17 08:50:24 -07:00
description :
'Keyword tags associated with the playlist. Mulplie can be defined separated by comma.' ,
2020-08-09 14:39:28 -07:00
} ,
] ,
} ,
2021-12-03 00:44:16 -08:00
] ;