Skip to main content

Command line tool for controlling your OctoPrint 3D printer server

This project has been archived.

The maintainers of this project have marked this project as archived. No new releases are expected.

Project description

octoprint-cli

version license

icon

Python 3 command line tool for controlling OctoPrint servers

This tool uses the OctoPrint API to control and view the status of 3D printers connected to OctoPrint servers

This project is a work in progress. Some features may not work as intended or be missing. If you have suggestions or find bugs, please report them in issues. Feel free to fork this repo to fix issues or to implement new features.

Features

These are the features that have been implemented so far, more functions will be implemented in the future. Current progress on features can be found on the project board.

  • Printer connection status
  • Print job status
  • File selection
  • Pause, resume, cancel prints
  • Start print
  • System commands (shutdown, reboot, restart)
  • Listing files/folders
  • Retrieving file/folder information
  • Setting extruder and bed temperature
  • Connect and disconnect from printer
  • Continuous status output with temperature status and progress bar
  • GCODE and STL file uploads to server storage
  • Run G-code on printer from terminal
  • Layer information from OctoPrint-DisplayLayerProgress plugin if installed on server

Limitations

Currently, octoprint-cli is limited to only printers with a single extruder and heated bed. Support for additional extruders and heated chambers may be implemented in the future. This program has been tested on OctoPi 0.17.0 on the Raspberry Pi 4 running OctoPrint 1.4.1 with a Monoprice Select Mini V2.

Colored and formatted text is not available on Windows systems due to the lack of support on cmd and powershell terminals

The program requires the API key to have all permissions to run

Installation

octoprint-cli can be installed from PyPI using pip. PyPI package can be found at https://pypi.org/project/octoprint-cli/

pip install octoprint-cli

octoprint-cli can also be installed manually using git and setup.py

git clone https://github.com/UserBlackBox/octoprint-cli.git
cd octoprint-cli
python3 setup.py install --user

Dependencies

Can be found in requirements.txt and installed with pip

  • termcolor
  • requests

Configuration

The tool reads its configuration from either config.ini in the application directory or from ~/.config/octoprint-cli.ini on Linux systems

A sample config file has been included in sample-config.ini

[server]
;Set OctoPrint server address and x-api-key
ServerAddress = SERVER_ADDRESS_HERE
ApiKey = API_KEY_HERE

[preferences]
;Set if the program uses colored or formatted text, this setting is turned off on windows due to cmd and powershell limitations
FormattedText = true
;Set if the program should check for updates
UpdateCheck = true

[printer]
;Set maximum temperature that printer can be set to
MaxExtruderTemp = 250
MaxBedTemp = 85

Usage

General Commands

octoprint-cli version - get OctoPrint server version information

octoprint-cli continuous - get continuous refreshing temperature, layer, and print status

Print Commands

octoprint-cli print status - get current print job status

octoprint-cli print select [path] - load file on server

octoprint-cli print start - start print job on loaded file

octoprint-cli print cancel - cancel current print job

octoprint-cli print pause - pauses the current print job

octoprint-cli print resume - resumes the current print job

octoprint-cli gcode [command] - run GCODE command on printer

octoprint-cli layers - get layer information during prints from the DisplayLayerProgress plugin

Connection Commands

octoprint-cli connection status - get OctoPrint print connection information

octoprint-cli connection connect - connect to printer, serial port and baudrate are decided automatically unless specified with the -b [BAUDRATE] and -p [PORT] flags

octoprint-cli connection disconnect - disconnect from printer

Temperature Commands

octoprint-cli temp status - get current and target temperatures of extruder and bed

octoprint-cli temp extruder [temp] - set target temperature of extruder

octoprint-cli temp bed [temp] - set target temperature of print bed

System Commands

octoprint-cli system restart - restart OctoPrint server

octoprint-cli system restart-safe - restart OctoPrint server to safe mode

octoprint-cli reboot - reboot OctoPrint server

octoprint-cli shutdown - shutdown OctoPrint server

File Commands

octoprint-cli files list - list files on OctoPrint server, listing in folders can be done with -p [PATH] flag, files/folders can be filtered using the --files and --folders flags

octoprint-cli files info [file] - get information on file on server

octoprint-cli files upload [file] - upload local file to server

The -h or --help flag can bring up a help message for all commands

The -v or --verbose flag can be used to view execution information like requests, useful for debugging configuration

Project details


Download files

Download the file for your platform. If you're not sure which to choose, learn more about installing packages.

Source Distribution

octoprint-cli-3.3.0.tar.gz (25.5 kB view details)

Uploaded Source

Built Distribution

If you're not sure about the file name format, learn more about wheel file names.

octoprint_cli-3.3.0-py3-none-any.whl (23.9 kB view details)

Uploaded Python 3

File details

Details for the file octoprint-cli-3.3.0.tar.gz.

File metadata

  • Download URL: octoprint-cli-3.3.0.tar.gz
  • Upload date:
  • Size: 25.5 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/3.3.0 pkginfo/1.6.1 requests/2.25.1 setuptools/54.1.2 requests-toolbelt/0.9.1 tqdm/4.55.1 CPython/3.9.2

File hashes

Hashes for octoprint-cli-3.3.0.tar.gz
Algorithm Hash digest
SHA256 25be070ca11114e7154cfce050182b124e59541b0b45eadbf838c827d3715a9d
MD5 4b0d0959c057ef5149604598cdd57a93
BLAKE2b-256 31aa960f5268db40cccbbcf9d10f3de1dbe972faa890f03162da364e15fe5bbd

See more details on using hashes here.

File details

Details for the file octoprint_cli-3.3.0-py3-none-any.whl.

File metadata

  • Download URL: octoprint_cli-3.3.0-py3-none-any.whl
  • Upload date:
  • Size: 23.9 kB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/3.3.0 pkginfo/1.6.1 requests/2.25.1 setuptools/54.1.2 requests-toolbelt/0.9.1 tqdm/4.55.1 CPython/3.9.2

File hashes

Hashes for octoprint_cli-3.3.0-py3-none-any.whl
Algorithm Hash digest
SHA256 0f09e78168d9010a1a9e47fce6bc305b98763e5f47783a90200ff8ec7a8f79c6
MD5 1e3d91620af4225f1fa313b9f552c531
BLAKE2b-256 60a57119679c0998e7e48b79b2f8e1c1bf8d1b1d6bfbc5518f91e13b8cdf1f57

See more details on using hashes here.

Supported by

AWS Cloud computing and Security Sponsor Datadog Monitoring Depot Continuous Integration Fastly CDN Google Download Analytics Pingdom Monitoring Sentry Error logging StatusPage Status page