nodered.py

make python function to Node-RED node


License
MIT
Install
pip install nodered.py==0.2.12

Documentation

NodeRED.py

make python function to Node-RED node




🎛️ requirements

  • node.js 18.16.1 or higher(latest stable)
    • nodered.py 0.2.6 or higher, automatically download from internet if no node.js installed
  • python 3.7 or higher
  • tested on
OS Tested Pass
Mac 13(Ventura)
Windows 10
Linux(WSL) 🚫



🌐 install

- using pip

python -m pip install nodered.py

- using git(dev)

python -m pip install git+https://github.com/oyajiDev/NodeRED.py.git



🛠 usage

Node-RED initialize

from noderedpy import REDBuilder, RED, Auth

# using builder
red = REDBuilder()\
    .set_user_dir("{user_dir}")\
    .set_node_red_dir("{node_red_dir}")\
    .set_admin_root("{admin_root}")\
    .set_node_root("{node_root}")\
    .set_port(port)\
    .set_default_flow("{default_flow}")\
    .set_remote_access(remote_access)\
    .set_default_categories([{default_categories}])\
    .build()

# using RED directly
red = RED(
    "{user_dir}", "{node_red_dir}",
    "{admin_root}", "{node_root}", port, "{default_flow}",
    remote_access, [{default_categories}]
)

# change editor theme settings
red.editor_theme.palette.editable = False
red.editor_theme.projects.enabled = False

# add auths
red.node_auths.append(
    Auth(username = "node-red-py", password = "p@ssword")
)

register Node

register as decorator

from noderedpy import Node
from noderedpy.decorator import register

@register("test")
def test(node:Node, props:dict, msg:dict) -> dict:
    # user codes here
    return msg

register from Node-RED object

api = API()

red.register("test", api.test)

register route

route(get, post)

  • register as decorator
from noderedpy.decorator import route

# get
@route("{route_url}", "get")
def route1(params:dict) -> dict:
    return {}

# post
@route("{route_url}", "post")
def route1(datas:dict) -> dict:
    return {}
  • register from Node-RED object
# get
red.route(lambda params: {}, "{route_url}", "get")

# post
red.route(lambda datas: {}, "{route_url}", "post")

static

red.static("/static", "{static_directory_or_file_path}")

start Node-RED

red.start({debug:bool}, {callback:MethodType})



Todos

✅ type support for "list" and "dict"



Roadmap To 2.0

✅ remove aiohttp server

🟩 flexible property ui