/** * Google Drive Node - Version 1 * Discriminator: resource=folder, operation=share */ interface Credentials { googleApi: CredentialReference; googleDriveOAuth2Api: CredentialReference; } /** Share a file */ export type GoogleDriveV1FolderShareParams = { resource: 'folder'; operation: 'share'; /** * Authentication * @default serviceAccount */ authentication?: 'serviceAccount' | 'oAuth2' | Expression; /** * The ID of the folder * @default {"mode":"list","value":""} */ fileId?: { __rl: true; mode: 'list' | 'url' | 'id'; value: string; cachedResultName?: string }; /** * Permissions * @default {} */ permissionsUi?: { /** Permission */ permissionsValues?: { /** Role */ role?: 'commenter' | 'fileOrganizer' | 'organizer' | 'owner' | 'reader' | 'writer' | Expression; /** Information about the different types can be found <a href="https://developers.google.com/drive/api/v3/ref-roles">here</a> */ type?: 'user' | 'group' | 'domain' | 'anyone' | Expression; /** The email address of the user or group to which this permission refers * @displayOptions.show { type: ["user", "group"] } */ emailAddress?: string | Expression | PlaceholderValue; /** The domain to which this permission refers * @displayOptions.show { type: ["domain"] } */ domain?: string | Expression | PlaceholderValue; /** Whether the permission allows the file to be discovered through search * @displayOptions.show { type: ["domain", "anyone"] } * @default false */ allowFileDiscovery?: boolean | Expression; }; }; /** * Options * @default {} */ options?: { /** A plain text custom message to include in the notification email */ emailMessage?: string | Expression | PlaceholderValue; /** Whether to opt in to API behavior that aims for all items to have exactly one parent. This parameter only takes effect if the item is not in a shared drive. * @default false */ enforceSingleParent?: boolean | Expression; /** The fields to return * @displayOptions.show { /operation: ["list", "copy"] } * @default [] */ fields?: Array<'*' | 'explicitlyTrashed' | 'exportLinks' | 'hasThumbnail' | 'iconLink' | 'id' | 'kind' | 'mimeType' | 'name' | 'permissions' | 'shared' | 'spaces' | 'starred' | 'thumbnailLink' | 'trashed' | 'version' | 'webViewLink'>; /** <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> * @default false */ moveToNewOwnersRoot?: boolean | Expression; /** Whether to send a notification email when sharing to users or groups * @default false */ sendNotificationEmail?: boolean | Expression; /** Whether the requesting application supports both My Drives and shared drives * @default false */ supportsAllDrives?: boolean | Expression; /** Whether to transfer ownership to the specified user and downgrade the current owner to a writer * @default false */ transferOwnership?: boolean | Expression; /** 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. * @default false */ useDomainAdminAccess?: boolean | Expression; /** The name the file should be saved as * @displayOptions.show { /operation: ["copy"], /resource: ["file"] } */ name?: string | Expression | PlaceholderValue; /** The IDs of the parent folders the file/folder should be saved in * @displayOptions.show { /operation: ["copy", "create"] } * @default [] */ parents?: string | Expression | PlaceholderValue; /** The spaces to operate on * @displayOptions.show { /operation: ["list"], /resource: ["file"] } * @default [] */ spaces?: Array<'*' | 'appDataFolder' | 'drive' | 'photos'>; /** The corpora to operate on * @displayOptions.show { /operation: ["list"], /resource: ["file"] } */ corpora?: 'user' | 'domain' | 'drive' | 'allDrives' | Expression; /** ID of the shared drive to search. The driveId parameter must be specified if and only if corpora is set to drive. * @displayOptions.show { /operation: ["list"], /resource: ["file"], corpora: ["drive"] } */ driveId?: string | Expression | PlaceholderValue; }; }; export type GoogleDriveV1FolderShareNode = { type: 'n8n-nodes-base.googleDrive'; version: 1; credentials?: Credentials; config: NodeConfig; };