n8n-nodes-ume-v4 4.5.16 → 4.5.18

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.
@@ -138,77 +138,148 @@ class UmeSocialSeeding {
138
138
  }
139
139
 
140
140
  // Add service-specific parameters
141
- for (const parameter of serviceData.parameters) {
141
+ // First, get all dynamic parameters that might be count_server_1, count_server_2, etc.
142
+ const allParameterNames = [];
143
+ serviceData.parameters.forEach(param => {
144
+ allParameterNames.push(param.name);
145
+ });
146
+
147
+ // Add server-specific count parameters if this service has servers
148
+ if (serviceData.servers && serviceData.parameters.find(p => p.name === 'count')) {
149
+ const serverParam = serviceData.parameters.find(p => p.name === 'server');
150
+ if (serverParam && serverParam.options) {
151
+ serverParam.options.forEach(serverOption => {
152
+ allParameterNames.push(`count_${serverOption.value}`);
153
+ });
154
+ }
155
+ }
156
+
157
+ // Now process all parameters (both static and dynamic)
158
+ for (const parameterName of allParameterNames) {
159
+ // Find the original parameter definition
160
+ let parameter = serviceData.parameters.find(p => p.name === parameterName);
161
+
162
+ // Check if this is a server-specific count parameter
163
+ if (parameterName.startsWith('count_') && !parameter) {
164
+ parameter = {
165
+ name: parameterName,
166
+ type: 'number',
167
+ displayName: `Số lượng (${parameterName})`
168
+ };
169
+ }
170
+
171
+ if (!parameter) continue;
142
172
 
143
173
  if (parameter.type === 'string') {
144
- const value = this.getNodeParameter(parameter.name, itemIndex, "");
145
- if (parameter.name === 'uid') {
174
+ const value = this.getNodeParameter(parameterName, itemIndex, "");
175
+ if (parameterName === 'uid') {
146
176
  // Extract ID from URL for UID services
147
177
  const extractedValue = (0, UmeSocialSeedingHelpers_1.extractIdFromUrl)(value.trim() || '', serviceName);
148
- formBody[parameter.name] = extractedValue;
178
+ formBody[parameterName] = extractedValue;
149
179
  }
150
- else if (parameter.name === 'url') {
180
+ else if (parameterName === 'url') {
151
181
  // For URL services, send the URL as-is without extraction
152
- formBody[parameter.name] = value.trim();
182
+ formBody[parameterName] = value.trim();
153
183
  }
154
- else if (parameter.name === 'link') {
184
+ else if (parameterName === 'link') {
155
185
  // For Instagram, TikTok, YouTube - send the URL as-is without extraction
156
- formBody[parameter.name] = value.trim();
186
+ formBody[parameterName] = value.trim();
157
187
  }
158
- else if (parameter.name === 'note') {
188
+ else if (parameterName === 'note') {
159
189
  // Set default note if empty
160
- formBody[parameter.name] = value.trim() || "Auto-generated by n8n UME Social Seeding";
190
+ formBody[parameterName] = value.trim() || "Auto-generated by n8n UME Social Seeding";
161
191
  }
162
- else if (parameter.name === 'comments') {
192
+ else if (parameterName === 'comments') {
163
193
  // Process comment list - convert multiline to API format
164
194
  const processedComments = (0, UmeSocialSeedingHelpers_1.processCommentList)(value.trim() || '');
165
195
  if (processedComments) {
166
- formBody[parameter.name] = processedComments;
196
+ formBody[parameterName] = processedComments;
167
197
  }
168
198
  }
169
- else if (parameter.name === 'list_comment') {
199
+ else if (parameterName === 'list_comment') {
170
200
  // Process comment list - convert multiline to API format
171
201
  const processedComments = (0, UmeSocialSeedingHelpers_1.processCommentList)(value.trim() || '');
172
202
  if (processedComments) {
173
- formBody[parameter.name] = processedComments;
203
+ formBody[parameterName] = processedComments;
174
204
  }
175
205
  }
176
206
  else if (value && value.trim() !== "") {
177
- formBody[parameter.name] = value.trim();
207
+ formBody[parameterName] = value.trim();
178
208
  }
179
209
  }
180
210
  else if (parameter.type === 'textarea') {
181
- const value = this.getNodeParameter(parameter.name, itemIndex, "");
182
- if (parameter.name === 'list_comment') {
211
+ const value = this.getNodeParameter(parameterName, itemIndex, "");
212
+ if (parameterName === 'list_comment') {
183
213
  // Process comment list - convert multiline to API format
184
214
  const processedComments = (0, UmeSocialSeedingHelpers_1.processCommentList)(value.trim());
185
215
  if (processedComments) {
186
- formBody[parameter.name] = processedComments;
216
+ formBody[parameterName] = processedComments;
187
217
  }
188
218
  }
189
- else if (parameter.name === 'uid') {
219
+ else if (parameterName === 'uid') {
190
220
  // Extract ID from URL for UID services
191
221
  const extractedValue = (0, UmeSocialSeedingHelpers_1.extractIdFromUrl)(value.trim() || '', serviceName);
192
- formBody[parameter.name] = extractedValue;
222
+ formBody[parameterName] = extractedValue;
193
223
  }
194
- else if (parameter.name === 'url') {
224
+ else if (parameterName === 'url') {
195
225
  // For URL services, send the URL as-is without extraction
196
- formBody[parameter.name] = value.trim();
226
+ formBody[parameterName] = value.trim();
197
227
  }
198
228
  else if (value && value.trim() !== "") {
199
- formBody[parameter.name] = value.trim();
229
+ formBody[parameterName] = value.trim();
200
230
  }
201
231
  }
202
232
  else if (parameter.type === 'number') {
203
- let value = this.getNodeParameter(parameter.name, itemIndex);
204
- if (value !== undefined && value !== null && !isNaN(Number(value))) {
205
- formBody[parameter.name] = Number(value).toString();
233
+ let value = this.getNodeParameter(parameterName, itemIndex);
234
+
235
+ // Handle server-specific count parameters (count_server_1, count_server_2, etc.)
236
+ if (parameterName.startsWith('count_') && selectedServerInfo) {
237
+ // This is a server-specific count parameter, get the actual value
238
+ if (value !== undefined && value !== null && !isNaN(Number(value))) {
239
+ formBody['count'] = Number(value).toString();
240
+ }
241
+ }
242
+ // Handle regular count parameter (fallback for services without server-specific counts)
243
+ else if (parameterName === 'count' && selectedServerInfo) {
244
+ // If no value provided or value is less than server MIN, use server MIN
245
+ if (value === undefined || value === null || isNaN(Number(value)) || Number(value) < selectedServerInfo.minQuantity) {
246
+ const originalValue = value;
247
+ value = selectedServerInfo.minQuantity;
248
+ // Store adjustment info for potential debugging
249
+ formBody._countAdjusted = {
250
+ originalValue,
251
+ adjustedTo: value,
252
+ reason: `Below server MIN (${selectedServerInfo.minQuantity})`,
253
+ server: selectedServer
254
+ };
255
+ }
256
+
257
+ // Also enforce server MAX if value exceeds it
258
+ if (Number(value) > selectedServerInfo.maxQuantity) {
259
+ const originalValue = value;
260
+ value = selectedServerInfo.maxQuantity;
261
+ formBody._countAdjusted = {
262
+ originalValue,
263
+ adjustedTo: value,
264
+ reason: `Above server MAX (${selectedServerInfo.maxQuantity})`,
265
+ server: selectedServer
266
+ };
267
+ }
268
+
269
+ if (value !== undefined && value !== null && !isNaN(Number(value))) {
270
+ formBody['count'] = Number(value).toString();
271
+ }
272
+ } else {
273
+ // Regular number parameter (not count)
274
+ if (value !== undefined && value !== null && !isNaN(Number(value))) {
275
+ formBody[parameterName] = Number(value).toString();
276
+ }
206
277
  }
207
278
  }
208
279
  else if (parameter.type === 'options') {
209
- const value = this.getNodeParameter(parameter.name, itemIndex, "");
280
+ const value = this.getNodeParameter(parameterName, itemIndex, "");
210
281
  if (value && value.trim() !== "") {
211
- formBody[parameter.name] = value.trim();
282
+ formBody[parameterName] = value.trim();
212
283
  }
213
284
  }
214
285
  }
@@ -115,7 +115,39 @@ function getDynamicProperties() {
115
115
  },
116
116
  };
117
117
 
118
-
118
+ // Add server-specific count parameters (one for each server)
119
+ if (parameter.name === 'count' && serverParam && serverParam.options) {
120
+ // Instead of one count parameter, create server-specific ones
121
+ serverParam.options.forEach((serverOption) => {
122
+ const serverInfo = serviceData.servers?.find(s =>
123
+ s.id === serverOption.value || s.server_id === serverOption.value
124
+ );
125
+
126
+ const serverSpecificCount = {
127
+ ...parameter,
128
+ name: `count_${serverOption.value}`,
129
+ displayName: `Số lượng (${serverOption.name})`,
130
+ default: serverInfo?.minQuantity || parameter.default || 50,
131
+ typeOptions: {
132
+ minValue: serverInfo?.minQuantity || parameter.typeOptions?.minValue || 1,
133
+ maxValue: serverInfo?.maxQuantity || parameter.typeOptions?.maxValue || 999999999
134
+ },
135
+ displayOptions: {
136
+ show: {
137
+ platform: [platformKey],
138
+ service: [serviceName],
139
+ server: [serverOption.value]
140
+ },
141
+ },
142
+ description: `Số lượng cần tăng (${serverOption.name}: ${serverInfo?.minQuantity || 'N/A'} - ${serverInfo?.maxQuantity || 'N/A'})`,
143
+ };
144
+ serviceParameters.push(serverSpecificCount);
145
+ });
146
+
147
+ // Skip adding the original count parameter
148
+ continue;
149
+ }
150
+
119
151
  serviceParameters.push(paramProperty);
120
152
  }
121
153
  }