Security News
Bun 1.2 Released with 90% Node.js Compatibility and Built-in S3 Object Support
Bun 1.2 enhances its JavaScript runtime with 90% Node.js compatibility, built-in S3 and Postgres support, HTML Imports, and faster, cloud-first performance.
n8n-node-dev
Advanced tools
Currently very simple and not very sophisticated CLI which makes it easier to create credentials and nodes in TypeScript for n8n.
npm install n8n-node-dev -g
The commandline tool can be started with n8n-node-dev <COMMAND>
The following commands exist:
Builds credentials and nodes in the current folder and copies them into the
n8n custom extension folder (~/.n8n/custom/
) unless destination path is
overwritten with --destination <FOLDER_PATH>
When "--watch" gets set it starts in watch mode and automatically builds and copies files whenever they change. To stop press "ctrl + c".
Creates new basic credentials or node of the selected type to have a first starting point.
The easiest way to create a new node is via the "n8n-node-dev" cli. It sets up all the basics.
A n8n node is a JavaScript file (normally written in TypeScript) which describes some basic information (like name, description, ...) and also at least one method. Depending on which method got implemented defines if it is a a regular-, trigger- or webhook-node.
A simple regular node which:
would look like this:
File named: MyNode.node.ts
import { IExecuteFunctions } from 'n8n-core';
import {
INodeExecutionData,
INodeType,
INodeTypeDescription,
} from 'n8n-workflow';
export class MyNode implements INodeType {
description: INodeTypeDescription = {
displayName: 'My Node',
name: 'myNode',
group: ['transform'],
version: 1,
description: 'Adds "myString" on all items to defined value.',
defaults: {
name: 'My Node',
color: '#772244',
},
inputs: ['main'],
outputs: ['main'],
properties: [
// Node properties which the user gets displayed and
// can change on the node.
{
displayName: 'My String',
name: 'myString',
type: 'string',
default: '',
placeholder: 'Placeholder value',
description: 'The description text',
}
]
};
async execute(this: IExecuteFunctions): Promise<INodeExecutionData[][]> {
const items = this.getInputData();
let item: INodeExecutionData;
let myString: string;
// Itterates over all input items and add the key "myString" with the
// value the parameter "myString" resolves to.
// (This could be a different value for each item in case it contains an expression)
for (let itemIndex = 0; itemIndex < items.length; itemIndex++) {
myString = this.getNodeParameter('myString', itemIndex, '') as string;
item = items[itemIndex];
item.json['myString'] = myString;
}
return this.prepareOutputData(items);
}
}
The "description" property has to be set on all nodes because it contains all the base information. Additionally do all nodes have to have exactly one of the following methods defined which contains the actual logic:
Regular node
Method get called when the workflow gets executed
execute
: Executed once no matter how many itemsexecuteSingle
: Executed once for every itemBy default always execute
should be used especially when creating a
third-party integration. The reason for that is that it is way more flexible
and allows to, for example, return a different amount of items than it received
as input. This is very important when a node should query data like return
all users. In that case, does the node normally just receive one input-item
but returns as many as users exist. So in doubt always execute
should be
used!
Trigger node
Method gets called once when the workflow gets activated. It can then trigger workflow runs which data it provides by itself.
trigger
Webhook node
Method gets called when webhook gets called.
webhook
Property overview
Node Type Description
bellow.The following properties can be set in the node description:
The following properties can be set in the node properties:
The following properties can be set in the node property options.
All properties are optional. However, most only work when the node-property is of a specfic type.
n8n is fair-code distributed under the Sustainable Use License.
Additional information on the license can be found in the FAQ
FAQs
CLI to simplify n8n credentials/node development
The npm package n8n-node-dev receives a total of 184 weekly downloads. As such, n8n-node-dev popularity was classified as not popular.
We found that n8n-node-dev demonstrated a not healthy version release cadence and project activity because the last version was released a year ago. It has 6 open source maintainers collaborating on the project.
Did you know?
Socket for GitHub automatically highlights issues in each pull request and monitors the health of all your open source dependencies. Discover the contents of your packages and block harmful activity before you install or update your dependencies.
Security News
Bun 1.2 enhances its JavaScript runtime with 90% Node.js compatibility, built-in S3 and Postgres support, HTML Imports, and faster, cloud-first performance.
Security News
Biden's executive order pushes for AI-driven cybersecurity, software supply chain transparency, and stronger protections for federal and open source systems.
Security News
Fluent Assertions is facing backlash after dropping the Apache license for a commercial model, leaving users blindsided and questioning contributor rights.