mirror of
https://github.com/Abdulazizzn/n8n-enterprise-unlocked.git
synced 2025-12-16 17:46:45 +00:00
95 lines
2.2 KiB
TypeScript
95 lines
2.2 KiB
TypeScript
import type { IExecuteFunctions, INodeExecutionData } from 'n8n-workflow';
|
|
import type { SpreadSheetProperties } from '../../helpers/GoogleSheets.types';
|
|
import { apiRequest } from '../../transport';
|
|
import { GOOGLE_DRIVE_FILE_URL_REGEX } from '../../../../constants';
|
|
import { wrapData } from '../../../../../../utils/utilities';
|
|
|
|
export const description: SpreadSheetProperties = [
|
|
{
|
|
displayName: 'Document',
|
|
name: 'documentId',
|
|
type: 'resourceLocator',
|
|
default: { mode: 'list', value: '' },
|
|
required: true,
|
|
modes: [
|
|
{
|
|
displayName: 'From List',
|
|
name: 'list',
|
|
type: 'list',
|
|
typeOptions: {
|
|
searchListMethod: 'spreadSheetsSearch',
|
|
searchable: true,
|
|
},
|
|
},
|
|
{
|
|
displayName: 'By URL',
|
|
name: 'url',
|
|
type: 'string',
|
|
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: 'By ID',
|
|
name: 'id',
|
|
type: 'string',
|
|
validation: [
|
|
{
|
|
type: 'regex',
|
|
properties: {
|
|
regex: '[a-zA-Z0-9\\-_]{2,}',
|
|
errorMessage: 'Not a valid Google Drive File ID',
|
|
},
|
|
},
|
|
],
|
|
url: '=https://docs.google.com/spreadsheets/d/{{$value}}/edit',
|
|
},
|
|
],
|
|
displayOptions: {
|
|
show: {
|
|
resource: ['spreadsheet'],
|
|
operation: ['deleteSpreadsheet'],
|
|
},
|
|
},
|
|
},
|
|
];
|
|
|
|
export async function execute(this: IExecuteFunctions): Promise<INodeExecutionData[]> {
|
|
const items = this.getInputData();
|
|
const returnData: INodeExecutionData[] = [];
|
|
|
|
for (let i = 0; i < items.length; i++) {
|
|
// const spreadsheetId = this.getNodeParameter('spreadsheetId', i) as string;
|
|
const documentId = this.getNodeParameter('documentId', i, undefined, {
|
|
extractValue: true,
|
|
}) as string;
|
|
|
|
await apiRequest.call(
|
|
this,
|
|
'DELETE',
|
|
'',
|
|
{},
|
|
{},
|
|
`https://www.googleapis.com/drive/v3/files/${documentId}`,
|
|
);
|
|
|
|
const executionData = this.helpers.constructExecutionMetaData(wrapData({ success: true }), {
|
|
itemData: { item: i },
|
|
});
|
|
|
|
returnData.push(...executionData);
|
|
}
|
|
|
|
return returnData;
|
|
}
|