mirror of
https://github.com/n8n-io/n8n.git
synced 2025-01-12 21:37:32 -08:00
refactor(Google Sheets Node): Stop reporting to Sentry sheet not found error (no-changelog) (#7617)
https://n8nio.sentry.io/issues/4264383378
This commit is contained in:
parent
b11c4de039
commit
52f655f3d2
|
@ -418,7 +418,10 @@ export class GoogleSheetsTrigger implements INodeType {
|
|||
}
|
||||
|
||||
const googleSheet = new GoogleSheet(documentId, this);
|
||||
const sheetName: string = await googleSheet.spreadsheetGetSheetNameById(sheetId);
|
||||
const sheetName: string = await googleSheet.spreadsheetGetSheetNameById(
|
||||
this.getNode(),
|
||||
sheetId,
|
||||
);
|
||||
const options = this.getNodeParameter('options') as IDataObject;
|
||||
|
||||
const previousRevision = workflowStaticData.lastRevision as number;
|
||||
|
|
|
@ -51,7 +51,7 @@ export async function router(this: IExecuteFunctions): Promise<INodeExecutionDat
|
|||
sheetName = `${spreadsheetId}||${sheetId}`;
|
||||
break;
|
||||
default:
|
||||
sheetName = await googleSheet.spreadsheetGetSheetNameById(sheetId);
|
||||
sheetName = await googleSheet.spreadsheetGetSheetNameById(this.getNode(), sheetId);
|
||||
}
|
||||
|
||||
results = await sheet[googleSheets.operation].execute.call(
|
||||
|
|
|
@ -3,6 +3,7 @@ import type {
|
|||
ILoadOptionsFunctions,
|
||||
IDataObject,
|
||||
IPollFunctions,
|
||||
INode,
|
||||
} from 'n8n-workflow';
|
||||
import { NodeOperationError } from 'n8n-workflow';
|
||||
import { utils as xlsxUtils } from 'xlsx';
|
||||
|
@ -117,7 +118,7 @@ export class GoogleSheet {
|
|||
/**
|
||||
* Returns the name of a sheet from a sheet id
|
||||
*/
|
||||
async spreadsheetGetSheetNameById(sheetId: string) {
|
||||
async spreadsheetGetSheetNameById(node: INode, sheetId: string) {
|
||||
const query = {
|
||||
fields: 'sheets.properties',
|
||||
};
|
||||
|
@ -133,9 +134,13 @@ export class GoogleSheet {
|
|||
const foundItem = response.sheets.find(
|
||||
(item: { properties: { sheetId: number } }) => item.properties.sheetId === +sheetId,
|
||||
);
|
||||
|
||||
if (!foundItem?.properties?.title) {
|
||||
throw new Error(`Sheet with id ${sheetId} not found`);
|
||||
throw new NodeOperationError(node, `Sheet with ID ${sheetId} not found`, {
|
||||
severity: 'warning',
|
||||
});
|
||||
}
|
||||
|
||||
return foundItem.properties.title;
|
||||
}
|
||||
|
||||
|
|
|
@ -45,7 +45,7 @@ export async function getSheetHeaderRow(
|
|||
sheetWithinDocument = '0';
|
||||
}
|
||||
|
||||
const sheetName = await sheet.spreadsheetGetSheetNameById(sheetWithinDocument);
|
||||
const sheetName = await sheet.spreadsheetGetSheetNameById(this.getNode(), sheetWithinDocument);
|
||||
const sheetData = await sheet.getData(`${sheetName}!1:1`, 'FORMATTED_VALUE');
|
||||
|
||||
if (sheetData === undefined) {
|
||||
|
|
|
@ -23,7 +23,7 @@ export async function getMappingColumns(
|
|||
sheetWithinDocument = '0';
|
||||
}
|
||||
|
||||
const sheetName = await sheet.spreadsheetGetSheetNameById(sheetWithinDocument);
|
||||
const sheetName = await sheet.spreadsheetGetSheetNameById(this.getNode(), sheetWithinDocument);
|
||||
const sheetData = await sheet.getData(`${sheetName}!1:1`, 'FORMATTED_VALUE');
|
||||
|
||||
const columns = sheet.testFilter(sheetData || [], 0, 0).filter((col) => col !== '');
|
||||
|
|
Loading…
Reference in a new issue