node-red-contrib-image-generation-ubos
A Node-RED node that interacts with OpenAI machine learning models to generate image outputs like 'DALL·E 2'.
Quick Start
Install with the built in Node-RED Palette manager or using npm:
npm install node-red-contrib-image-generation-ubos
Setup
When editing the nodes properties, to get your OPENAI_API_KEY
log in to ChatGPT and then visit https://platform.openai.com/account/api-keys click "+ Create new secret key" then copy and paste the "API key" into the nodes API_KEY
property value.
To get your Organization
visit https://platform.openai.com/account/org-settings then copy and paste the "OrganizationID" into the nodes Organization
property value.
Properties
- [Required]
msg.OPENAI_API_KEY
: This is the API key provided by OpenAI. It is necessary for authentication when making requests to the OpenAI API.
-
When msg.type
is set to create_image
:
-
[Required] msg.prompt
: A text description of the desired image(s). The maximum length is 1000 characters.
-
msg.n
: The number of images to generate. Must be between 1 and 10.
-
msg.size
: The size of the generated images. Must be one of 256x256, 512x512, or 1024x1024.
-
msg.response_format
: The format in which the generated images are returned. Must be one of url or b64_json.
-
msg.user
: A unique identifier representing your end-user, which can help OpenAI to monitor and detect abuse. Learn more
-
When msg.type
is set to create_image_edit
:
- [Required]
msg.image
: The image to edit. Must be a valid PNG file, less than 4MB, and square. If mask is not provided, image must have transparency, which will be used as the mask. For example:
msg.image = {
"value": msg.req.files[0].buffer,
"options": {
"filename": msg.req.files[0].originalname
}
};
msg.mask
: An additional image whose fully transparent areas (e.g. where alpha is zero) indicate where image
should be edited. Must be a valid PNG file, less than 4MB, and have the same dimensions as image
. For example
msg.mask = {
"value": msg.req.files[1].buffer,
"options": {
"filename": msg.req.files[1].originalname
}
};
-
[Required] msg.prompt
: A text description of the desired image(s). The maximum length is 1000 characters.
-
msg.n
: The number of images to generate. Must be between 1 and 10.
-
msg.size
: The size of the generated images. Must be one of 256x256, 512x512, or 1024x1024.
-
msg.response_format
: The format in which the generated images are returned. Must be one of url or b64_json.
-
msg.user
: A unique identifier representing your end-user, which can help OpenAI to monitor and detect abuse. Learn more
-
When msg.type
is set to create_image_variation
:
- [Required]
msg.image
: The image to use as the basis for the variation(s). Must be a valid PNG file, less than 4MB, and square. For example
msg.image = {
"value": msg.req.files[0].buffer,
"options": {
"filename": msg.req.files[0].originalname
}
};
-
msg.n
: The number of images to generate. Must be between 1 and 10.
-
msg.size
: The size of the generated images. Must be one of 256x256, 512x512, or 1024x1024.
-
msg.response_format
: The format in which the generated images are returned. Must be one of url or b64_json.
-
msg.user
: A unique identifier representing your end-user, which can help OpenAI to monitor and detect abuse. Learn more
Demo
Create image
data:image/s3,"s3://crabby-images/e5cb8/e5cb88cf5bafbba0e88906674d24f11aaa008df9" alt="Group 21"
Image edit
data:image/s3,"s3://crabby-images/ab471/ab471c759935b86904449adaff43e3eecb432fee" alt="Group 21"
Image variation
data:image/s3,"s3://crabby-images/bd516/bd51697c853fe7e2b41ebada81105f409d94dd24" alt="Group 21 (1)"
Bugs reports and feature requests
Please report any issues or feature requests at GitHub.
License
MIT License