Skip to content

Instantly share code, notes, and snippets.

@cannikin
Forked from p123ad/README.md
Last active March 5, 2025 10:07
Show Gist options
  • Save cannikin/4954d050b72ff61ef0719c42922464e5 to your computer and use it in GitHub Desktop.
Save cannikin/4954d050b72ff61ef0719c42922464e5 to your computer and use it in GitHub Desktop.
Use Raspberry Pi Camera with Prusa Connect

Use Raspberry Pi and Pi Cam for Prusa Connect

I couldn't get the script from p123ad to work on my Pi Zero W 2 with Camera Module 3 (all kinds of ffmpeg errors). There are several built-in tools for working with the camera now, so I tried to figure out if I could use one of those instead.

Behold this version, which uses the built-in libcamera-still tool to actually interact with the camera and save a JPEG. That image is then uploaded to Prusa Connect, same as the original script.

Instructions

  1. Go to the Cameras section at https://connect.prusa3d.com
  2. Add a new camera by clicking "Add new other camera"
  3. Copy the generated Token
  4. Set up your Pi Zero W 2 with Raspian OS Lite (32-bit) (this may work with other combinations of Pi and OS but I haven't tested)
  5. Log into your Pi and create a shell script with sudo nano /usr/local/bin/prusaconnect_upload_cam.sh and swap out connect-token-here in the script example with the Token you copied in step 3
  6. Change ownership of the script to the user you log into your pi with, for example if your user is pi then run: sudo chown pi:pi /usr/local/bin/prusaconnect_upload_cam.sh
  7. Make the script executable: chmod +x /usr/local/bin/prusaconnect_upload_cam.sh
  8. Start the script with /usr/local/bin/prusaconnect_upload_cam.sh

If it works you should see no error messages, and a new image appearing in Prusa Connect every 10 seconds.

Create Autostart Service

To run the script in the background and have it start automatically when your Pi starts:

  1. Create the service file with sudo nano /etc/systemd/system/prusaconnect_upload_cam.service, paste the content from below and save.
  2. Start the service: sudo systemctl start prusaconnect_upload_cam.service.
  3. Check if the service is running with sudo systemctl status prusaconnect_upload_cam.service.
  4. Enable the service to run at startup: sudo systemctl enable prusaconnect_upload_cam.service.
[Unit]
Description=Raspi Cam to Prusa Connect
[Service]
ExecStart=/usr/local/bin/prusaconnect_upload_cam.sh
[Install]
WantedBy=multi-user.target
#!/bin/bash
# Set default values for environment variables
: "${HTTP_URL:=https://connect.prusa3d.com/c/snapshot}"
: "${DELAY_SECONDS:=10}"
: "${LONG_DELAY_SECONDS:=60}"
# FINGERPRINT can be a random string with at least 16 characters
: "${FINGERPRINT:=123456789012345678}"
# CAMERA_TOKEN generated by the Connect server
: "${CAMERA_TOKEN:=connect-token-here}"
while true; do
# Grab a frame from libcamera-still with the highest resolution
# that is displayed on Prusa Connect: 1704 x 1278 for a 4:3 image
# Setting the quality to 80 saves almost 50% in file size for
# very little decrease in quality. Set to taste!
# If you need to rotate the image 180Β° add `--rotate 180`
# (One user reported needing to make this `--camera.rotate 180` instead!)
libcamera-still -v 0 --immediate --width 2274 --height 1280 -q 80 -o /tmp/output.jpg
# If no error, upload it.
if [ $? -eq 0 ]; then
# POST the image to the HTTP URL using curl
curl -k -X PUT "$HTTP_URL" \
-H "accept: */*" \
-H "content-type: image/jpg" \
-H "fingerprint: $FINGERPRINT" \
-H "token: $CAMERA_TOKEN" \
--data-binary "@/tmp/output.jpg" \
--no-progress-meter \
--compressed
# Reset delay to the normal value
DELAY=$DELAY_SECONDS
else
echo "libcamera-still returned an error, retrying after ${LONG_DELAY_SECONDS}s..."
# Set delay to the longer value
DELAY=$LONG_DELAY_SECONDS
fi
sleep "$DELAY"
done
@cryinkfly
Copy link

I have configured this for my Logitech, Inc. HD Pro Webcam C920:

Bildschirmfoto_2024-09-10_17-04-16

@SlimeCodex
Copy link

BTW, on a fresh Pi Zero 2 I had to use --rotation 180 to make rotation work. Using --rotate or --camera.rotate gives me errors.

ERROR: *** unrecognised option '--rotate' ***
libcamera-still returned an error, retrying after 60s...
ERROR: *** unrecognised option '--camera.rotate' ***
libcamera-still returned an error, retrying after 60s...

Have a great day!

@cannikin
Copy link
Author

Updated the script to send the -k flag to curl: I was getting an error that the server's certificate couldn't be verified:

curl failed to verify the legitimacy of the server and therefore could not
establish a secure connection to it. To learn more about this situation and
how to fix it, please visit the web page mentioned above.

-k tells curl to skip this step.

@cmysayph
Copy link

cmysayph commented Jan 1, 2025

You can use the script above to make Prusaconnect work with any camera with an RTSP feed. The easiest way I found to do this is with FFmpeg.

ffmpeg -y -rtsp_transport tcp -i rtsp://user:password@IP_ADDRESS_OF_RTSP -update -frames:v 1 -update 1 /tmp/output.jpg

@aurbani
Copy link

aurbani commented Feb 1, 2025

Thanks for this guide

I got a Pi camera that died on arival so switched to a Webcam

Now you can use webcams with the above scritps but tweeked with different setups

Please see what I did

Setting Up a USB Webcam for Prusa Connect
Use a Raspberry Pi & Logitech C270 (or any USB webcam) to upload snapshots to Prusa Connect.

πŸ”Ή Features
βœ… Automatically captures images every 10 seconds
βœ… Uploads snapshots to Prusa Connect using API
βœ… Runs continuously and restarts on boot

πŸ“Œ Step 1: Install Required Software

sudo apt update && sudo apt upgrade -y
sudo apt install -y fswebcam curl

fswebcam β†’ Captures images from the Logitech C270
curl β†’ Uploads images to Prusa Connect

Step 2: Test the Camera

fswebcam -r 1280x720 --no-banner /home/pi/snapshot.jpg
ls -l /home/pi/snapshot.jpg

If the file exists, the camera is working!

Step 3: Create the Upload Script

nano ~/prusa-camera-upload.sh
Paste this:

#!/bin/bash

# Set default values for environment variables
: "${HTTP_URL:=https://connect.prusa3d.com/c/snapshot}"
: "${DELAY_SECONDS:=10}"
: "${LONG_DELAY_SECONDS:=60}"
# A unique string to identify your camera
: "${FINGERPRINT:=123456789012345678}"
# Prusa Connect Camera Token (Replace this with your actual token)
: "${CAMERA_TOKEN:=your_prusa_camera_token}"

while true; do
    # Capture an image using fswebcam
    fswebcam -r 1280x720 --no-banner /home/pi/snapshot.jpg

    # If capture was successful, upload it
    if [ $? -eq 0 ]; then
        curl -k -X PUT "$HTTP_URL" \
            -H "accept: */*" \
            -H "content-type: image/jpg" \
            -H "fingerprint: $FINGERPRINT" \
            -H "token: $CAMERA_TOKEN" \
            --data-binary "@/home/pi/snapshot.jpg" \
            --no-progress-meter \
            --compressed

        # Reset delay to normal value
        DELAY=$DELAY_SECONDS
    else
        echo "fswebcam failed, retrying in $LONG_DELAY_SECONDS seconds..."
        DELAY=$LONG_DELAY_SECONDS
    fi

    sleep "$DELAY"
done

Replace your_prusa_camera_token with your actual Prusa Connect camera token.

If you don’t have a token yet, generate one in Prusa Connect.

Example:
CAMERA_TOKEN="apJ3t1lz2d3Zqm5RI2E9"

Save and exit:

Press CTRL + X, then Y, then Enter.

Make the script executable:

chmod +x ~/prusa-camera-upload.sh

Step 4: Run the Script

~/prusa-camera-upload.sh

βœ… If successful, check Prusa Connect Web Cameras for updates.
❌ If it fails, check for errors

Step 5: Automate the Script on Boot

crontab -e

Add This at the buttom:
@reboot /home/pi/prusa-camera-upload.sh >/dev/null 2>&1

Save and exit.

Restart cron:
sudo systemctl restart cron

I also reboot the Pi:
sudo reboot now

The script will automatically start on boot.

And here is my result

Capture

@domosgabor
Copy link

Am I the only one who gets regurarly status_code:204 error messages? It's totally random, usually I have to restart the service every day. Sometimes it works for 10 hours, sometimes for 40 hours. Do you have any idea how can I fix this?

sudo systemctl status prusaconnect_upload_cam.service
● prusaconnect_upload_cam.service - Raspi Cam to Prusa Connect
Loaded: loaded (/etc/systemd/system/prusaconnect_upload_cam.service; enabled; preset: enabled)
Active: active (running) since Fri 2025-02-07 19:03:31 CET; 2 days ago
Main PID: 27648 (prusaconnect_up)
Tasks: 2 (limit: 1568)
CPU: 2h 3min 53.964s
CGroup: /system.slice/prusaconnect_upload_cam.service
β”œβ”€27648 /bin/bash /usr/local/bin/prusaconnect_upload_cam.sh
└─29610 curl -k -X PUT https://connect.prusa3d.com/c/snapshot -H "accept: /" -H "content-type: image/jpg>

Feb 09 18:53:19 raspberrypi prusaconnect_upload_cam.sh[29485]: {"status_code":204}
Feb 09 18:53:42 raspberrypi prusaconnect_upload_cam.sh[29496]: {"status_code":204}
Feb 09 18:54:20 raspberrypi prusaconnect_upload_cam.sh[29507]: {"status_code":204}
Feb 09 18:55:11 raspberrypi prusaconnect_upload_cam.sh[29518]: {"status_code":204}
Feb 09 18:55:44 raspberrypi prusaconnect_upload_cam.sh[29531]: {"status_code":204}
Feb 09 18:56:52 raspberrypi prusaconnect_upload_cam.sh[29542]: {"status_code":204}
Feb 09 18:57:28 raspberrypi prusaconnect_upload_cam.sh[29553]: {"status_code":204}
Feb 09 18:58:23 raspberrypi prusaconnect_upload_cam.sh[29564]: {"status_code":204}
Feb 09 18:58:50 raspberrypi prusaconnect_upload_cam.sh[29576]: {"status_code":204}
Feb 09 18:59:19 raspberrypi prusaconnect_upload_cam.sh[29587]: {"status_code":204}

@cannikin
Copy link
Author

cannikin commented Feb 9, 2025

@domosgabor So a 204 isn't an error in the HTTP world: it's a success and just the server saying "I have nothing to return": https://developer.mozilla.org/en-US/docs/Web/HTTP/Status/204 Do you find that once the 204s start showing up that your webcam images don't update on the Prusa site?

@domosgabor
Copy link

@domosgabor So a 204 isn't an error in the HTTP world: it's a success and just the server saying "I have nothing to return": https://developer.mozilla.org/en-US/docs/Web/HTTP/Status/204 Do you find that once the 204s start showing up that your webcam images don't update on the Prusa site?

Thanks for the clarification. Exactly as you said, the camera stops updating after getting 204 status code.

So it's not an error, but how can I investigate why the image is not updating?

Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment