mirror of
https://github.com/Abdulazizzn/n8n-enterprise-unlocked.git
synced 2025-12-17 18:12:04 +00:00
🔀 Merge branch 'ignore-bots' of https://github.com/pemontto/n8n into pemontto-ignore-bots
This commit is contained in:
@@ -21,6 +21,7 @@ import * as fs from 'fs';
|
|||||||
|
|
||||||
import * as formidable from 'formidable';
|
import * as formidable from 'formidable';
|
||||||
|
|
||||||
|
import * as isbot from 'isbot';
|
||||||
|
|
||||||
function authorizationError(resp: Response, realm: string, responseCode: number, message?: string) {
|
function authorizationError(resp: Response, realm: string, responseCode: number, message?: string) {
|
||||||
if (message === undefined) {
|
if (message === undefined) {
|
||||||
@@ -627,6 +628,13 @@ export class Wait implements INodeType {
|
|||||||
placeholder: 'webhook',
|
placeholder: 'webhook',
|
||||||
description: 'This suffix path will be appended to the restart URL. Helpful when using multiple wait nodes. Note: Does not support expressions.',
|
description: 'This suffix path will be appended to the restart URL. Helpful when using multiple wait nodes. Note: Does not support expressions.',
|
||||||
},
|
},
|
||||||
|
{
|
||||||
|
displayName: 'Ignore Bots',
|
||||||
|
name: 'ignoreBots',
|
||||||
|
type: 'boolean',
|
||||||
|
default: false,
|
||||||
|
description: 'Set to true to ignore requests from bots like link previewers and web crawlers',
|
||||||
|
},
|
||||||
// {
|
// {
|
||||||
// displayName: 'Raw Body',
|
// displayName: 'Raw Body',
|
||||||
// name: 'rawBody',
|
// name: 'rawBody',
|
||||||
@@ -656,6 +664,11 @@ export class Wait implements INodeType {
|
|||||||
const headers = this.getHeaderData();
|
const headers = this.getHeaderData();
|
||||||
const realm = 'Webhook';
|
const realm = 'Webhook';
|
||||||
|
|
||||||
|
const ignoreBots = options.ignoreBots as boolean;
|
||||||
|
if (ignoreBots && isbot((headers as IDataObject)['user-agent'] as string)) {
|
||||||
|
return authorizationError(resp, realm, 403);
|
||||||
|
}
|
||||||
|
|
||||||
if (incomingAuthentication === 'basicAuth') {
|
if (incomingAuthentication === 'basicAuth') {
|
||||||
// Basic authorization is needed to call webhook
|
// Basic authorization is needed to call webhook
|
||||||
const httpBasicAuth = await this.getCredentials('httpBasicAuth');
|
const httpBasicAuth = await this.getCredentials('httpBasicAuth');
|
||||||
|
|||||||
@@ -20,6 +20,8 @@ import * as fs from 'fs';
|
|||||||
|
|
||||||
import * as formidable from 'formidable';
|
import * as formidable from 'formidable';
|
||||||
|
|
||||||
|
import * as isbot from 'isbot';
|
||||||
|
|
||||||
function authorizationError(resp: Response, realm: string, responseCode: number, message?: string) {
|
function authorizationError(resp: Response, realm: string, responseCode: number, message?: string) {
|
||||||
if (message === undefined) {
|
if (message === undefined) {
|
||||||
message = 'Authorization problem!';
|
message = 'Authorization problem!';
|
||||||
@@ -378,6 +380,13 @@ export class Webhook implements INodeType {
|
|||||||
default: false,
|
default: false,
|
||||||
description: 'Raw body (binary)',
|
description: 'Raw body (binary)',
|
||||||
},
|
},
|
||||||
|
{
|
||||||
|
displayName: 'Ignore Bots',
|
||||||
|
name: 'ignoreBots',
|
||||||
|
type: 'boolean',
|
||||||
|
default: false,
|
||||||
|
description: 'Set to true to ignore requests from bots like link previewers and web crawlers',
|
||||||
|
},
|
||||||
],
|
],
|
||||||
},
|
},
|
||||||
],
|
],
|
||||||
@@ -391,6 +400,11 @@ export class Webhook implements INodeType {
|
|||||||
const headers = this.getHeaderData();
|
const headers = this.getHeaderData();
|
||||||
const realm = 'Webhook';
|
const realm = 'Webhook';
|
||||||
|
|
||||||
|
const ignoreBots = options.ignoreBots as boolean;
|
||||||
|
if (ignoreBots && isbot((headers as IDataObject)['user-agent'] as string)) {
|
||||||
|
return authorizationError(resp, realm, 403);
|
||||||
|
}
|
||||||
|
|
||||||
if (authentication === 'basicAuth') {
|
if (authentication === 'basicAuth') {
|
||||||
// Basic authorization is needed to call webhook
|
// Basic authorization is needed to call webhook
|
||||||
const httpBasicAuth = await this.getCredentials('httpBasicAuth');
|
const httpBasicAuth = await this.getCredentials('httpBasicAuth');
|
||||||
|
|||||||
@@ -709,6 +709,7 @@
|
|||||||
"iconv-lite": "^0.6.2",
|
"iconv-lite": "^0.6.2",
|
||||||
"ics": "^2.27.0",
|
"ics": "^2.27.0",
|
||||||
"imap-simple": "^4.3.0",
|
"imap-simple": "^4.3.0",
|
||||||
|
"isbot": "^3.3.4",
|
||||||
"iso-639-1": "^2.1.3",
|
"iso-639-1": "^2.1.3",
|
||||||
"jsonwebtoken": "^8.5.1",
|
"jsonwebtoken": "^8.5.1",
|
||||||
"kafkajs": "^1.14.0",
|
"kafkajs": "^1.14.0",
|
||||||
|
|||||||
Reference in New Issue
Block a user