This is not an official Google product.
Node-RED nodes for Google Cloud Platform.
There are multiple ways to install node-red-contrib-google-cloud
. The official ways are described in the Node-RED documentation.
Property | Type | Description |
---|---|---|
name | string |
Label for easy idetification, essentially a comment. |
account | string |
Credentials in the form of a JSON key. |
The credentials for a service account can be acquired from the API Manager. After you finish creating a service account key it will be downloaded in a JSON format. Copy and paste the contents of the file directly into the Key field in the node editor.
Create a new flow or if this is your first flow use the default one. Next drag and drop the pubsub input node onto the workspace. Then double-click the node you just placed.
Click the button with the pencil icon next to input field that says Add new google-cloud-credentials...
. A new pane should appear with a Name
and Key
input field. The name can
be anything you like. The key must be the service account key. Refer to Google Cloud Credentials on how to obtain the key. After clicking done you will
be returned to the previous pane. Fill in the Topic
input field with an existing or new topic name and click done.
Next drag and drop the pubsub output node onto the workspace. Then double-click the node you just placed. The Credentials
input field will be automatically filled with the credentials
you created previously. Fill in the Topic
input field with the same name you used previously and click done.
We now have our input and output nodes, but we need some data. The easiest way to do this is using the inject input node with static data. Drag and drop the inject input node onto the workspace.
Then double-click the node you just placed. Change the Payload
type to string
and fill in the Payload
input field with some text, like Hello World!
. Lastly change the Repeat
type to interval
and click done.
At this point we need some way to view the data from the pubsub input node to make sure things are working. The easiest way to accomplish this is to use the debug output node. Drag and drop the debug output node onto the workspace. The default configuration will do with this node, but feel free to modify it.
Lastly we need to wire everything up. Connect the inject input node to the pubsub output node and the pubsub input node to the debug output node as shown below.
Click deploy. If everything goes well the pubsub nodes should change their status to connected
and/or publishing
. Switch to the debug
pane on the right side to view the payload.
Property | Type | Description |
---|---|---|
account | google-cloud-credentials |
See Google Cloud Credentials |
topic | string |
Name of the topic to subscribe to. |
subscription | string |
Name of the subscription to create. If null one will be autogenerated. |
ackDeadlineSeconds | integer |
Number of seconds to wait before attempting to redeliver a message. |
encoding | string |
Underlying encoding of the payload. Defaults to 'utf-8'. |
interval | integer |
Number of milliseconds between polling for messages. |
timeout | integer |
Number of milliseconds before giving up on an HTTP request. |
name | string |
Label for easy identification, essentially a comment. |
Property | Type | Description |
---|---|---|
payload | string |
The payload passed as-is from the PubSub message. |
time | date |
The timestamp converted to the number of milliseconds since 1 January 1970 UTC. |
project | string |
The name of Google Cloud Platform project. |
topic | string |
The name of the topic in Google Cloud Platform. |
subscription | string |
The name of the subscription in Google Cloud Platform. |
resource | string |
The URI of the resource in the form of /projects/project/subscriptions/subscription. |
Property | Type | Description |
---|---|---|
account | google-cloud-credentials |
See Google Cloud Credentials |
topic | string |
Name of the topic to publish to. |
name | string |
Label for easy identification, essentially a comment. |
Property | Type | Description |
---|---|---|
payload | string |
The payload passed as-is to the PubSub message. |
time | date |
The timestamp converted from the number of milliseconds since 1 January 1970 UTC. |
After installing node-red-contrib-google-cloud
the nodes are missing from the interface, where are they?
Refer to the Node-RED documentation for adding nodes. If you used one of the methods described there and are still have trouble try modifying the Node-RED configuration with a more verbose logging level and run Node-RED from the terminal, if you are not already. See the running Node-RED article for different ways of starting Node-RED.
After installing node-red-contrib-google-cloud
the logs contain errors about not finding the grpc_node.node module, what gives?
This issue usually comes up after installing node-red-contrib-google-cloud
globally i.e. sudo npm install -g node-red-contrib-google-cloud
. Some versions dislike running install scripts
as the root user and will silently fail to run the script, making the installation appear successful when in reality it failed. See this issue for more details.
The solution is to run the installation again, but append --unsafe-perm
to the command i.e. sudo npm install -g node-red-contrib-google-cloud --unsafe-perm
.