@lab1095/n8n-nodes-sharepoint-excel 0.1.1 → 0.2.0

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (51) hide show
  1. package/dist/credentials/MicrosoftGraphOAuth2Api.credentials.d.ts +3 -2
  2. package/dist/credentials/MicrosoftGraphOAuth2Api.credentials.js +9 -33
  3. package/dist/credentials/MicrosoftGraphOAuth2Api.credentials.js.map +1 -1
  4. package/dist/nodes/SharePointExcel/SharePointExcel.node.d.ts +4 -0
  5. package/dist/nodes/SharePointExcel/SharePointExcel.node.js +4 -0
  6. package/dist/nodes/SharePointExcel/SharePointExcel.node.js.map +1 -1
  7. package/dist/nodes/SharePointExcel/actions/router.js +12 -5
  8. package/dist/nodes/SharePointExcel/actions/router.js.map +1 -1
  9. package/dist/nodes/SharePointExcel/actions/sheet/appendRows.js +52 -29
  10. package/dist/nodes/SharePointExcel/actions/sheet/appendRows.js.map +1 -1
  11. package/dist/nodes/SharePointExcel/actions/sheet/appendRows.test.d.ts +1 -0
  12. package/dist/nodes/SharePointExcel/actions/sheet/appendRows.test.js +437 -0
  13. package/dist/nodes/SharePointExcel/actions/sheet/appendRows.test.js.map +1 -0
  14. package/dist/nodes/SharePointExcel/actions/sheet/clearSheet.js +2 -2
  15. package/dist/nodes/SharePointExcel/actions/sheet/clearSheet.js.map +1 -1
  16. package/dist/nodes/SharePointExcel/actions/sheet/clearSheet.test.d.ts +1 -0
  17. package/dist/nodes/SharePointExcel/actions/sheet/clearSheet.test.js +182 -0
  18. package/dist/nodes/SharePointExcel/actions/sheet/clearSheet.test.js.map +1 -0
  19. package/dist/nodes/SharePointExcel/actions/sheet/readRows.js +75 -20
  20. package/dist/nodes/SharePointExcel/actions/sheet/readRows.js.map +1 -1
  21. package/dist/nodes/SharePointExcel/actions/sheet/readRows.test.d.ts +1 -0
  22. package/dist/nodes/SharePointExcel/actions/sheet/readRows.test.js +251 -0
  23. package/dist/nodes/SharePointExcel/actions/sheet/readRows.test.js.map +1 -0
  24. package/dist/nodes/SharePointExcel/actions/sheet/upsertRows.js +100 -55
  25. package/dist/nodes/SharePointExcel/actions/sheet/upsertRows.js.map +1 -1
  26. package/dist/nodes/SharePointExcel/actions/table/getRows.js +69 -13
  27. package/dist/nodes/SharePointExcel/actions/table/getRows.js.map +1 -1
  28. package/dist/nodes/SharePointExcel/actions/table/getRows.test.d.ts +1 -0
  29. package/dist/nodes/SharePointExcel/actions/table/getRows.test.js +228 -0
  30. package/dist/nodes/SharePointExcel/actions/table/getRows.test.js.map +1 -0
  31. package/dist/nodes/SharePointExcel/actions/workbook/getWorkbooks.test.d.ts +1 -0
  32. package/dist/nodes/SharePointExcel/actions/workbook/getWorkbooks.test.js +151 -0
  33. package/dist/nodes/SharePointExcel/actions/workbook/getWorkbooks.test.js.map +1 -0
  34. package/dist/nodes/SharePointExcel/descriptions.d.ts +7 -0
  35. package/dist/nodes/SharePointExcel/descriptions.js +198 -13
  36. package/dist/nodes/SharePointExcel/descriptions.js.map +1 -1
  37. package/dist/nodes/SharePointExcel/listSearch.js +20 -5
  38. package/dist/nodes/SharePointExcel/listSearch.js.map +1 -1
  39. package/dist/nodes/SharePointExcel/listSearch.test.d.ts +1 -0
  40. package/dist/nodes/SharePointExcel/listSearch.test.js +302 -0
  41. package/dist/nodes/SharePointExcel/listSearch.test.js.map +1 -0
  42. package/dist/nodes/SharePointExcel/resourceMapping.d.ts +2 -0
  43. package/dist/nodes/SharePointExcel/resourceMapping.js +118 -0
  44. package/dist/nodes/SharePointExcel/resourceMapping.js.map +1 -0
  45. package/dist/nodes/SharePointExcel/test-utils/mocks.d.ts +114 -0
  46. package/dist/nodes/SharePointExcel/test-utils/mocks.js +116 -0
  47. package/dist/nodes/SharePointExcel/test-utils/mocks.js.map +1 -0
  48. package/dist/nodes/SharePointExcel/types.d.ts +25 -2
  49. package/dist/package.json +7 -3
  50. package/dist/tsconfig.tsbuildinfo +1 -1
  51. package/package.json +7 -3
@@ -0,0 +1,302 @@
1
+ "use strict";
2
+ Object.defineProperty(exports, "__esModule", { value: true });
3
+ const vitest_1 = require("vitest");
4
+ const listSearch_1 = require("./listSearch");
5
+ const mocks_1 = require("./test-utils/mocks");
6
+ const mockWorkbookInstance = {
7
+ xlsx: { load: vitest_1.vi.fn() },
8
+ worksheets: [],
9
+ };
10
+ vitest_1.vi.mock('exceljs', () => ({
11
+ Workbook: class MockWorkbook {
12
+ constructor() {
13
+ this.xlsx = mockWorkbookInstance.xlsx;
14
+ }
15
+ get worksheets() {
16
+ return mockWorkbookInstance.worksheets;
17
+ }
18
+ },
19
+ }));
20
+ (0, vitest_1.describe)('listSearch', () => {
21
+ (0, vitest_1.beforeEach)(() => {
22
+ vitest_1.vi.clearAllMocks();
23
+ });
24
+ (0, vitest_1.describe)('searchSites', () => {
25
+ (0, vitest_1.describe)('basic functionality', () => {
26
+ (0, vitest_1.it)('returns sites from Graph API response', async () => {
27
+ const mockFunctions = (0, mocks_1.createMockLoadOptionsFunctions)();
28
+ mockFunctions._httpRequestWithAuthentication.mockResolvedValue({
29
+ value: [
30
+ { id: 'site-1', displayName: 'Site One', webUrl: 'https://example.com/site1' },
31
+ { id: 'site-2', displayName: 'Site Two', webUrl: 'https://example.com/site2' },
32
+ ],
33
+ });
34
+ const result = await listSearch_1.searchSites.call(mockFunctions);
35
+ (0, vitest_1.expect)(result.results).toHaveLength(2);
36
+ (0, vitest_1.expect)(result.results[0]).toEqual({
37
+ name: 'Site One',
38
+ value: 'site-1',
39
+ url: 'https://example.com/site1',
40
+ });
41
+ });
42
+ (0, vitest_1.it)('uses wildcard search when no filter provided', async () => {
43
+ const mockFunctions = (0, mocks_1.createMockLoadOptionsFunctions)();
44
+ mockFunctions._httpRequestWithAuthentication.mockResolvedValue({ value: [] });
45
+ await listSearch_1.searchSites.call(mockFunctions);
46
+ (0, vitest_1.expect)(mockFunctions._httpRequestWithAuthentication).toHaveBeenCalledWith(mockFunctions, 'microsoftGraphOAuth2Api', vitest_1.expect.objectContaining({
47
+ url: vitest_1.expect.stringContaining('search=*'),
48
+ }));
49
+ });
50
+ (0, vitest_1.it)('uses filter term when provided', async () => {
51
+ const mockFunctions = (0, mocks_1.createMockLoadOptionsFunctions)();
52
+ mockFunctions._httpRequestWithAuthentication.mockResolvedValue({ value: [] });
53
+ await listSearch_1.searchSites.call(mockFunctions, 'marketing');
54
+ (0, vitest_1.expect)(mockFunctions._httpRequestWithAuthentication).toHaveBeenCalledWith(mockFunctions, 'microsoftGraphOAuth2Api', vitest_1.expect.objectContaining({
55
+ url: vitest_1.expect.stringContaining('search=marketing'),
56
+ }));
57
+ });
58
+ });
59
+ (0, vitest_1.describe)('edge cases', () => {
60
+ (0, vitest_1.it)('returns empty results when API returns no value', async () => {
61
+ const mockFunctions = (0, mocks_1.createMockLoadOptionsFunctions)();
62
+ mockFunctions._httpRequestWithAuthentication.mockResolvedValue({});
63
+ const result = await listSearch_1.searchSites.call(mockFunctions);
64
+ (0, vitest_1.expect)(result.results).toHaveLength(0);
65
+ });
66
+ });
67
+ (0, vitest_1.describe)('error handling', () => {
68
+ (0, vitest_1.it)('logs error and returns empty results on API failure', async () => {
69
+ const mockFunctions = (0, mocks_1.createMockLoadOptionsFunctions)();
70
+ mockFunctions._httpRequestWithAuthentication.mockRejectedValue(new Error('Network error'));
71
+ const result = await listSearch_1.searchSites.call(mockFunctions);
72
+ (0, vitest_1.expect)(result.results).toHaveLength(0);
73
+ (0, vitest_1.expect)(mockFunctions.logger.error).toHaveBeenCalledWith('Failed to search sites', { error: 'Network error' });
74
+ });
75
+ });
76
+ });
77
+ (0, vitest_1.describe)('getDrives', () => {
78
+ (0, vitest_1.describe)('basic functionality', () => {
79
+ (0, vitest_1.it)('returns drives for selected site', async () => {
80
+ const mockFunctions = (0, mocks_1.createMockLoadOptionsFunctions)({
81
+ siteId: 'site-123',
82
+ });
83
+ mockFunctions._httpRequestWithAuthentication.mockResolvedValue({
84
+ value: [
85
+ { id: 'drive-1', name: 'Documents' },
86
+ { id: 'drive-2', name: 'Shared Files' },
87
+ ],
88
+ });
89
+ const result = await listSearch_1.getDrives.call(mockFunctions);
90
+ (0, vitest_1.expect)(result.results).toHaveLength(2);
91
+ (0, vitest_1.expect)(result.results[0]).toEqual({
92
+ name: 'Documents',
93
+ value: 'drive-1',
94
+ });
95
+ });
96
+ (0, vitest_1.it)('handles resourceLocator format for parameters', async () => {
97
+ const mockFunctions = (0, mocks_1.createMockLoadOptionsFunctions)({
98
+ siteId: { mode: 'list', value: 'site-456' },
99
+ });
100
+ mockFunctions._httpRequestWithAuthentication.mockResolvedValue({ value: [] });
101
+ await listSearch_1.getDrives.call(mockFunctions);
102
+ (0, vitest_1.expect)(mockFunctions._httpRequestWithAuthentication).toHaveBeenCalledWith(mockFunctions, 'microsoftGraphOAuth2Api', vitest_1.expect.objectContaining({
103
+ url: vitest_1.expect.stringContaining('/sites/site-456/drives'),
104
+ }));
105
+ });
106
+ });
107
+ (0, vitest_1.describe)('edge cases', () => {
108
+ (0, vitest_1.it)('returns empty results when siteId is missing', async () => {
109
+ const mockFunctions = (0, mocks_1.createMockLoadOptionsFunctions)({});
110
+ const result = await listSearch_1.getDrives.call(mockFunctions);
111
+ (0, vitest_1.expect)(result.results).toHaveLength(0);
112
+ (0, vitest_1.expect)(mockFunctions._httpRequestWithAuthentication).not.toHaveBeenCalled();
113
+ });
114
+ });
115
+ (0, vitest_1.describe)('error handling', () => {
116
+ (0, vitest_1.it)('logs error and returns empty results on API failure', async () => {
117
+ const mockFunctions = (0, mocks_1.createMockLoadOptionsFunctions)({
118
+ siteId: 'site-123',
119
+ });
120
+ mockFunctions._httpRequestWithAuthentication.mockRejectedValue(new Error('Network error'));
121
+ const result = await listSearch_1.getDrives.call(mockFunctions);
122
+ (0, vitest_1.expect)(result.results).toHaveLength(0);
123
+ (0, vitest_1.expect)(mockFunctions.logger.error).toHaveBeenCalledWith('Failed to get drives', { error: 'Network error' });
124
+ });
125
+ });
126
+ });
127
+ (0, vitest_1.describe)('getFiles', () => {
128
+ (0, vitest_1.describe)('basic functionality', () => {
129
+ (0, vitest_1.it)('returns only Excel files from drive', async () => {
130
+ const mockFunctions = (0, mocks_1.createMockLoadOptionsFunctions)({
131
+ driveId: 'drive-123',
132
+ });
133
+ mockFunctions._httpRequestWithAuthentication.mockResolvedValue({
134
+ value: [
135
+ { id: 'file-1', name: 'Report.xlsx', file: {} },
136
+ { id: 'file-2', name: 'Document.docx', file: {} },
137
+ { id: 'file-3', name: 'Data.xlsx', file: {} },
138
+ { id: 'folder-1', name: 'Subfolder' },
139
+ ],
140
+ });
141
+ const result = await listSearch_1.getFiles.call(mockFunctions);
142
+ (0, vitest_1.expect)(result.results).toHaveLength(2);
143
+ (0, vitest_1.expect)(result.results[0]).toEqual({ name: 'Report.xlsx', value: 'file-1' });
144
+ (0, vitest_1.expect)(result.results[1]).toEqual({ name: 'Data.xlsx', value: 'file-3' });
145
+ });
146
+ (0, vitest_1.it)('handles resourceLocator format for driveId', async () => {
147
+ const mockFunctions = (0, mocks_1.createMockLoadOptionsFunctions)({
148
+ driveId: { mode: 'list', value: 'drive-456' },
149
+ });
150
+ mockFunctions._httpRequestWithAuthentication.mockResolvedValue({ value: [] });
151
+ await listSearch_1.getFiles.call(mockFunctions);
152
+ (0, vitest_1.expect)(mockFunctions._httpRequestWithAuthentication).toHaveBeenCalledWith(mockFunctions, 'microsoftGraphOAuth2Api', vitest_1.expect.objectContaining({
153
+ url: vitest_1.expect.stringContaining('/drives/drive-456/root/children'),
154
+ }));
155
+ });
156
+ });
157
+ (0, vitest_1.describe)('edge cases', () => {
158
+ (0, vitest_1.it)('returns empty results when driveId is missing', async () => {
159
+ const mockFunctions = (0, mocks_1.createMockLoadOptionsFunctions)({});
160
+ const result = await listSearch_1.getFiles.call(mockFunctions);
161
+ (0, vitest_1.expect)(result.results).toHaveLength(0);
162
+ (0, vitest_1.expect)(mockFunctions._httpRequestWithAuthentication).not.toHaveBeenCalled();
163
+ });
164
+ });
165
+ (0, vitest_1.describe)('error handling', () => {
166
+ (0, vitest_1.it)('logs error and returns empty results on API failure', async () => {
167
+ const mockFunctions = (0, mocks_1.createMockLoadOptionsFunctions)({
168
+ driveId: 'drive-123',
169
+ });
170
+ mockFunctions._httpRequestWithAuthentication.mockRejectedValue(new Error('Access denied'));
171
+ const result = await listSearch_1.getFiles.call(mockFunctions);
172
+ (0, vitest_1.expect)(result.results).toHaveLength(0);
173
+ (0, vitest_1.expect)(mockFunctions.logger.error).toHaveBeenCalledWith('Failed to get files', { error: 'Access denied' });
174
+ });
175
+ });
176
+ });
177
+ (0, vitest_1.describe)('getSheets', () => {
178
+ (0, vitest_1.beforeEach)(() => {
179
+ mockWorkbookInstance.xlsx.load.mockReset();
180
+ mockWorkbookInstance.worksheets = [];
181
+ });
182
+ (0, vitest_1.describe)('basic functionality', () => {
183
+ (0, vitest_1.it)('returns worksheet names from Excel file', async () => {
184
+ const mockFunctions = (0, mocks_1.createMockLoadOptionsFunctions)({
185
+ siteId: 'site-123',
186
+ driveId: 'drive-123',
187
+ fileId: 'file-123',
188
+ });
189
+ mockFunctions._httpRequestWithAuthentication.mockResolvedValue(Buffer.from('mock-excel-data'));
190
+ mockWorkbookInstance.worksheets = [
191
+ { name: 'Sheet1' },
192
+ { name: 'Sheet2' },
193
+ { name: 'Data' },
194
+ ];
195
+ const result = await listSearch_1.getSheets.call(mockFunctions);
196
+ (0, vitest_1.expect)(result.results).toHaveLength(3);
197
+ (0, vitest_1.expect)(result.results[0]).toEqual({ name: 'Sheet1', value: 'Sheet1' });
198
+ (0, vitest_1.expect)(result.results[1]).toEqual({ name: 'Sheet2', value: 'Sheet2' });
199
+ (0, vitest_1.expect)(result.results[2]).toEqual({ name: 'Data', value: 'Data' });
200
+ });
201
+ (0, vitest_1.it)('downloads file content and parses with ExcelJS', async () => {
202
+ const mockFunctions = (0, mocks_1.createMockLoadOptionsFunctions)({
203
+ siteId: 'site-123',
204
+ driveId: 'drive-123',
205
+ fileId: 'file-123',
206
+ });
207
+ const fileContent = Buffer.from('mock-excel-data');
208
+ mockFunctions._httpRequestWithAuthentication.mockResolvedValue(fileContent);
209
+ mockWorkbookInstance.worksheets = [];
210
+ await listSearch_1.getSheets.call(mockFunctions);
211
+ (0, vitest_1.expect)(mockFunctions._httpRequestWithAuthentication).toHaveBeenCalledWith(mockFunctions, 'microsoftGraphOAuth2Api', vitest_1.expect.objectContaining({
212
+ url: vitest_1.expect.stringContaining('/sites/site-123/drives/drive-123/items/file-123/content'),
213
+ encoding: 'arraybuffer',
214
+ }));
215
+ (0, vitest_1.expect)(mockWorkbookInstance.xlsx.load).toHaveBeenCalledWith(fileContent);
216
+ });
217
+ });
218
+ (0, vitest_1.describe)('edge cases', () => {
219
+ (0, vitest_1.it)('returns empty results when required params are missing', async () => {
220
+ const mockFunctions = (0, mocks_1.createMockLoadOptionsFunctions)({
221
+ siteId: 'site-123',
222
+ fileId: 'file-123',
223
+ });
224
+ const result = await listSearch_1.getSheets.call(mockFunctions);
225
+ (0, vitest_1.expect)(result.results).toHaveLength(0);
226
+ (0, vitest_1.expect)(mockFunctions._httpRequestWithAuthentication).not.toHaveBeenCalled();
227
+ });
228
+ });
229
+ (0, vitest_1.describe)('error handling', () => {
230
+ (0, vitest_1.it)('logs error and returns empty results on Excel parse failure', async () => {
231
+ const mockFunctions = (0, mocks_1.createMockLoadOptionsFunctions)({
232
+ siteId: 'site-123',
233
+ driveId: 'drive-123',
234
+ fileId: 'file-123',
235
+ });
236
+ mockFunctions._httpRequestWithAuthentication.mockResolvedValue(Buffer.from('invalid-data'));
237
+ mockWorkbookInstance.xlsx.load.mockRejectedValue(new Error('Invalid Excel format'));
238
+ const result = await listSearch_1.getSheets.call(mockFunctions);
239
+ (0, vitest_1.expect)(result.results).toHaveLength(0);
240
+ (0, vitest_1.expect)(mockFunctions.logger.error).toHaveBeenCalledWith('Failed to get sheets', { error: 'Invalid Excel format' });
241
+ });
242
+ });
243
+ });
244
+ (0, vitest_1.describe)('getTables', () => {
245
+ (0, vitest_1.describe)('basic functionality', () => {
246
+ (0, vitest_1.it)('returns tables from Graph API', async () => {
247
+ const mockFunctions = (0, mocks_1.createMockLoadOptionsFunctions)({
248
+ siteId: 'site-123',
249
+ driveId: 'drive-123',
250
+ fileId: 'file-123',
251
+ });
252
+ mockFunctions._httpRequestWithAuthentication.mockResolvedValue({
253
+ value: [
254
+ { id: 'table-1', name: 'SalesData' },
255
+ { id: 'table-2', name: 'Inventory' },
256
+ ],
257
+ });
258
+ const result = await listSearch_1.getTables.call(mockFunctions);
259
+ (0, vitest_1.expect)(result.results).toHaveLength(2);
260
+ (0, vitest_1.expect)(result.results[0]).toEqual({ name: 'SalesData', value: 'SalesData' });
261
+ (0, vitest_1.expect)(result.results[1]).toEqual({ name: 'Inventory', value: 'Inventory' });
262
+ });
263
+ (0, vitest_1.it)('uses workbook/tables Graph API endpoint', async () => {
264
+ const mockFunctions = (0, mocks_1.createMockLoadOptionsFunctions)({
265
+ siteId: 'site-123',
266
+ driveId: 'drive-123',
267
+ fileId: 'file-123',
268
+ });
269
+ mockFunctions._httpRequestWithAuthentication.mockResolvedValue({ value: [] });
270
+ await listSearch_1.getTables.call(mockFunctions);
271
+ (0, vitest_1.expect)(mockFunctions._httpRequestWithAuthentication).toHaveBeenCalledWith(mockFunctions, 'microsoftGraphOAuth2Api', vitest_1.expect.objectContaining({
272
+ url: vitest_1.expect.stringContaining('/workbook/tables'),
273
+ }));
274
+ });
275
+ });
276
+ (0, vitest_1.describe)('edge cases', () => {
277
+ (0, vitest_1.it)('returns empty results when required params are missing', async () => {
278
+ const mockFunctions = (0, mocks_1.createMockLoadOptionsFunctions)({
279
+ siteId: 'site-123',
280
+ driveId: 'drive-123',
281
+ });
282
+ const result = await listSearch_1.getTables.call(mockFunctions);
283
+ (0, vitest_1.expect)(result.results).toHaveLength(0);
284
+ (0, vitest_1.expect)(mockFunctions._httpRequestWithAuthentication).not.toHaveBeenCalled();
285
+ });
286
+ });
287
+ (0, vitest_1.describe)('error handling', () => {
288
+ (0, vitest_1.it)('logs error and returns empty results on API failure', async () => {
289
+ const mockFunctions = (0, mocks_1.createMockLoadOptionsFunctions)({
290
+ siteId: 'site-123',
291
+ driveId: 'drive-123',
292
+ fileId: 'file-123',
293
+ });
294
+ mockFunctions._httpRequestWithAuthentication.mockRejectedValue(new Error('Table access denied'));
295
+ const result = await listSearch_1.getTables.call(mockFunctions);
296
+ (0, vitest_1.expect)(result.results).toHaveLength(0);
297
+ (0, vitest_1.expect)(mockFunctions.logger.error).toHaveBeenCalledWith('Failed to get tables', { error: 'Table access denied' });
298
+ });
299
+ });
300
+ });
301
+ });
302
+ //# sourceMappingURL=listSearch.test.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"listSearch.test.js","sourceRoot":"","sources":["../../../nodes/SharePointExcel/listSearch.test.ts"],"names":[],"mappings":"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"}
@@ -0,0 +1,2 @@
1
+ import type { ILoadOptionsFunctions, ResourceMapperFields } from 'n8n-workflow';
2
+ export declare function getMappingColumns(this: ILoadOptionsFunctions): Promise<ResourceMapperFields>;
@@ -0,0 +1,118 @@
1
+ "use strict";
2
+ var __createBinding = (this && this.__createBinding) || (Object.create ? (function(o, m, k, k2) {
3
+ if (k2 === undefined) k2 = k;
4
+ var desc = Object.getOwnPropertyDescriptor(m, k);
5
+ if (!desc || ("get" in desc ? !m.__esModule : desc.writable || desc.configurable)) {
6
+ desc = { enumerable: true, get: function() { return m[k]; } };
7
+ }
8
+ Object.defineProperty(o, k2, desc);
9
+ }) : (function(o, m, k, k2) {
10
+ if (k2 === undefined) k2 = k;
11
+ o[k2] = m[k];
12
+ }));
13
+ var __setModuleDefault = (this && this.__setModuleDefault) || (Object.create ? (function(o, v) {
14
+ Object.defineProperty(o, "default", { enumerable: true, value: v });
15
+ }) : function(o, v) {
16
+ o["default"] = v;
17
+ });
18
+ var __importStar = (this && this.__importStar) || (function () {
19
+ var ownKeys = function(o) {
20
+ ownKeys = Object.getOwnPropertyNames || function (o) {
21
+ var ar = [];
22
+ for (var k in o) if (Object.prototype.hasOwnProperty.call(o, k)) ar[ar.length] = k;
23
+ return ar;
24
+ };
25
+ return ownKeys(o);
26
+ };
27
+ return function (mod) {
28
+ if (mod && mod.__esModule) return mod;
29
+ var result = {};
30
+ if (mod != null) for (var k = ownKeys(mod), i = 0; i < k.length; i++) if (k[i] !== "default") __createBinding(result, mod, k[i]);
31
+ __setModuleDefault(result, mod);
32
+ return result;
33
+ };
34
+ })();
35
+ Object.defineProperty(exports, "__esModule", { value: true });
36
+ exports.getMappingColumns = getMappingColumns;
37
+ const ExcelJS = __importStar(require("exceljs"));
38
+ const GRAPH_BASE_URL = 'https://graph.microsoft.com/v1.0';
39
+ const CREDENTIAL_NAME = 'microsoftGraphOAuth2Api';
40
+ function getResourceValue(param) {
41
+ return typeof param === 'object' ? param.value : param;
42
+ }
43
+ function inferFieldType(value) {
44
+ if (value === null || value === undefined) {
45
+ return 'string';
46
+ }
47
+ if (typeof value === 'number') {
48
+ return 'number';
49
+ }
50
+ if (typeof value === 'boolean') {
51
+ return 'boolean';
52
+ }
53
+ if (value instanceof Date) {
54
+ return 'dateTime';
55
+ }
56
+ return 'string';
57
+ }
58
+ async function getMappingColumns() {
59
+ const fields = [];
60
+ try {
61
+ const siteIdParam = this.getNodeParameter('siteId');
62
+ const siteId = getResourceValue(siteIdParam);
63
+ const driveIdParam = this.getNodeParameter('driveId');
64
+ const driveId = getResourceValue(driveIdParam);
65
+ const fileIdParam = this.getNodeParameter('fileId');
66
+ const fileId = getResourceValue(fileIdParam);
67
+ const sheetNameParam = this.getNodeParameter('sheetName');
68
+ const sheetName = getResourceValue(sheetNameParam);
69
+ if (!siteId || !driveId || !fileId || !sheetName) {
70
+ return { fields };
71
+ }
72
+ let headerRow = 1;
73
+ try {
74
+ const options = this.getNodeParameter('options', {});
75
+ headerRow = options.headerRow || 1;
76
+ }
77
+ catch {
78
+ }
79
+ const endpoint = `${GRAPH_BASE_URL}/sites/${siteId}/drives/${driveId}/items/${fileId}/content`;
80
+ const response = await this.helpers.httpRequestWithAuthentication.call(this, CREDENTIAL_NAME, {
81
+ method: 'GET',
82
+ url: endpoint,
83
+ encoding: 'arraybuffer',
84
+ json: false,
85
+ });
86
+ const workbook = new ExcelJS.Workbook();
87
+ await workbook.xlsx.load(response);
88
+ const worksheet = workbook.getWorksheet(sheetName);
89
+ if (!worksheet) {
90
+ return { fields };
91
+ }
92
+ const headerRowData = worksheet.getRow(headerRow);
93
+ const dataRow = worksheet.getRow(headerRow + 1);
94
+ headerRowData.eachCell({ includeEmpty: false }, (cell, colNumber) => {
95
+ const headerValue = String(cell.value || '').trim();
96
+ if (headerValue) {
97
+ const dataCell = dataRow.getCell(colNumber);
98
+ const fieldType = inferFieldType(dataCell.value);
99
+ fields.push({
100
+ id: headerValue,
101
+ displayName: headerValue,
102
+ required: false,
103
+ defaultMatch: false,
104
+ display: true,
105
+ type: fieldType,
106
+ canBeUsedToMatch: true,
107
+ });
108
+ }
109
+ });
110
+ }
111
+ catch (err) {
112
+ this.logger.error('Failed to load mapping columns', {
113
+ error: err instanceof Error ? err.message : String(err),
114
+ });
115
+ }
116
+ return { fields };
117
+ }
118
+ //# sourceMappingURL=resourceMapping.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"resourceMapping.js","sourceRoot":"","sources":["../../../nodes/SharePointExcel/resourceMapping.ts"],"names":[],"mappings":"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"}
@@ -0,0 +1,114 @@
1
+ import { vi } from 'vitest';
2
+ import type { IExecuteFunctions, ILoadOptionsFunctions } from 'n8n-workflow';
3
+ import type { OperationContext } from '../types';
4
+ export declare function createMockExecuteFunctions(params?: Record<string, unknown>): IExecuteFunctions;
5
+ export declare function createMockLoadOptionsFunctions(params?: Record<string, unknown>): ILoadOptionsFunctions & {
6
+ _httpRequestWithAuthentication: ReturnType<typeof vi.fn>;
7
+ };
8
+ export declare function createMockContext(overrides?: Partial<OperationContext>): OperationContext;
9
+ export declare function createMockCell(value: string | number | boolean | null): {
10
+ value: string | number | boolean | null;
11
+ };
12
+ export declare function createMockRow(cells: Record<number, string | number | boolean | null>): {
13
+ eachCell: import("vitest").Mock<(opts: {
14
+ includeEmpty: boolean;
15
+ }, callback: (cell: {
16
+ value: unknown;
17
+ }, colNumber: number) => void) => void>;
18
+ getCell: import("vitest").Mock<(colNumber: number) => {
19
+ value: string | number | boolean | null;
20
+ }>;
21
+ };
22
+ export interface MockWorksheetOptions {
23
+ headers: Record<number, string>;
24
+ rows: Record<number, string | number | boolean | null>[];
25
+ rowCount?: number;
26
+ columnCount?: number;
27
+ }
28
+ export declare function createMockWorksheet(data: MockWorksheetOptions): {
29
+ rowCount: number;
30
+ columnCount: number;
31
+ getRow: import("vitest").Mock<(rowNum: number) => {
32
+ eachCell: import("vitest").Mock<(opts: {
33
+ includeEmpty: boolean;
34
+ }, callback: (cell: {
35
+ value: unknown;
36
+ }, colNumber: number) => void) => void>;
37
+ getCell: import("vitest").Mock<(colNumber: number) => {
38
+ value: string | number | boolean | null;
39
+ }>;
40
+ }>;
41
+ spliceRows: import("vitest").Mock<import("@vitest/spy").Procedure>;
42
+ addRow: import("vitest").Mock<import("@vitest/spy").Procedure>;
43
+ };
44
+ export declare function createMockWorkbook(worksheets: Record<string, ReturnType<typeof createMockWorksheet>>): {
45
+ getWorksheet: import("vitest").Mock<(name: string) => {
46
+ rowCount: number;
47
+ columnCount: number;
48
+ getRow: import("vitest").Mock<(rowNum: number) => {
49
+ eachCell: import("vitest").Mock<(opts: {
50
+ includeEmpty: boolean;
51
+ }, callback: (cell: {
52
+ value: unknown;
53
+ }, colNumber: number) => void) => void>;
54
+ getCell: import("vitest").Mock<(colNumber: number) => {
55
+ value: string | number | boolean | null;
56
+ }>;
57
+ }>;
58
+ spliceRows: import("vitest").Mock<import("@vitest/spy").Procedure>;
59
+ addRow: import("vitest").Mock<import("@vitest/spy").Procedure>;
60
+ }>;
61
+ xlsx: {
62
+ load: import("vitest").Mock<import("@vitest/spy").Procedure>;
63
+ };
64
+ };
65
+ export interface SetupSheetMocksOptions {
66
+ sheetName: string;
67
+ rowCount: number;
68
+ columnCount: number;
69
+ headers?: Record<number, string>;
70
+ rows?: Record<number, string | number | boolean | null>[];
71
+ }
72
+ export declare function setupSheetMocks(mocks: {
73
+ loadWorkbook: unknown;
74
+ saveWorkbook: unknown;
75
+ getWorksheet: unknown;
76
+ }, options: SetupSheetMocksOptions): {
77
+ worksheet: {
78
+ rowCount: number;
79
+ columnCount: number;
80
+ getRow: import("vitest").Mock<(rowNum: number) => {
81
+ eachCell: import("vitest").Mock<(opts: {
82
+ includeEmpty: boolean;
83
+ }, callback: (cell: {
84
+ value: unknown;
85
+ }, colNumber: number) => void) => void>;
86
+ getCell: import("vitest").Mock<(colNumber: number) => {
87
+ value: string | number | boolean | null;
88
+ }>;
89
+ }>;
90
+ spliceRows: import("vitest").Mock<import("@vitest/spy").Procedure>;
91
+ addRow: import("vitest").Mock<import("@vitest/spy").Procedure>;
92
+ };
93
+ workbook: {
94
+ getWorksheet: import("vitest").Mock<(name: string) => {
95
+ rowCount: number;
96
+ columnCount: number;
97
+ getRow: import("vitest").Mock<(rowNum: number) => {
98
+ eachCell: import("vitest").Mock<(opts: {
99
+ includeEmpty: boolean;
100
+ }, callback: (cell: {
101
+ value: unknown;
102
+ }, colNumber: number) => void) => void>;
103
+ getCell: import("vitest").Mock<(colNumber: number) => {
104
+ value: string | number | boolean | null;
105
+ }>;
106
+ }>;
107
+ spliceRows: import("vitest").Mock<import("@vitest/spy").Procedure>;
108
+ addRow: import("vitest").Mock<import("@vitest/spy").Procedure>;
109
+ }>;
110
+ xlsx: {
111
+ load: import("vitest").Mock<import("@vitest/spy").Procedure>;
112
+ };
113
+ };
114
+ };