@marvalt/madapter 2.2.2 → 2.3.2

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.
@@ -0,0 +1,459 @@
1
+ import fs from 'fs';
2
+ import path from 'path';
3
+
4
+ /**
5
+ * @license GPL-3.0-or-later
6
+ *
7
+ * This file is part of the MarVAlt Open SDK.
8
+ * Copyright (c) 2025 Vibune Pty Ltd.
9
+ *
10
+ * This program is free software: you can redistribute it and/or modify
11
+ * it under the terms of the GNU General Public License as published by
12
+ * the Free Software Foundation, either version 3 of the License, or
13
+ * (at your option) any later version.
14
+ *
15
+ * This program is distributed in the hope that it will be useful,
16
+ * but WITHOUT ANY WARRANTY; without even the implied warranty of
17
+ * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.
18
+ * See the GNU General Public License for more details.
19
+ */
20
+ class MauticClient {
21
+ constructor(config) {
22
+ this.config = config;
23
+ // Convention-based: Always use /api/mautic-submit unless explicitly overridden
24
+ this.proxyEndpoint = config.proxyEndpoint || '/api/mautic-submit';
25
+ }
26
+ async makeRequest(endpoint, options = {}) {
27
+ // Always use proxy endpoint (convention-based)
28
+ const proxyEndpoint = endpoint.startsWith('/') ? endpoint : `/${endpoint}`;
29
+ const url = `${this.proxyEndpoint}?endpoint=${encodeURIComponent(proxyEndpoint)}`;
30
+ const isFormSubmission = endpoint.startsWith('/form/submit') ||
31
+ (endpoint.startsWith('/forms/') && endpoint.includes('/submit'));
32
+ const headers = {
33
+ ...options.headers,
34
+ };
35
+ // Default JSON only for non-form submissions when a body exists and no explicit content-type provided
36
+ const hasBody = options.body != null && options.body !== undefined;
37
+ if (!isFormSubmission && hasBody && !('Content-Type' in headers)) {
38
+ headers['Content-Type'] = 'application/json';
39
+ }
40
+ try {
41
+ const response = await fetch(url, {
42
+ ...options,
43
+ headers,
44
+ });
45
+ // Determine if this was a form submission based on the original endpoint
46
+ const wasFormSubmission = endpoint.startsWith('/form/submit') ||
47
+ (endpoint.startsWith('/forms/') && endpoint.includes('/submit'));
48
+ if (!response.ok) {
49
+ // For form submissions, some Mautic setups respond with an HTML 404 after a successful submit.
50
+ // Do not treat this as an error; let the frontend handle success/redirect messaging.
51
+ const isRedirect = response.status >= 300 && response.status < 400;
52
+ const isHtmlLike = (response.headers.get('content-type') || '').includes('text/html');
53
+ if (!(wasFormSubmission && (isRedirect || response.status === 404 || isHtmlLike))) {
54
+ throw new Error(`Mautic API request failed: ${response.status} ${response.statusText}`);
55
+ }
56
+ }
57
+ const responseText = await response.text();
58
+ // Handle empty responses
59
+ if (!responseText) {
60
+ return [];
61
+ }
62
+ // For Mautic form submissions, the response may be HTML. Try JSON first, fallback to text.
63
+ try {
64
+ return JSON.parse(responseText);
65
+ }
66
+ catch {
67
+ return responseText;
68
+ }
69
+ }
70
+ catch (error) {
71
+ const message = error instanceof Error ? error.message : String(error);
72
+ console.error('Mautic API request error:', message);
73
+ throw new Error(message);
74
+ }
75
+ }
76
+ /**
77
+ * Submit a form to Mautic
78
+ */
79
+ async submitForm(formId, submission) {
80
+ const endpoint = `/form/submit?formId=${formId}`;
81
+ // Encode as application/x-www-form-urlencoded to match Mautic expectations
82
+ const formParams = new URLSearchParams();
83
+ // Add fields
84
+ Object.entries(submission.fields || {}).forEach(([alias, value]) => {
85
+ if (Array.isArray(value)) {
86
+ value.forEach((v) => formParams.append(`mauticform[${alias}]`, String(v)));
87
+ }
88
+ else if (typeof value === 'boolean') {
89
+ formParams.append(`mauticform[${alias}]`, value ? '1' : '0');
90
+ }
91
+ else if (value != null) {
92
+ formParams.append(`mauticform[${alias}]`, String(value));
93
+ }
94
+ });
95
+ // Required hidden fields
96
+ formParams.append('mauticform[formId]', String(formId));
97
+ // Prevent Mautic from attempting a redirect; frontend will handle any redirect
98
+ formParams.append('mauticform[return]', '');
99
+ // Mautic submit flag similar to native form button name/value
100
+ formParams.append('mauticform[submit]', '1');
101
+ // Include formName only if provided (derived from cachedHtml)
102
+ if (submission.formName) {
103
+ formParams.append('mauticform[formName]', submission.formName);
104
+ }
105
+ return this.makeRequest(endpoint, {
106
+ method: 'POST',
107
+ headers: {
108
+ 'Content-Type': 'application/x-www-form-urlencoded'
109
+ },
110
+ body: formParams.toString(),
111
+ });
112
+ }
113
+ /**
114
+ * Create a new contact in Mautic
115
+ */
116
+ async createContact(contact) {
117
+ return this.makeRequest('/contacts/new', {
118
+ method: 'POST',
119
+ body: JSON.stringify(contact),
120
+ });
121
+ }
122
+ /**
123
+ * Update an existing contact in Mautic
124
+ */
125
+ async updateContact(contactId, contact) {
126
+ return this.makeRequest(`/contacts/${contactId}/edit`, {
127
+ method: 'PATCH',
128
+ body: JSON.stringify(contact),
129
+ });
130
+ }
131
+ /**
132
+ * Get a contact by email
133
+ */
134
+ async getContactByEmail(email) {
135
+ return this.makeRequest(`/contacts?search=email:${encodeURIComponent(email)}`);
136
+ }
137
+ /**
138
+ * Get all forms from Mautic
139
+ */
140
+ async getForms() {
141
+ const response = await this.makeRequest('/forms');
142
+ return response.forms || [];
143
+ }
144
+ /**
145
+ * Get a specific form by ID
146
+ */
147
+ async getForm(formId) {
148
+ return this.makeRequest(`/forms/${formId}`);
149
+ }
150
+ /**
151
+ * Track an event in Mautic
152
+ */
153
+ async trackEvent(eventName, eventData = {}) {
154
+ return this.makeRequest('/events', {
155
+ method: 'POST',
156
+ body: JSON.stringify({
157
+ eventName,
158
+ eventData,
159
+ }),
160
+ });
161
+ }
162
+ /**
163
+ * Add tags to a contact
164
+ */
165
+ async addTagToContact(contactId, tags) {
166
+ return this.makeRequest(`/contacts/${contactId}/tags`, {
167
+ method: 'POST',
168
+ body: JSON.stringify({ tags }),
169
+ });
170
+ }
171
+ /**
172
+ * Remove tags from a contact
173
+ */
174
+ async removeTagFromContact(contactId, tags) {
175
+ return this.makeRequest(`/contacts/${contactId}/tags`, {
176
+ method: 'DELETE',
177
+ body: JSON.stringify({ tags }),
178
+ });
179
+ }
180
+ /**
181
+ * Get contact tags
182
+ */
183
+ async getContactTags(contactId) {
184
+ return this.makeRequest(`/contacts/${contactId}/tags`);
185
+ }
186
+ /**
187
+ * Get all tags
188
+ */
189
+ async getTags() {
190
+ return this.makeRequest('/tags');
191
+ }
192
+ /**
193
+ * Get segments
194
+ */
195
+ async getSegments() {
196
+ return this.makeRequest('/segments');
197
+ }
198
+ /**
199
+ * Add contact to segment
200
+ */
201
+ async addContactToSegment(contactId, segmentId) {
202
+ return this.makeRequest(`/contacts/${contactId}/segments`, {
203
+ method: 'POST',
204
+ body: JSON.stringify({ segmentId }),
205
+ });
206
+ }
207
+ /**
208
+ * Remove contact from segment
209
+ */
210
+ async removeContactFromSegment(contactId, segmentId) {
211
+ return this.makeRequest(`/contacts/${contactId}/segments`, {
212
+ method: 'DELETE',
213
+ body: JSON.stringify({ segmentId }),
214
+ });
215
+ }
216
+ }
217
+
218
+ /**
219
+ * @license GPL-3.0-or-later
220
+ *
221
+ * This file is part of the MarVAlt Open SDK.
222
+ * Copyright (c) 2025 Vibune Pty Ltd.
223
+ *
224
+ * This program is free software: you can redistribute it and/or modify
225
+ * it under the terms of the GNU General Public License as published by
226
+ * the Free Software Foundation, either version 3 of the License, or
227
+ * (at your option) any later version.
228
+ *
229
+ * This program is distributed in the hope that it will be useful,
230
+ * but WITHOUT ANY WARRANTY; without even the implied warranty of
231
+ * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.
232
+ * See the GNU General Public License for more details.
233
+ */
234
+ class MauticGenerator {
235
+ constructor(config) {
236
+ this.cachedToken = null;
237
+ this.config = config;
238
+ // Generator uses direct OAuth2 calls, not the client
239
+ // Client is only used for proxy mode (cloudflare_proxy)
240
+ this.client = new MauticClient({
241
+ apiUrl: config.apiUrl,
242
+ proxyEndpoint: config.cloudflareWorkerUrl,
243
+ timeout: config.timeout,
244
+ retries: config.retries,
245
+ });
246
+ }
247
+ /**
248
+ * Get OAuth2 token for direct mode API calls
249
+ */
250
+ async getOAuth2Token() {
251
+ if (this.cachedToken && this.cachedToken.expires_at > Date.now() + 300000) {
252
+ console.log('🔑 Using cached OAuth2 token');
253
+ return this.cachedToken.access_token;
254
+ }
255
+ if (!this.config.clientId || !this.config.clientSecret) {
256
+ throw new Error('OAuth2 credentials (clientId, clientSecret) required for direct mode');
257
+ }
258
+ console.log('🔑 Fetching new OAuth2 token...');
259
+ const tokenUrl = `${this.config.apiUrl}/oauth/v2/token`;
260
+ const body = new URLSearchParams({
261
+ grant_type: 'client_credentials',
262
+ client_id: this.config.clientId,
263
+ client_secret: this.config.clientSecret,
264
+ });
265
+ const headers = { 'Content-Type': 'application/x-www-form-urlencoded' };
266
+ if (this.config.cfAccessClientId && this.config.cfAccessClientSecret) {
267
+ headers['CF-Access-Client-Id'] = this.config.cfAccessClientId;
268
+ headers['CF-Access-Client-Secret'] = this.config.cfAccessClientSecret;
269
+ console.log('🔐 Added CF Access headers to OAuth2 token request');
270
+ }
271
+ const resp = await fetch(tokenUrl, { method: 'POST', headers, body: body.toString() });
272
+ if (!resp.ok) {
273
+ const errText = await resp.text();
274
+ throw new Error(`OAuth2 token failed: ${resp.status} ${errText}`);
275
+ }
276
+ const data = await resp.json();
277
+ this.cachedToken = {
278
+ access_token: data.access_token,
279
+ expires_at: Date.now() + (data.expires_in * 1000),
280
+ };
281
+ console.log('✅ OAuth2 token cached');
282
+ return this.cachedToken.access_token;
283
+ }
284
+ /**
285
+ * Generate static data for Mautic forms
286
+ */
287
+ async generateStaticData() {
288
+ console.log('🔄 Generating Mautic forms JSON data...');
289
+ try {
290
+ const allForms = await this.fetchMauticFormsList();
291
+ console.log(`📝 Found ${allForms.length} forms`);
292
+ const forms = [];
293
+ for (const formSummary of allForms) {
294
+ const formId = formSummary.id?.toString();
295
+ if (!formId) {
296
+ console.warn(`⚠️ Form summary missing ID:`, formSummary);
297
+ continue;
298
+ }
299
+ try {
300
+ const formDetails = await this.fetchMauticForm(formId);
301
+ if (!formDetails) {
302
+ console.warn(`⚠️ No form details returned for form ${formId}`);
303
+ continue;
304
+ }
305
+ // Extract the form data with proper structure
306
+ const formData = {
307
+ id: formId,
308
+ name: formDetails.name || formSummary.name || `Form ${formId}`,
309
+ description: formDetails.description,
310
+ isPublished: formDetails.isPublished || formSummary.isPublished || false,
311
+ // Include post-submission behavior configuration
312
+ postAction: formDetails.postAction || 'message',
313
+ postActionProperty: formDetails.postActionProperty || 'Thank you for your submission!',
314
+ // Include other important form properties
315
+ formType: formDetails.formType || 'standalone',
316
+ // Extract fields with validation and properties
317
+ fields: (formDetails.fields || []).map((field) => ({
318
+ id: field.id,
319
+ label: field.label,
320
+ alias: field.alias,
321
+ type: field.type,
322
+ isRequired: field.isRequired || false,
323
+ validationMessage: field.validationMessage,
324
+ defaultValue: field.defaultValue,
325
+ properties: {
326
+ placeholder: field.properties?.placeholder,
327
+ cssClass: field.properties?.cssClass,
328
+ validation: field.properties?.validation,
329
+ options: field.properties?.options,
330
+ helpText: field.properties?.helpText,
331
+ size: field.properties?.size,
332
+ ...field.properties
333
+ }
334
+ })),
335
+ // Extract actions
336
+ actions: (formDetails.actions || []).map((action) => ({
337
+ id: action.id,
338
+ name: action.name,
339
+ type: action.type,
340
+ properties: action.properties || {}
341
+ })),
342
+ // Include styling and behavior
343
+ cssClass: formDetails.cssClass,
344
+ submitAction: formDetails.submitAction,
345
+ // Keep the details for reference
346
+ ...formSummary
347
+ };
348
+ forms.push(formData);
349
+ console.log(`✅ Processed form: ${formData.name} (ID: ${formId})`);
350
+ }
351
+ catch (error) {
352
+ const message = error instanceof Error ? error.message : String(error);
353
+ console.error(`❌ Error processing form ${formId}:`, message);
354
+ // Continue with other forms
355
+ }
356
+ }
357
+ const staticData = {
358
+ generated_at: new Date().toISOString(),
359
+ total_forms: forms.length,
360
+ forms: forms.map((form) => ({
361
+ id: parseInt(form.id),
362
+ name: form.name,
363
+ alias: String(form.alias ?? (form.name || '').toLowerCase().replace(/\s+/g, '-')),
364
+ description: form.description,
365
+ isPublished: form.isPublished,
366
+ fields: form.fields,
367
+ actions: form.actions,
368
+ cssClass: form.cssClass,
369
+ submitAction: form.submitAction,
370
+ postAction: form.postAction,
371
+ postActionProperty: form.postActionProperty,
372
+ formType: form.formType,
373
+ }))
374
+ };
375
+ console.log(`✅ Generated static data for ${forms.length} forms`);
376
+ return staticData;
377
+ }
378
+ catch (error) {
379
+ const message = error instanceof Error ? error.message : String(error);
380
+ console.error('❌ Error generating Mautic static data:', message);
381
+ throw new Error(message);
382
+ }
383
+ }
384
+ /**
385
+ * Write static data to file
386
+ */
387
+ async writeStaticData(staticData) {
388
+ const outputPath = path.resolve(this.config.outputPath);
389
+ const outputDir = path.dirname(outputPath);
390
+ // Ensure output directory exists
391
+ if (!fs.existsSync(outputDir)) {
392
+ fs.mkdirSync(outputDir, { recursive: true });
393
+ }
394
+ // Write the static data
395
+ fs.writeFileSync(outputPath, JSON.stringify(staticData, null, 2));
396
+ console.log(`📁 Static data written to: ${outputPath}`);
397
+ }
398
+ /**
399
+ * Generate and write static data
400
+ */
401
+ async generateAndWrite() {
402
+ const staticData = await this.generateStaticData();
403
+ await this.writeStaticData(staticData);
404
+ return staticData;
405
+ }
406
+ /**
407
+ * Fetch list of forms from Mautic
408
+ */
409
+ async fetchMauticFormsList() {
410
+ if (this.config.authMode === 'cloudflare_proxy') {
411
+ const forms = await this.client.getForms();
412
+ return Array.isArray(forms) ? forms : [];
413
+ }
414
+ // Direct mode with OAuth2
415
+ const token = await this.getOAuth2Token();
416
+ const url = `${this.config.apiUrl}/api/forms`;
417
+ const headers = { 'Authorization': `Bearer ${token}` };
418
+ if (this.config.cfAccessClientId && this.config.cfAccessClientSecret) {
419
+ headers['CF-Access-Client-Id'] = this.config.cfAccessClientId;
420
+ headers['CF-Access-Client-Secret'] = this.config.cfAccessClientSecret;
421
+ }
422
+ const resp = await fetch(url, { headers });
423
+ if (!resp.ok)
424
+ throw new Error(`Failed to fetch forms: ${resp.status}`);
425
+ const data = await resp.json();
426
+ return Array.isArray(data.forms) ? data.forms : [];
427
+ }
428
+ /**
429
+ * Fetch individual form details from Mautic
430
+ */
431
+ async fetchMauticForm(formId) {
432
+ if (this.config.authMode === 'cloudflare_proxy') {
433
+ return this.client.getForm(parseInt(formId, 10));
434
+ }
435
+ // Direct mode with OAuth2
436
+ const token = await this.getOAuth2Token();
437
+ const url = `${this.config.apiUrl}/api/forms/${formId}`;
438
+ const headers = { 'Authorization': `Bearer ${token}` };
439
+ if (this.config.cfAccessClientId && this.config.cfAccessClientSecret) {
440
+ headers['CF-Access-Client-Id'] = this.config.cfAccessClientId;
441
+ headers['CF-Access-Client-Secret'] = this.config.cfAccessClientSecret;
442
+ }
443
+ const resp = await fetch(url, { headers });
444
+ if (!resp.ok)
445
+ throw new Error(`Failed to fetch form ${formId}: ${resp.status}`);
446
+ const data = await resp.json();
447
+ return data.form || data;
448
+ }
449
+ }
450
+ /**
451
+ * Generate Mautic static data with configuration
452
+ */
453
+ async function generateMauticData(config) {
454
+ const generator = new MauticGenerator(config);
455
+ return generator.generateAndWrite();
456
+ }
457
+
458
+ export { MauticGenerator, generateMauticData };
459
+ //# sourceMappingURL=generators.esm.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"generators.esm.js","sources":["../src/client/mautic-client.ts","../src/generators/mautic-generator.ts"],"sourcesContent":[null,null],"names":[],"mappings":"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"}