@marktoflow/integrations 2.0.0-alpha.6 → 2.0.0-alpha.7

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 (41) hide show
  1. package/dist/index.d.ts +10 -1
  2. package/dist/index.d.ts.map +1 -1
  3. package/dist/index.js +29 -1
  4. package/dist/index.js.map +1 -1
  5. package/dist/services/google-calendar.d.ts +220 -0
  6. package/dist/services/google-calendar.d.ts.map +1 -0
  7. package/dist/services/google-calendar.js +318 -0
  8. package/dist/services/google-calendar.js.map +1 -0
  9. package/dist/services/google-docs.d.ts +197 -0
  10. package/dist/services/google-docs.d.ts.map +1 -0
  11. package/dist/services/google-docs.js +293 -0
  12. package/dist/services/google-docs.js.map +1 -0
  13. package/dist/services/google-drive.d.ts +149 -0
  14. package/dist/services/google-drive.d.ts.map +1 -0
  15. package/dist/services/google-drive.js +288 -0
  16. package/dist/services/google-drive.js.map +1 -0
  17. package/dist/services/google-sheets.d.ts +165 -0
  18. package/dist/services/google-sheets.d.ts.map +1 -0
  19. package/dist/services/google-sheets.js +352 -0
  20. package/dist/services/google-sheets.js.map +1 -0
  21. package/dist/services/mysql.d.ts +91 -0
  22. package/dist/services/mysql.d.ts.map +1 -0
  23. package/dist/services/mysql.js +250 -0
  24. package/dist/services/mysql.js.map +1 -0
  25. package/dist/services/postgres.d.ts +83 -0
  26. package/dist/services/postgres.d.ts.map +1 -0
  27. package/dist/services/postgres.js +230 -0
  28. package/dist/services/postgres.js.map +1 -0
  29. package/dist/services/supabase.d.ts +193 -0
  30. package/dist/services/supabase.d.ts.map +1 -0
  31. package/dist/services/supabase.js +328 -0
  32. package/dist/services/supabase.js.map +1 -0
  33. package/dist/services/telegram.d.ts +247 -0
  34. package/dist/services/telegram.d.ts.map +1 -0
  35. package/dist/services/telegram.js +247 -0
  36. package/dist/services/telegram.js.map +1 -0
  37. package/dist/services/whatsapp.d.ts +311 -0
  38. package/dist/services/whatsapp.d.ts.map +1 -0
  39. package/dist/services/whatsapp.js +253 -0
  40. package/dist/services/whatsapp.js.map +1 -0
  41. package/package.json +21 -5
@@ -0,0 +1,352 @@
1
+ /**
2
+ * Google Sheets Integration
3
+ *
4
+ * Spreadsheet automation platform.
5
+ * API Docs: https://developers.google.com/sheets/api
6
+ */
7
+ import { google } from 'googleapis';
8
+ /**
9
+ * Google Sheets actions for workflow integration
10
+ */
11
+ export class GoogleSheetsActions {
12
+ sheets;
13
+ constructor(sheets) {
14
+ this.sheets = sheets;
15
+ }
16
+ /**
17
+ * Get spreadsheet metadata
18
+ */
19
+ async getSpreadsheet(spreadsheetId) {
20
+ const response = await this.sheets.spreadsheets.get({
21
+ spreadsheetId,
22
+ });
23
+ const data = response.data;
24
+ return {
25
+ spreadsheetId: data.spreadsheetId ?? spreadsheetId,
26
+ properties: {
27
+ title: data.properties?.title ?? '',
28
+ locale: data.properties?.locale ?? '',
29
+ autoRecalc: data.properties?.autoRecalc ?? '',
30
+ timeZone: data.properties?.timeZone ?? '',
31
+ },
32
+ sheets: data.sheets?.map((sheet) => ({
33
+ sheetId: sheet.properties?.sheetId ?? 0,
34
+ title: sheet.properties?.title ?? '',
35
+ index: sheet.properties?.index ?? 0,
36
+ sheetType: sheet.properties?.sheetType ?? '',
37
+ gridProperties: {
38
+ rowCount: sheet.properties?.gridProperties?.rowCount ?? 0,
39
+ columnCount: sheet.properties?.gridProperties?.columnCount ?? 0,
40
+ },
41
+ })) ?? [],
42
+ };
43
+ }
44
+ /**
45
+ * Get values from a range
46
+ */
47
+ async getValues(spreadsheetId, range) {
48
+ const response = await this.sheets.spreadsheets.values.get({
49
+ spreadsheetId,
50
+ range,
51
+ });
52
+ return response.data.values ?? [];
53
+ }
54
+ /**
55
+ * Get multiple ranges at once
56
+ */
57
+ async batchGetValues(spreadsheetId, ranges) {
58
+ const response = await this.sheets.spreadsheets.values.batchGet({
59
+ spreadsheetId,
60
+ ranges,
61
+ });
62
+ return (response.data.valueRanges?.map((vr) => ({
63
+ range: vr.range ?? '',
64
+ values: vr.values ?? [],
65
+ })) ?? []);
66
+ }
67
+ /**
68
+ * Append values to a sheet
69
+ */
70
+ async appendValues(spreadsheetId, options) {
71
+ const response = await this.sheets.spreadsheets.values.append({
72
+ spreadsheetId,
73
+ range: options.range,
74
+ valueInputOption: options.valueInputOption ?? 'USER_ENTERED',
75
+ insertDataOption: options.insertDataOption ?? 'INSERT_ROWS',
76
+ requestBody: {
77
+ values: options.values,
78
+ },
79
+ });
80
+ return {
81
+ updatedRange: response.data.updates?.updatedRange ?? '',
82
+ updatedRows: response.data.updates?.updatedRows ?? 0,
83
+ updatedColumns: response.data.updates?.updatedColumns ?? 0,
84
+ };
85
+ }
86
+ /**
87
+ * Update values in a range
88
+ */
89
+ async updateValues(spreadsheetId, options) {
90
+ const response = await this.sheets.spreadsheets.values.update({
91
+ spreadsheetId,
92
+ range: options.range,
93
+ valueInputOption: options.valueInputOption ?? 'USER_ENTERED',
94
+ requestBody: {
95
+ values: options.values,
96
+ },
97
+ });
98
+ return {
99
+ updatedRange: response.data.updatedRange ?? '',
100
+ updatedRows: response.data.updatedRows ?? 0,
101
+ updatedColumns: response.data.updatedColumns ?? 0,
102
+ updatedCells: response.data.updatedCells ?? 0,
103
+ };
104
+ }
105
+ /**
106
+ * Update multiple ranges at once
107
+ */
108
+ async batchUpdateValues(spreadsheetId, options) {
109
+ const response = await this.sheets.spreadsheets.values.batchUpdate({
110
+ spreadsheetId,
111
+ requestBody: {
112
+ valueInputOption: options.valueInputOption ?? 'USER_ENTERED',
113
+ data: options.data,
114
+ },
115
+ });
116
+ return {
117
+ totalUpdatedRows: response.data.totalUpdatedRows ?? 0,
118
+ totalUpdatedColumns: response.data.totalUpdatedColumns ?? 0,
119
+ totalUpdatedCells: response.data.totalUpdatedCells ?? 0,
120
+ };
121
+ }
122
+ /**
123
+ * Clear values in a range
124
+ */
125
+ async clearValues(spreadsheetId, range) {
126
+ const response = await this.sheets.spreadsheets.values.clear({
127
+ spreadsheetId,
128
+ range,
129
+ });
130
+ return {
131
+ clearedRange: response.data.clearedRange ?? '',
132
+ };
133
+ }
134
+ /**
135
+ * Create a new spreadsheet
136
+ */
137
+ async createSpreadsheet(options) {
138
+ const response = await this.sheets.spreadsheets.create({
139
+ requestBody: {
140
+ properties: {
141
+ title: options.title,
142
+ locale: options.locale,
143
+ timeZone: options.timeZone,
144
+ },
145
+ sheets: options.sheets?.map((sheet) => ({
146
+ properties: {
147
+ title: sheet.title,
148
+ gridProperties: {
149
+ rowCount: sheet.rowCount ?? 1000,
150
+ columnCount: sheet.columnCount ?? 26,
151
+ },
152
+ },
153
+ })),
154
+ },
155
+ });
156
+ const data = response.data;
157
+ return {
158
+ spreadsheetId: data.spreadsheetId ?? '',
159
+ properties: {
160
+ title: data.properties?.title ?? '',
161
+ locale: data.properties?.locale ?? '',
162
+ autoRecalc: data.properties?.autoRecalc ?? '',
163
+ timeZone: data.properties?.timeZone ?? '',
164
+ },
165
+ sheets: data.sheets?.map((sheet) => ({
166
+ sheetId: sheet.properties?.sheetId ?? 0,
167
+ title: sheet.properties?.title ?? '',
168
+ index: sheet.properties?.index ?? 0,
169
+ sheetType: sheet.properties?.sheetType ?? '',
170
+ gridProperties: {
171
+ rowCount: sheet.properties?.gridProperties?.rowCount ?? 0,
172
+ columnCount: sheet.properties?.gridProperties?.columnCount ?? 0,
173
+ },
174
+ })) ?? [],
175
+ };
176
+ }
177
+ /**
178
+ * Add a new sheet to an existing spreadsheet
179
+ */
180
+ async addSheet(spreadsheetId, options) {
181
+ const response = await this.sheets.spreadsheets.batchUpdate({
182
+ spreadsheetId,
183
+ requestBody: {
184
+ requests: [
185
+ {
186
+ addSheet: {
187
+ properties: {
188
+ title: options.title,
189
+ index: options.index,
190
+ gridProperties: {
191
+ rowCount: options.rowCount ?? 1000,
192
+ columnCount: options.columnCount ?? 26,
193
+ },
194
+ },
195
+ },
196
+ },
197
+ ],
198
+ },
199
+ });
200
+ const addedSheet = response.data.replies?.[0]?.addSheet?.properties;
201
+ return {
202
+ sheetId: addedSheet?.sheetId ?? 0,
203
+ title: addedSheet?.title ?? '',
204
+ index: addedSheet?.index ?? 0,
205
+ sheetType: addedSheet?.sheetType ?? '',
206
+ gridProperties: {
207
+ rowCount: addedSheet?.gridProperties?.rowCount ?? 0,
208
+ columnCount: addedSheet?.gridProperties?.columnCount ?? 0,
209
+ },
210
+ };
211
+ }
212
+ /**
213
+ * Delete a sheet
214
+ */
215
+ async deleteSheet(spreadsheetId, sheetId) {
216
+ await this.sheets.spreadsheets.batchUpdate({
217
+ spreadsheetId,
218
+ requestBody: {
219
+ requests: [
220
+ {
221
+ deleteSheet: {
222
+ sheetId,
223
+ },
224
+ },
225
+ ],
226
+ },
227
+ });
228
+ }
229
+ /**
230
+ * Duplicate a sheet
231
+ */
232
+ async duplicateSheet(spreadsheetId, sourceSheetId, newSheetName) {
233
+ const response = await this.sheets.spreadsheets.batchUpdate({
234
+ spreadsheetId,
235
+ requestBody: {
236
+ requests: [
237
+ {
238
+ duplicateSheet: {
239
+ sourceSheetId,
240
+ newSheetName,
241
+ },
242
+ },
243
+ ],
244
+ },
245
+ });
246
+ const duplicatedSheet = response.data.replies?.[0]?.duplicateSheet?.properties;
247
+ return {
248
+ sheetId: duplicatedSheet?.sheetId ?? 0,
249
+ title: duplicatedSheet?.title ?? '',
250
+ index: duplicatedSheet?.index ?? 0,
251
+ sheetType: duplicatedSheet?.sheetType ?? '',
252
+ gridProperties: {
253
+ rowCount: duplicatedSheet?.gridProperties?.rowCount ?? 0,
254
+ columnCount: duplicatedSheet?.gridProperties?.columnCount ?? 0,
255
+ },
256
+ };
257
+ }
258
+ /**
259
+ * Find and replace text
260
+ */
261
+ async findReplace(spreadsheetId, find, replacement, options) {
262
+ const response = await this.sheets.spreadsheets.batchUpdate({
263
+ spreadsheetId,
264
+ requestBody: {
265
+ requests: [
266
+ {
267
+ findReplace: {
268
+ find,
269
+ replacement,
270
+ sheetId: options?.sheetId,
271
+ allSheets: options?.allSheets ?? false,
272
+ matchCase: options?.matchCase ?? false,
273
+ matchEntireCell: options?.matchEntireCell ?? false,
274
+ searchByRegex: options?.searchByRegex ?? false,
275
+ },
276
+ },
277
+ ],
278
+ },
279
+ });
280
+ const result = response.data.replies?.[0]?.findReplace;
281
+ return {
282
+ occurrencesChanged: result?.occurrencesChanged ?? 0,
283
+ valuesChanged: result?.valuesChanged ?? 0,
284
+ };
285
+ }
286
+ /**
287
+ * Sort a range
288
+ */
289
+ async sortRange(spreadsheetId, range, sortSpecs) {
290
+ await this.sheets.spreadsheets.batchUpdate({
291
+ spreadsheetId,
292
+ requestBody: {
293
+ requests: [
294
+ {
295
+ sortRange: {
296
+ range: this.parseA1Notation(range),
297
+ sortSpecs,
298
+ },
299
+ },
300
+ ],
301
+ },
302
+ });
303
+ }
304
+ /**
305
+ * Parse A1 notation into grid range
306
+ * Helper method for internal use
307
+ */
308
+ parseA1Notation(range) {
309
+ // This is a simplified parser - production code should handle more cases
310
+ const match = range.match(/^([A-Za-z]+)(\d+):([A-Za-z]+)(\d+)$/);
311
+ if (!match) {
312
+ throw new Error(`Invalid range format: ${range}`);
313
+ }
314
+ const [, startCol, startRow, endCol, endRow] = match;
315
+ const columnToIndex = (col) => {
316
+ let index = 0;
317
+ for (let i = 0; i < col.length; i++) {
318
+ index = index * 26 + col.charCodeAt(i) - 'A'.charCodeAt(0) + 1;
319
+ }
320
+ return index - 1;
321
+ };
322
+ return {
323
+ startRowIndex: parseInt(startRow) - 1,
324
+ endRowIndex: parseInt(endRow),
325
+ startColumnIndex: columnToIndex(startCol.toUpperCase()),
326
+ endColumnIndex: columnToIndex(endCol.toUpperCase()) + 1,
327
+ };
328
+ }
329
+ }
330
+ export const GoogleSheetsInitializer = {
331
+ async initialize(_module, config) {
332
+ const clientId = config.auth?.['client_id'];
333
+ const clientSecret = config.auth?.['client_secret'];
334
+ const redirectUri = config.auth?.['redirect_uri'];
335
+ const refreshToken = config.auth?.['refresh_token'];
336
+ const accessToken = config.auth?.['access_token'];
337
+ if (!clientId || !clientSecret || !redirectUri) {
338
+ throw new Error('Google Sheets SDK requires auth.client_id, auth.client_secret, auth.redirect_uri');
339
+ }
340
+ const oauth2Client = new google.auth.OAuth2(clientId, clientSecret, redirectUri);
341
+ oauth2Client.setCredentials({
342
+ refresh_token: refreshToken,
343
+ access_token: accessToken,
344
+ });
345
+ const sheets = google.sheets({ version: 'v4', auth: oauth2Client });
346
+ return {
347
+ client: sheets,
348
+ actions: new GoogleSheetsActions(sheets),
349
+ };
350
+ },
351
+ };
352
+ //# sourceMappingURL=google-sheets.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"google-sheets.js","sourceRoot":"","sources":["../../src/services/google-sheets.ts"],"names":[],"mappings":"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"}
@@ -0,0 +1,91 @@
1
+ /**
2
+ * MySQL Integration
3
+ *
4
+ * Popular open-source relational database.
5
+ * API: Using mysql2 driver
6
+ */
7
+ import { SDKInitializer } from '@marktoflow/core';
8
+ export interface MySQLConfig {
9
+ host: string;
10
+ port?: number;
11
+ database: string;
12
+ user: string;
13
+ password: string;
14
+ ssl?: boolean | {
15
+ rejectUnauthorized?: boolean;
16
+ };
17
+ connectTimeout?: number;
18
+ connectionLimit?: number;
19
+ waitForConnections?: boolean;
20
+ queueLimit?: number;
21
+ }
22
+ export interface QueryResult<T = unknown> {
23
+ rows: T[];
24
+ fields: {
25
+ name: string;
26
+ type: string;
27
+ }[];
28
+ affectedRows?: number;
29
+ insertId?: number;
30
+ }
31
+ export interface MySQLTransaction {
32
+ query<T = unknown>(sql: string, params?: unknown[]): Promise<QueryResult<T>>;
33
+ commit(): Promise<void>;
34
+ rollback(): Promise<void>;
35
+ }
36
+ /**
37
+ * MySQL client wrapper for workflow integration
38
+ * Note: This is a lightweight wrapper. The actual mysql2 module will be dynamically imported.
39
+ */
40
+ export declare class MySQLClient {
41
+ private pool;
42
+ private config;
43
+ constructor(config: MySQLConfig);
44
+ /**
45
+ * Initialize the connection pool
46
+ */
47
+ connect(): Promise<void>;
48
+ /**
49
+ * Execute a SQL query
50
+ */
51
+ query<T = unknown>(sql: string, params?: unknown[]): Promise<QueryResult<T>>;
52
+ /**
53
+ * Select data from a table
54
+ */
55
+ select<T = Record<string, unknown>>(table: string, options?: {
56
+ columns?: string[];
57
+ where?: Record<string, unknown>;
58
+ orderBy?: string;
59
+ limit?: number;
60
+ offset?: number;
61
+ }): Promise<T[]>;
62
+ /**
63
+ * Insert data into a table
64
+ */
65
+ insert<T = Record<string, unknown>>(table: string, data: Record<string, unknown> | Record<string, unknown>[]): Promise<{
66
+ insertId: number;
67
+ affectedRows: number;
68
+ }>;
69
+ /**
70
+ * Update data in a table
71
+ */
72
+ update<T = Record<string, unknown>>(table: string, data: Record<string, unknown>, where: Record<string, unknown>): Promise<{
73
+ affectedRows: number;
74
+ }>;
75
+ /**
76
+ * Delete data from a table
77
+ */
78
+ delete<T = Record<string, unknown>>(table: string, where: Record<string, unknown>): Promise<{
79
+ affectedRows: number;
80
+ }>;
81
+ /**
82
+ * Begin a transaction
83
+ */
84
+ transaction<T>(callback: (trx: MySQLTransaction) => Promise<T>): Promise<T>;
85
+ /**
86
+ * Close the connection pool
87
+ */
88
+ close(): Promise<void>;
89
+ }
90
+ export declare const MySQLInitializer: SDKInitializer;
91
+ //# sourceMappingURL=mysql.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"mysql.d.ts","sourceRoot":"","sources":["../../src/services/mysql.ts"],"names":[],"mappings":"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"}