/** * Google Drive Node - Version 1 * Discriminator: resource=file, operation=upload */ interface Credentials { googleApi: CredentialReference; googleDriveOAuth2Api: CredentialReference; } /** Upload a file */ export type GoogleDriveV1FileUploadParams = { resource: 'file'; operation: 'upload'; /** * Authentication * @default serviceAccount */ authentication?: 'serviceAccount' | 'oAuth2' | Expression; /** * Whether the data to upload should be taken from binary field * @default false */ binaryData?: boolean | Expression; /** * The text content of the file to upload * @displayOptions.show { binaryData: [false] } */ fileContent?: string | Expression | PlaceholderValue; /** * Input Binary Field * @hint The name of the input binary field containing the file to be uploaded * @displayOptions.show { binaryData: [true] } * @default data */ binaryPropertyName?: string | Expression | PlaceholderValue; /** * The name the file should be saved as */ name?: string | Expression | PlaceholderValue; /** * By default the response only contain the ID of the file. If this option gets activated, it will resolve the data automatically. * @default false */ resolveData?: boolean | Expression; /** * The IDs of the parent folders which contain the file * @default [] */ parents?: string | Expression | PlaceholderValue; /** * Options * @displayOptions.show { /operation: ["copy", "list", "share", "create"] } * @default {} */ options?: { /** A plain text custom message to include in the notification email * @displayOptions.show { /operation: ["share"] } */ 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. * @displayOptions.show { /operation: ["share"] } * @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> * @displayOptions.show { /operation: ["share"] } * @default false */ moveToNewOwnersRoot?: boolean | Expression; /** Whether to send a notification email when sharing to users or groups * @displayOptions.show { /operation: ["share"] } * @default false */ sendNotificationEmail?: boolean | Expression; /** Whether the requesting application supports both My Drives and shared drives * @displayOptions.show { /operation: ["share"] } * @default false */ supportsAllDrives?: boolean | Expression; /** Whether to transfer ownership to the specified user and downgrade the current owner to a writer * @displayOptions.show { /operation: ["share"] } * @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. * @displayOptions.show { /operation: ["share"] } * @default false */ useDomainAdminAccess?: boolean | Expression; /** The name the file should be saved as * @displayOptions.show { /operation: ["copy"] } */ 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"] } * @default [] */ spaces?: Array<'*' | 'appDataFolder' | 'drive' | 'photos'>; /** The corpora to operate on * @displayOptions.show { /operation: ["list"] } */ 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"], corpora: ["drive"] } */ driveId?: string | Expression | PlaceholderValue; }; }; export type GoogleDriveV1FileUploadNode = { type: 'n8n-nodes-base.googleDrive'; version: 1; credentials?: Credentials; config: NodeConfig; };