diff --git a/packages/nodes-base/nodes/HttpRequest/V3/HttpRequestV3.node.ts b/packages/nodes-base/nodes/HttpRequest/V3/HttpRequestV3.node.ts index 295761af12fba..0d75c74c00d6e 100644 --- a/packages/nodes-base/nodes/HttpRequest/V3/HttpRequestV3.node.ts +++ b/packages/nodes-base/nodes/HttpRequest/V3/HttpRequestV3.node.ts @@ -1810,8 +1810,8 @@ export class HttpRequestV3 implements INodeType { } } + const responseContentType = response.headers['content-type'] ?? ''; if (autoDetectResponseFormat) { - const responseContentType = response.headers['content-type'] ?? ''; if (responseContentType.includes('application/json')) { responseFormat = 'json'; if (!response.__bodyResolved) { @@ -1890,7 +1890,22 @@ export class HttpRequestV3 implements INodeType { newItem.json = items[itemIndex].json; binaryData = response; } - newItem.binary![outputPropertyName] = await this.helpers.prepareBinaryData(binaryData); + const preparedBinaryData = await this.helpers.prepareBinaryData( + binaryData, + undefined, + responseContentType || undefined, + ); + + if ( + !preparedBinaryData.fileName && + preparedBinaryData.fileExtension && + typeof requestOptions.uri === 'string' && + requestOptions.uri.endsWith(preparedBinaryData.fileExtension) + ) { + preparedBinaryData.fileName = requestOptions.uri.split('/').pop(); + } + + newItem.binary![outputPropertyName] = preparedBinaryData; returnItems.push(newItem); } else if (responseFormat === 'text') {