Skip to content

Nodes for interfacing with mqtt-based planning and monitoring systems

License

Notifications You must be signed in to change notification settings

smarc-project/smarc_nodered

 
 

Folders and files

NameName
Last commit message
Last commit date

Latest commit

 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 

Repository files navigation

smarc_nodered

A node to publish ROS stuff into MQTT, for use with node-red GUI of SMaRC. roslaunch smarc_nodered smarc_nodered.launch robot_name:=XXX broker_addr:=XXX broker_port:=XXX

By default, connects to the smarc server with robot_name sam.

mqtt_nodered

Contains the settings and docker files to setup the SMaRC node-red GUI. Also contains mapserver settings for Sweden bathymetry dataset(private).

Installation

apt install ros-{$ROS_DISTRO}-mqtt-bridge
apt install python-paho-mqtt

If {$ROS_DISTRO} == Noetic: pip install inject

If {$ROS_DISTRO} == Melodic: pip2 install --user Inject==3.5.4 Because melodic is now ancient and needs special elderly care...

Local installation

1- Install docker and docker-compose with your preffered method.

2- Start up the docker containers:

git clone https://github.com/smarc-project/smarc_nodered
cd smarc_nodered/mqtt_nodered
docker-compose up

(Ignore the error loading credentials and flows, we will load them later)

3- Connect to node-red flow on your browser: http://127.0.0.1:1880/flow/

4- Ask me for the username and password.

5- Ignore the welcome-wagon, press the 'x' on the pop-up

6- On the second pop-up about projects, click "Clone Repository"

7- Enter your name and email. This is used for commits and such. Not your github username and password!

8- Github settings

8-1- Git repository url: https://github.com/KKalem/smarc_nodered_cnc

8-2- Fill your github username and password (or gpg key)

8-3- Credentials encryption key: usual smarc password but with a 2.

8-4- Click Clone Project

9- You will see a pop-up telling you that some stuff is missing, close the pop-up

10- Hamburger-menu on top right > projects > project settings > dependencies

11- Click the install buttons on each one. You can spam them. Pop-ups will come, click install again.

12- In the background, you will see a MESS. Ignore the dread for now. Close the open pop-up.

13- Go back to the terminal where you ran docker-compose up, Ctrl-C, and again docker-compose up. This restarts everything.

14- Back to the browser. Refresh the page. The mess should be gone and no pop-ups should appear. You have now a working copy of the node-red interface.

Using the local installation

Updating

Node-RED flows (most likely):

  • Click the small git-branch icon on the right-panel, click commit history at the bottom, and then the up-down arrows right under.
  • Click pull.

Node-RED dependencies (less frequent):

  • Easy way: Hamburger menu -> Projects -> Dependencies -> click update on all.
  • Harder way: Navigate to smarc_nodered_cnc, git pull.
  • Either way: Restart the Node-RED container. (You can also kill them all and docker-compose up again)

After any update:

  • Deploy the changes with the top-right red button.

The UI

Its here: http://127.0.0.1:1880/ui

Use the usual smarc username and pw.

Connect your robot to this GUI

The robot connects to the local AND cloud-based GUIs at the same time. You shouldn't need to do anything.

About

Nodes for interfacing with mqtt-based planning and monitoring systems

Resources

License

Stars

Watchers

Forks

Releases

No releases published

Packages

No packages published

Languages

  • JavaScript 50.9%
  • Python 18.5%
  • CMake 12.9%
  • HTML 11.1%
  • CSS 6.6%