mirror of
https://github.com/n8n-io/n8n.git
synced 2024-12-28 22:19:41 -08:00
615 lines
13 KiB
TypeScript
615 lines
13 KiB
TypeScript
import type { INodeProperties } from 'n8n-workflow';
|
|
import { DRIVE, RLC_DRIVE_DEFAULT } from '../helpers/interfaces';
|
|
import { GOOGLE_DRIVE_FILE_URL_REGEX, GOOGLE_DRIVE_FOLDER_URL_REGEX } from '../../../constants';
|
|
|
|
export const fileRLC: INodeProperties = {
|
|
displayName: 'File',
|
|
name: 'fileId',
|
|
type: 'resourceLocator',
|
|
default: { mode: 'list', value: '' },
|
|
required: true,
|
|
modes: [
|
|
{
|
|
displayName: 'File',
|
|
name: 'list',
|
|
type: 'list',
|
|
placeholder: 'Select a file...',
|
|
typeOptions: {
|
|
searchListMethod: 'fileSearch',
|
|
searchable: true,
|
|
},
|
|
},
|
|
{
|
|
displayName: 'Link',
|
|
name: 'url',
|
|
type: 'string',
|
|
placeholder:
|
|
'e.g. https://drive.google.com/file/d/1anGBg0b5re2VtF2bKu201_a-Vnz5BHq9Y4r-yBDAj5A/edit',
|
|
extractValue: {
|
|
type: 'regex',
|
|
regex: GOOGLE_DRIVE_FILE_URL_REGEX,
|
|
},
|
|
validation: [
|
|
{
|
|
type: 'regex',
|
|
properties: {
|
|
regex: GOOGLE_DRIVE_FILE_URL_REGEX,
|
|
errorMessage: 'Not a valid Google Drive File URL',
|
|
},
|
|
},
|
|
],
|
|
},
|
|
{
|
|
displayName: 'ID',
|
|
name: 'id',
|
|
type: 'string',
|
|
placeholder: 'e.g. 1anGBg0b5re2VtF2bKu201_a-Vnz5BHq9Y4r-yBDAj5A',
|
|
validation: [
|
|
{
|
|
type: 'regex',
|
|
properties: {
|
|
regex: '[a-zA-Z0-9\\-_]{2,}',
|
|
errorMessage: 'Not a valid Google Drive File ID',
|
|
},
|
|
},
|
|
],
|
|
url: '=https://drive.google.com/file/d/{{$value}}/view',
|
|
},
|
|
],
|
|
description: 'The file to operate on',
|
|
};
|
|
|
|
export const folderNoRootRLC: INodeProperties = {
|
|
displayName: 'Folder',
|
|
name: 'folderNoRootId',
|
|
type: 'resourceLocator',
|
|
default: { mode: 'list', value: '' },
|
|
required: true,
|
|
modes: [
|
|
{
|
|
displayName: 'Folder',
|
|
name: 'list',
|
|
type: 'list',
|
|
placeholder: 'Select a folder...',
|
|
typeOptions: {
|
|
searchListMethod: 'folderSearch',
|
|
searchable: true,
|
|
},
|
|
},
|
|
{
|
|
displayName: 'Link',
|
|
name: 'url',
|
|
type: 'string',
|
|
placeholder: 'e.g. https://drive.google.com/drive/folders/1Tx9WHbA3wBpPB4C_HcoZDH9WZFWYxAMU',
|
|
extractValue: {
|
|
type: 'regex',
|
|
regex: GOOGLE_DRIVE_FOLDER_URL_REGEX,
|
|
},
|
|
validation: [
|
|
{
|
|
type: 'regex',
|
|
properties: {
|
|
regex: GOOGLE_DRIVE_FOLDER_URL_REGEX,
|
|
errorMessage: 'Not a valid Google Drive Folder URL',
|
|
},
|
|
},
|
|
],
|
|
},
|
|
{
|
|
displayName: 'ID',
|
|
name: 'id',
|
|
type: 'string',
|
|
placeholder: 'e.g. 1anGBg0b5re2VtF2bKu201_a-Vnz5BHq9Y4r-yBDAj5A',
|
|
validation: [
|
|
{
|
|
type: 'regex',
|
|
properties: {
|
|
regex: '[a-zA-Z0-9\\-_]{2,}',
|
|
errorMessage: 'Not a valid Google Drive Folder ID',
|
|
},
|
|
},
|
|
],
|
|
url: '=https://drive.google.com/drive/folders/{{$value}}',
|
|
},
|
|
],
|
|
description: 'The folder to operate on',
|
|
};
|
|
|
|
export const folderRLC: INodeProperties = {
|
|
displayName: 'Folder',
|
|
name: 'folderId',
|
|
type: 'resourceLocator',
|
|
default: { mode: 'list', value: 'root', cachedResultName: '/ (Root folder)' },
|
|
required: true,
|
|
modes: [
|
|
{
|
|
displayName: 'Folder',
|
|
name: 'list',
|
|
type: 'list',
|
|
placeholder: 'Select a folder...',
|
|
typeOptions: {
|
|
searchListMethod: 'folderSearchWithDefault',
|
|
searchable: true,
|
|
},
|
|
},
|
|
{
|
|
displayName: 'Link',
|
|
name: 'url',
|
|
type: 'string',
|
|
placeholder: 'e.g. https://drive.google.com/drive/folders/1Tx9WHbA3wBpPB4C_HcoZDH9WZFWYxAMU',
|
|
extractValue: {
|
|
type: 'regex',
|
|
regex: GOOGLE_DRIVE_FOLDER_URL_REGEX,
|
|
},
|
|
validation: [
|
|
{
|
|
type: 'regex',
|
|
properties: {
|
|
regex: GOOGLE_DRIVE_FOLDER_URL_REGEX,
|
|
errorMessage: 'Not a valid Google Drive Folder URL',
|
|
},
|
|
},
|
|
],
|
|
},
|
|
{
|
|
displayName: 'ID',
|
|
name: 'id',
|
|
type: 'string',
|
|
placeholder: 'e.g. 1anGBg0b5re2VtF2bKu201_a-Vnz5BHq9Y4r-yBDAj5A',
|
|
validation: [
|
|
{
|
|
type: 'regex',
|
|
properties: {
|
|
regex: '[a-zA-Z0-9\\-_]{2,}',
|
|
errorMessage: 'Not a valid Google Drive Folder ID',
|
|
},
|
|
},
|
|
],
|
|
url: '=https://drive.google.com/drive/folders/{{$value}}',
|
|
},
|
|
],
|
|
description: 'The folder to operate on',
|
|
};
|
|
|
|
export const driveRLC: INodeProperties = {
|
|
displayName: 'Drive',
|
|
name: 'driveId',
|
|
type: 'resourceLocator',
|
|
default: { mode: 'list', value: RLC_DRIVE_DEFAULT },
|
|
required: true,
|
|
modes: [
|
|
{
|
|
displayName: 'Drive',
|
|
name: 'list',
|
|
type: 'list',
|
|
placeholder: 'Select a drive...',
|
|
typeOptions: {
|
|
searchListMethod: 'driveSearchWithDefault',
|
|
searchable: true,
|
|
},
|
|
},
|
|
{
|
|
displayName: 'Link',
|
|
name: 'url',
|
|
type: 'string',
|
|
placeholder: 'https://drive.google.com/drive/folders/0AaaaaAAAAAAAaa',
|
|
extractValue: {
|
|
type: 'regex',
|
|
regex: GOOGLE_DRIVE_FOLDER_URL_REGEX,
|
|
},
|
|
validation: [
|
|
{
|
|
type: 'regex',
|
|
properties: {
|
|
regex: GOOGLE_DRIVE_FOLDER_URL_REGEX,
|
|
errorMessage: 'Not a valid Google Drive Drive URL',
|
|
},
|
|
},
|
|
],
|
|
},
|
|
{
|
|
displayName: 'ID',
|
|
name: 'id',
|
|
type: 'string',
|
|
hint: 'The ID of the shared drive',
|
|
validation: [
|
|
{
|
|
type: 'regex',
|
|
properties: {
|
|
regex: '[a-zA-Z0-9\\-_]{2,}',
|
|
errorMessage: 'Not a valid Google Drive Drive ID',
|
|
},
|
|
},
|
|
],
|
|
url: '=https://drive.google.com/drive/folders/{{$value}}',
|
|
},
|
|
],
|
|
description: 'The ID of the drive',
|
|
};
|
|
|
|
export const sharedDriveRLC: INodeProperties = {
|
|
displayName: 'Shared Drive',
|
|
name: 'driveId',
|
|
type: 'resourceLocator',
|
|
default: { mode: 'list', value: '' },
|
|
required: true,
|
|
modes: [
|
|
{
|
|
displayName: 'Drive',
|
|
name: 'list',
|
|
type: 'list',
|
|
placeholder: 'Select a shared drive...',
|
|
typeOptions: {
|
|
searchListMethod: 'driveSearch',
|
|
searchable: true,
|
|
},
|
|
},
|
|
{
|
|
displayName: 'Link',
|
|
name: 'url',
|
|
type: 'string',
|
|
placeholder: 'e.g. https://drive.google.com/drive/u/1/folders/0AIjtcbwnjtcbwn9PVA',
|
|
extractValue: {
|
|
type: 'regex',
|
|
regex: GOOGLE_DRIVE_FOLDER_URL_REGEX,
|
|
},
|
|
validation: [
|
|
{
|
|
type: 'regex',
|
|
properties: {
|
|
regex: GOOGLE_DRIVE_FOLDER_URL_REGEX,
|
|
errorMessage: 'Not a valid Google Drive Drive URL',
|
|
},
|
|
},
|
|
],
|
|
},
|
|
{
|
|
displayName: 'ID',
|
|
name: 'id',
|
|
type: 'string',
|
|
// hint: 'The ID of the shared drive',
|
|
placeholder: 'e.g. 0AMXTKI5ZSiM7Uk9PVA',
|
|
validation: [
|
|
{
|
|
type: 'regex',
|
|
properties: {
|
|
regex: '[a-zA-Z0-9\\-_]{2,}',
|
|
errorMessage: 'Not a valid Google Drive Drive ID',
|
|
},
|
|
},
|
|
],
|
|
url: '=https://drive.google.com/drive/folders/{{$value}}',
|
|
},
|
|
],
|
|
description: 'The shared drive to operate on',
|
|
};
|
|
|
|
export const shareOptions: INodeProperties = {
|
|
displayName: 'Options',
|
|
name: 'options',
|
|
type: 'collection',
|
|
placeholder: 'Add Option',
|
|
default: {},
|
|
options: [
|
|
{
|
|
displayName: 'Email Message',
|
|
name: 'emailMessage',
|
|
type: 'string',
|
|
default: '',
|
|
description: 'A plain text custom message to include in the notification email',
|
|
typeOptions: {
|
|
rows: 2,
|
|
},
|
|
},
|
|
{
|
|
displayName: 'Move To New Owners Root',
|
|
name: 'moveToNewOwnersRoot',
|
|
type: 'boolean',
|
|
default: false,
|
|
// eslint-disable-next-line n8n-nodes-base/node-param-description-boolean-without-whether
|
|
description:
|
|
"<p>This parameter only takes effect if the item is not in a shared drive and the request is attempting to transfer the ownership of the item.</p><p>When set to true, the item is moved to the new owner's My Drive root folder and all prior parents removed.</p>",
|
|
},
|
|
{
|
|
displayName: 'Send Notification Email',
|
|
name: 'sendNotificationEmail',
|
|
type: 'boolean',
|
|
default: false,
|
|
description: 'Whether to send a notification email when sharing to users or groups',
|
|
},
|
|
{
|
|
displayName: 'Transfer Ownership',
|
|
name: 'transferOwnership',
|
|
type: 'boolean',
|
|
default: false,
|
|
description:
|
|
'Whether to transfer ownership to the specified user and downgrade the current owner to a writer',
|
|
},
|
|
{
|
|
displayName: 'Use Domain Admin Access',
|
|
name: 'useDomainAdminAccess',
|
|
type: 'boolean',
|
|
default: false,
|
|
description:
|
|
'Whether to perform the operation as domain administrator, i.e. if you are an administrator of the domain to which the shared drive belongs, you will be granted access automatically.',
|
|
},
|
|
],
|
|
};
|
|
|
|
export const permissionsOptions: INodeProperties = {
|
|
displayName: 'Permissions',
|
|
name: 'permissionsUi',
|
|
placeholder: 'Add Permission',
|
|
type: 'fixedCollection',
|
|
default: {},
|
|
typeOptions: {
|
|
multipleValues: false,
|
|
},
|
|
options: [
|
|
{
|
|
displayName: 'Permission',
|
|
name: 'permissionsValues',
|
|
values: [
|
|
{
|
|
displayName: 'Role',
|
|
name: 'role',
|
|
type: 'options',
|
|
description: 'Defines what users can do with the file or folder',
|
|
options: [
|
|
{
|
|
name: 'Commenter',
|
|
value: 'commenter',
|
|
},
|
|
{
|
|
name: 'File Organizer',
|
|
value: 'fileOrganizer',
|
|
},
|
|
{
|
|
name: 'Organizer',
|
|
value: 'organizer',
|
|
},
|
|
{
|
|
name: 'Owner',
|
|
value: 'owner',
|
|
},
|
|
{
|
|
name: 'Reader',
|
|
value: 'reader',
|
|
},
|
|
{
|
|
name: 'Writer',
|
|
value: 'writer',
|
|
},
|
|
],
|
|
default: '',
|
|
},
|
|
{
|
|
displayName: 'Type',
|
|
name: 'type',
|
|
type: 'options',
|
|
options: [
|
|
{
|
|
name: 'User',
|
|
value: 'user',
|
|
},
|
|
{
|
|
name: 'Group',
|
|
value: 'group',
|
|
},
|
|
{
|
|
name: 'Domain',
|
|
value: 'domain',
|
|
},
|
|
{
|
|
name: 'Anyone',
|
|
value: 'anyone',
|
|
},
|
|
],
|
|
default: '',
|
|
description:
|
|
'The scope of the permission. A permission with type=user applies to a specific user whereas a permission with type=domain applies to everyone in a specific domain.',
|
|
},
|
|
{
|
|
displayName: 'Email Address',
|
|
name: 'emailAddress',
|
|
type: 'string',
|
|
displayOptions: {
|
|
show: {
|
|
type: ['user', 'group'],
|
|
},
|
|
},
|
|
placeholder: '“e.g. name@mail.com',
|
|
default: '',
|
|
description: 'The email address of the user or group to which this permission refers',
|
|
},
|
|
{
|
|
displayName: 'Domain',
|
|
name: 'domain',
|
|
type: 'string',
|
|
displayOptions: {
|
|
show: {
|
|
type: ['domain'],
|
|
},
|
|
},
|
|
placeholder: 'e.g. mycompany.com',
|
|
default: '',
|
|
description: 'The domain to which this permission refers',
|
|
},
|
|
{
|
|
displayName: 'Allow File Discovery',
|
|
name: 'allowFileDiscovery',
|
|
type: 'boolean',
|
|
displayOptions: {
|
|
show: {
|
|
type: ['domain', 'anyone'],
|
|
},
|
|
},
|
|
default: false,
|
|
description: 'Whether to allow the file to be discovered through search',
|
|
},
|
|
],
|
|
},
|
|
],
|
|
};
|
|
|
|
export const updateCommonOptions: INodeProperties[] = [
|
|
{
|
|
displayName: 'APP Properties',
|
|
name: 'appPropertiesUi',
|
|
placeholder: 'Add Property',
|
|
type: 'fixedCollection',
|
|
default: {},
|
|
typeOptions: {
|
|
multipleValues: true,
|
|
},
|
|
description:
|
|
'A collection of arbitrary key-value pairs which are private to the requesting app',
|
|
options: [
|
|
{
|
|
name: 'appPropertyValues',
|
|
displayName: 'APP Property',
|
|
values: [
|
|
{
|
|
displayName: 'Key',
|
|
name: 'key',
|
|
type: 'string',
|
|
default: '',
|
|
description: 'Name of the key to add',
|
|
},
|
|
{
|
|
displayName: 'Value',
|
|
name: 'value',
|
|
type: 'string',
|
|
default: '',
|
|
description: 'Value to set for the key',
|
|
},
|
|
],
|
|
},
|
|
],
|
|
},
|
|
{
|
|
displayName: 'Properties',
|
|
name: 'propertiesUi',
|
|
placeholder: 'Add Property',
|
|
type: 'fixedCollection',
|
|
default: {},
|
|
typeOptions: {
|
|
multipleValues: true,
|
|
},
|
|
description: 'A collection of arbitrary key-value pairs which are visible to all apps',
|
|
options: [
|
|
{
|
|
name: 'propertyValues',
|
|
displayName: 'Property',
|
|
values: [
|
|
{
|
|
displayName: 'Key',
|
|
name: 'key',
|
|
type: 'string',
|
|
default: '',
|
|
description: 'Name of the key to add',
|
|
},
|
|
{
|
|
displayName: 'Value',
|
|
name: 'value',
|
|
type: 'string',
|
|
default: '',
|
|
description: 'Value to set for the key',
|
|
},
|
|
],
|
|
},
|
|
],
|
|
},
|
|
{
|
|
displayName: 'Keep Revision Forever',
|
|
name: 'keepRevisionForever',
|
|
type: 'boolean',
|
|
default: false,
|
|
description:
|
|
"Whether to set the 'keepForever' field in the new head revision. This is only applicable to files with binary content in Google Drive. Only 200 revisions for the file can be kept forever. If the limit is reached, try deleting pinned revisions.",
|
|
},
|
|
{
|
|
displayName: 'OCR Language',
|
|
name: 'ocrLanguage',
|
|
type: 'string',
|
|
default: '',
|
|
placeholder: 'e.g. en',
|
|
description: 'A language hint for OCR processing during image import (ISO 639-1 code)',
|
|
},
|
|
{
|
|
displayName: 'Use Content As Indexable Text',
|
|
name: 'useContentAsIndexableText',
|
|
type: 'boolean',
|
|
default: false,
|
|
description: 'Whether to use the uploaded content as indexable text',
|
|
},
|
|
];
|
|
|
|
export const fileTypesOptions = [
|
|
{
|
|
name: 'All',
|
|
value: '*',
|
|
description: 'Return all file types',
|
|
},
|
|
{
|
|
name: '3rd Party Shortcut',
|
|
value: DRIVE.SDK,
|
|
},
|
|
{
|
|
name: 'Audio',
|
|
value: DRIVE.AUDIO,
|
|
},
|
|
{
|
|
name: 'Folder',
|
|
value: DRIVE.FOLDER,
|
|
},
|
|
{
|
|
name: 'Google Apps Scripts',
|
|
value: DRIVE.APP_SCRIPTS,
|
|
},
|
|
{
|
|
name: 'Google Docs',
|
|
value: DRIVE.DOCUMENT,
|
|
},
|
|
{
|
|
name: 'Google Drawing',
|
|
value: DRIVE.DRAWING,
|
|
},
|
|
{
|
|
name: 'Google Forms',
|
|
value: DRIVE.FORM,
|
|
},
|
|
{
|
|
name: 'Google Fusion Tables',
|
|
value: DRIVE.FUSIONTABLE,
|
|
},
|
|
{
|
|
name: 'Google My Maps',
|
|
value: DRIVE.MAP,
|
|
},
|
|
{
|
|
name: 'Google Sheets',
|
|
value: DRIVE.SPREADSHEET,
|
|
},
|
|
{
|
|
name: 'Google Sites',
|
|
value: DRIVE.SITES,
|
|
},
|
|
{
|
|
name: 'Google Slides',
|
|
value: DRIVE.PRESENTATION,
|
|
},
|
|
{
|
|
name: 'Photo',
|
|
value: DRIVE.PHOTO,
|
|
},
|
|
{
|
|
name: 'Unknown',
|
|
value: DRIVE.UNKNOWN,
|
|
},
|
|
{
|
|
name: 'Video',
|
|
value: DRIVE.VIDEO,
|
|
},
|
|
];
|