MrDraw/docs/api/printer.rst

973 lines
28 KiB
ReStructuredText
Raw Normal View History

2013-12-16 00:47:06 +00:00
.. _sec-api-printer:
******************
Printer operations
******************
2013-12-16 00:47:06 +00:00
.. warning::
This part of the API is still heavily in development, especially anything that has to do with temperature control.
If you happen to want to develop against it, you should drop me an email to make sure I can give you a heads-up when
something changes.
2013-12-21 12:01:18 +00:00
.. contents::
Printer control is mostly achieved through the use of commands, issued to resources reflecting components of the
printer. OctoPrint currently knows the following components:
Print head
Print head commands allow jogging and homing the print head in all three axes. Querying the resource is currently
not supported.
See :ref:`sec-api-printer-printheadcommand`.
Tool
Tool commands allow setting the temperature and temperature offsets for the printer's hotends/tools. Querying the
corresponding resource returns temperature information including an optional history.
See :ref:`sec-api-printer-toolcommand`.
Bed
Bed commands allow setting the temperature and temperature offset for the printer's heated bed. Querying the
corresponding resource returns temperature information including an optional history.
See :ref:`sec-api-printer-bedcommand`.
2013-12-21 12:01:18 +00:00
SD card
SD commands allow initialization, refresh and release of the printer's SD card (if available). Querying the
corresponding resource returns the current SD card state.
See :ref:`sec-api-printer-sdcommand`.
Besides that, OctoPrint also provides a :ref:`full state report of the printer <sec-api-printer-state>`.
.. _sec-api-printer-state:
Retrieve the current printer state
==================================
.. http:get:: /api/printer
Retrieves the current state of the printer. Returned information includes:
* temperature information (see also :ref:`Retrieve the current tool state <sec-api-printer-toolstate>` and
:ref:`Retrieve the current bed state <sec-api-printer-bedstate>`)
* sd state (if available, see also :ref:`Retrieve the current SD state <sec-api-printer-sdstate>`)
* general printer state
Temperature information can also be made to include the printer's temperature history by supplying the ``history``
query parameter. The amount of data points to return here can be limited using the ``limit`` query parameter.
Clients can specific a list of attributes to not return in the response (e.g. if they don't need it) via the
``exclude`` query parameter.
Returns a :http:statuscode:`200` with a :ref:`Full State Response <sec-api-printer-datamodel-fullstate>` in the
body upon success.
**Example 1**
Include temperature history data, but limit it to two entries.
.. sourcecode:: http
GET /api/printer?history=true&limit=2 HTTP/1.1
Host: example.com
X-Api-Key: abcdef...
.. sourcecode:: http
HTTP/1.1 200 OK
Content-Type: application/json
{
"temperature": {
"tool0": {
"actual": 214.8821,
"target": 220.0,
"offset": 0
},
"tool1": {
"actual": 25.3,
"target": null,
"offset": 0
},
"bed": {
"actual": 50.221,
"target": 70.0,
"offset": 5
},
"history": [
{
"time": 1395651928,
"tool0": {
"actual": 214.8821,
"target": 220.0
},
"tool1": {
"actual": 25.3,
"target": null
},
"bed": {
"actual": 50.221,
"target": 70.0
}
},
{
"time": 1395651926,
"tool0": {
"actual": 212.32,
"target": 220.0
},
"tool1": {
"actual": 25.1,
"target": null
},
"bed": {
"actual": 49.1123,
"target": 70.0
}
}
]
},
"sd": {
"ready": true
},
"state": {
"text": "Operational",
"flags": {
"operational": true,
"paused": false,
"printing": false,
"sdReady": true,
"error": false,
"ready": true,
"closedOrError": false
}
}
}
**Example 2**
Exclude temperature and sd data.
.. sourcecode:: http
GET /api/printer?exclude=temperature,sd HTTP/1.1
Host: example.com
X-Api-Key: abcdef...
.. sourcecode:: http
HTTP/1.1 200 OK
Content-Type: application/json
{
"state": {
"text": "Operational",
"flags": {
"operational": true,
"paused": false,
"printing": false,
"sdReady": true,
"error": false,
"ready": true,
"closedOrError": false
}
}
}
:query exclude: An optional comma-separated list of fields to exclude from the response (e.g. if not needed by
the client). Valid values to supply here are ``temperature``, ``sd`` and ``state``.
:query history: If set to ``true`` (or: ``yes``, ``y``, ``1``), history information will be included in the response
too. If no ``limit`` parameter is given, all available temperature history data will be returned.
:query limit: If set to an integer (``n``), only the last ``n`` data points from the printer's temperature history
will be returned. Will be ignored if ``history`` is not enabled.
:statuscode 200: No error
:statuscode 409: If the printer is not operational.
2013-12-21 12:01:18 +00:00
.. _sec-api-printer-printheadcommand:
2013-12-16 00:47:06 +00:00
Issue a print head command
==========================
.. http:post:: /api/printer/printhead
2013-12-16 00:47:06 +00:00
Print head commands allow jogging and homing the print head in all three axes. Available commands are:
jog
Jogs the print head (relatively) by a defined amount in one or more axes. Additional parameters are:
* ``x``: Optional. Amount to jog print head on x axis, must be a valid number corresponding to the distance to travel in mm.
* ``y``: Optional. Amount to jog print head on y axis, must be a valid number corresponding to the distance to travel in mm.
* ``z``: Optional. Amount to jog print head on z axis, must be a valid number corresponding to the distance to travel in mm.
home
Homes the print head in all of the given axes. Additional parameters are:
* ``axes``: A list of axes which to home, valid values are one or more of ``x``, ``y``, ``z``.
feedrate
Changes the feedrate factor to apply to the movement's of the axes.
* ``factor``: The new factor, percentage as integer or float (percentage divided by 100) between 50 and 200%.
All of these commands except ``feedrate`` may only be sent if the printer is currently operational and not printing.
Otherwise a :http:statuscode:`409` is returned.
2013-12-21 12:01:18 +00:00
Upon success, a status code of :http:statuscode:`204` and an empty body is returned.
2013-12-16 00:47:06 +00:00
**Example Jog Request**
Jog the print head by 10mm in X, -5mm in Y and 0.02mm in Z.
.. sourcecode:: http
POST /api/printer/printhead HTTP/1.1
2013-12-16 00:47:06 +00:00
Host: example.com
Content-Type: application/json
X-Api-Key: abcdef...
{
"command": "jog",
"x": 10,
"y": -5,
"z": 0.02
}
.. sourcecode:: http
HTTP/1.1 204 No Content
2013-12-16 00:47:06 +00:00
**Example Home Request**
Home the X and Y axes.
.. sourcecode:: http
POST /api/printer/printhead HTTP/1.1
2013-12-16 00:47:06 +00:00
Host: example.com
Content-Type: application/json
X-Api-Key: abcdef...
{
"command": "home",
"axes": ["x", "y"]
}
.. sourcecode:: http
HTTP/1.1 204 No Content
**Example feed rate request**
Set the feed rate factor to 105%.
.. sourcecode:: http
POST /api/printer/printhead HTTP/1.1
Host: example.com
Content-Type: application/json
X-Api-Key: abcdef...
{
"command": "feedrate",
"factor": 105
}
.. sourcecode:: http
HTTP/1.1 204 No Content
2013-12-16 00:47:06 +00:00
:json string command: The command to issue, either ``jog`` or ``home``.
:json number x: ``jog`` command: The amount to travel on the X axis in mm.
:json number y: ``jog`` command: The amount to travel on the Y axis in mm.
:json number z: ``jog`` command: The amount to travel on the Z axis in mm.
:json array axes: ``home`` command: The axes which to home, valid values are one or more of ``x``, ``y`` and ``z``.
:json number factor: ``feedrate`` command: The factor to apply to the feed rate, percentage between 50 and 200% as integer or float.
2013-12-21 12:01:18 +00:00
:statuscode 204: No error
:statuscode 400: Invalid axis specified, invalid value for travel amount for a jog command or factor for feed rate or otherwise invalid
2013-12-16 00:47:06 +00:00
request.
2013-12-21 12:01:18 +00:00
:statuscode 409: If the printer is not operational or currently printing.
2013-12-16 00:47:06 +00:00
.. _sec-api-printer-toolcommand:
Issue a tool command
====================
2013-12-16 00:47:06 +00:00
.. http:post:: /api/printer/tool
2013-12-16 00:47:06 +00:00
Tool commands allow setting the temperature and temperature offsets for the printer's tools (hotends), selecting
the current tool and extruding/retracting from the currently selected tool. Available commands are:
target
Sets the given target temperature on the printer's tools. Additional parameters:
* ``targets``: Target temperature(s) to set, properties must match the format ``tool{n}`` with ``n`` being the
tool's index starting with 0.
2013-12-16 00:47:06 +00:00
offset
Sets the given temperature offset on the printer's tools. Additional parameters:
2013-12-16 00:47:06 +00:00
* ``offsets``: Offset(s) to set, properties must match the format ``tool{n}`` with ``n`` being the tool's index
starting with 0.
2013-12-16 00:47:06 +00:00
select
Selects the printer's current tool. Additional parameters:
2013-12-16 00:47:06 +00:00
* ``tool``: Tool to select, format ``tool{n}`` with ``n`` being the tool's index starting with 0.
2013-12-16 00:47:06 +00:00
extrude
Extrudes the given amount of filament from the currently selected tool. Additional parameters:
2013-12-16 00:47:06 +00:00
* ``amount``: The amount of filament to extrude in mm. May be negative to retract.
2013-12-16 00:47:06 +00:00
flowrate
Changes the flow rate factor to apply to extrusion of the tool.
* ``factor``: The new factor, percentage as integer or float (percentage divided by 100) between 75 and 125%.
2013-12-16 00:47:06 +00:00
All of these commands may only be sent if the printer is currently operational and -- in case of ``select`` and
``extrude`` -- not printing. Otherwise a :http:statuscode:`409` is returned.
2013-12-21 12:01:18 +00:00
Upon success, a status code of :http:statuscode:`204` and an empty body is returned.
2013-12-16 00:47:06 +00:00
**Example Target Temperature Request**
Set the target temperature for the printer's first hotend to 220°C and the printer's second extruder to 205°C.
2013-12-16 00:47:06 +00:00
.. sourcecode:: http
POST /api/printer/tool HTTP/1.1
2013-12-16 00:47:06 +00:00
Host: example.com
Content-Type: application/json
X-Api-Key: abcdef...
{
"command": "target",
"targets": {
"tool0": 220,
"tool1": 205
2013-12-16 00:47:06 +00:00
}
}
.. sourcecode:: http
HTTP/1.1 204 No Content
2013-12-16 00:47:06 +00:00
**Example Offset Temperature Request**
Set the offset for temperatures on ``tool0`` to +10°C and on ``tool1`` to -5°C.
2013-12-16 00:47:06 +00:00
.. sourcecode:: http
POST /api/printer/tool HTTP/1.1
2013-12-16 00:47:06 +00:00
Host: example.com
Content-Type: application/json
X-Api-Key: abcdef...
{
"command": "offset",
"offsets": {
"tool0": 10,
"tool1": -5
2013-12-16 00:47:06 +00:00
}
}
.. sourcecode:: http
2013-12-16 00:47:06 +00:00
HTTP/1.1 204 No Content
2013-12-16 00:47:06 +00:00
**Example Tool Select Request**
2013-12-16 01:11:40 +00:00
Select the second hotend of the printer for any following ``extrude`` commands.
2013-12-16 01:11:40 +00:00
.. sourcecode:: http
2013-12-16 01:11:40 +00:00
POST /api/printer/tool HTTP/1.1
Host: example.com
Content-Type: application/json
X-Api-Key: abcdef...
2013-12-16 01:11:40 +00:00
{
"command": "select",
"tool": "tool1"
}
2013-12-16 01:11:40 +00:00
.. sourcecode:: http
2013-12-21 12:01:18 +00:00
HTTP/1.1 204 No Content
2013-12-21 12:01:18 +00:00
2013-12-16 01:11:40 +00:00
**Example Extrude Request**
Extrude 5mm on the currently selected tool.
2013-12-16 01:11:40 +00:00
.. sourcecode:: http
POST /api/printer/tool HTTP/1.1
2013-12-16 01:11:40 +00:00
Host: example.com
Content-Type: application/json
X-Api-Key: abcdef...
{
"command": "extrude",
"amount": 5
2013-12-16 01:11:40 +00:00
}
.. sourcecode:: http
HTTP/1.1 204 No Content
2013-12-16 01:11:40 +00:00
**Example Retract Request**
Retract 3mm of filament on the currently selected tool.
2013-12-16 01:11:40 +00:00
.. sourcecode:: http
POST /api/printer/tool HTTP/1.1
2013-12-16 01:11:40 +00:00
Host: example.com
Content-Type: application/json
X-Api-Key: abcdef...
2013-12-16 00:47:06 +00:00
2013-12-16 01:11:40 +00:00
{
"command": "extrude",
"amount": -3
}
.. sourcecode:: http
HTTP/1.1 204 No Content
**Example flow rate request**
Set the flow rate factor to 95%.
.. sourcecode:: http
POST /api/printer/tool HTTP/1.1
Host: example.com
Content-Type: application/json
X-Api-Key: abcdef...
{
"command": "flowrate",
"factor": 95
}
.. sourcecode:: http
HTTP/1.1 204 No Content
:json string command: The command to issue, either ``target``, ``offset``, ``select`` or ``extrude``.
:json object targets: ``target`` command: The target temperatures to set. Valid properties have to match the format ``tool{n}``.
:json object offsets: ``offset`` command: The offset temperature to set. Valid properties have to match the format ``tool{n}``.
:json object tool: ``select`` command: The tool to select, value has to match the format ``tool{n}``.
:json object amount: ``extrude`` command: The amount of filament to extrude from the currently selected tool.
:json number factor: ``flowrate`` command: The factor to apply to the flow rate, percentage between 75 and 125% as integer or float.
2013-12-21 12:01:18 +00:00
:statuscode 204: No error
:statuscode 400: If ``targets`` or ``offsets`` contains a property or ``tool`` contains a value not matching the format
``tool{n}``, the target/offset temperature, extrusion amount or flow rate factor is not a valid number or outside of
the supported range, or if the request is otherwise invalid.
:statuscode 409: If the printer is not operational or -- in case of ``select`` or ``extrude`` -- currently printing.
.. _sec-api-printer-toolstate:
Retrieve the current tool state
===============================
.. http:get:: /api/printer/tool
Retrieves the current temperature data (actual, target and offset) plus optionally a (limited) history (actual, target,
timestamp) for all of the printer's available tools.
It's also possible to retrieve the temperature history by supplying the ``history`` query parameter set to ``true``. The
amount of returned history data points can be limited using the ``limit`` query parameter.
Returns a :http:statuscode:`200` with a Temperature Response in the body upon success.
.. note::
If you want both tool and bed temperature information at the same time, take a look at
:ref:`Retrieve the current printer state <sec-api-printer-state>`.
**Example**
Query the tool temperature data and also include the temperature history but limit it to two entries.
.. sourcecode:: http
GET /api/printer/tool?history=true&limit=2 HTTP/1.1
Host: example.com
X-Api-Key: abcdef...
.. sourcecode:: http
HTTP/1.1 200 OK
Content-Type: application/json
{
"tool0": {
"actual": 214.8821,
"target": 220.0,
"offset": 0
},
"tool1": {
"actual": 25.3,
"target": null,
"offset": 0
},
"history": [
{
"time": 1395651928,
"tool0": {
"actual": 214.8821,
"target": 220.0
},
"tool1": {
"actual": 25.3,
"target": null
}
},
{
"time": 1395651926,
"tool0": {
"actual": 212.32,
"target": 220.0
},
"tool1": {
"actual": 25.1
}
}
]
}
:query history: If set to ``true`` (or: ``yes``, ``y``, ``1``), history information will be included in the response
too. If no ``limit`` parameter is given, all available temperature history data will be returned.
:query limit: If set to an integer (``n``), only the last ``n`` data points from the printer's temperature history
will be returned. Will be ignored if ``history`` is not enabled.
:statuscode 200: No error
:statuscode 409: If the printer is not operational.
.. _sec-api-printer-bedcommand:
Issue a bed command
===================
.. http:post:: /api/printer/bed
Bed commands allow setting the temperature and temperature offsets for the printer's heated bed. Available commands
are:
target
Sets the given target temperature on the printer's tools. Additional parameters:
* ``target``: Target temperature to set.
offset
Sets the given temperature offset on the printer's tools. Additional parameters:
* ``offset``: Offset to set.
All of these commands may only be sent if the printer is currently operational. Otherwise a :http:statuscode:`409`
is returned.
Upon success, a status code of :http:statuscode:`204` and an empty body is returned.
**Example Target Temperature Request**
Set the target temperature for the printer's heated bed to 75°C.
.. sourcecode:: http
POST /api/printer/bed HTTP/1.1
Host: example.com
Content-Type: application/json
X-Api-Key: abcdef...
{
"command": "target",
"target": 75
}
.. sourcecode:: http
HTTP/1.1 204 No Content
**Example Offset Temperature Request**
Set the temperature offset for the heated bed to -5°C.
.. sourcecode:: http
POST /api/printer/bed HTTP/1.1
Host: example.com
Content-Type: application/json
X-Api-Key: abcdef...
{
"command": "offset",
"offset": -5
}
.. sourcecode:: http
HTTP/1.1 204 No Content
:json string command: The command to issue, either ``target`` or ``offset``.
:json object target: ``target`` command: The target temperature to set.
:json object offset: ``offset`` command: The offset temperature to set.
:statuscode 204: No error
:statuscode 400: If ``target`` or ``offset`` is not a valid number or outside of the supported range, or if the
request is otherwise invalid.
:statuscode 409: If the printer is not operational.
.. _sec-api-printer-bedstate:
Retrieve the current bed state
==============================
.. http:get:: /api/printer/bed
Retrieves the current temperature data (actual, target and offset) plus optionally a (limited) history (actual, target,
timestamp) for the printer's heated bed.
It's also possible to retrieve the temperature history by supplying the ``history`` query parameter set to ``true``. The
amount of returned history data points can be limited using the ``limit`` query parameter.
Returns a :http:statuscode:`200` with a Temperature Response in the body upon success.
.. note::
If you want both tool and bed temperature information at the same time, take a look at
:ref:`Retrieve the current printer state <sec-api-printer-state>`.
**Example**
Query the bed temperature data and also include the temperature history but limit it to two entries.
.. sourcecode:: http
GET /api/printer/bed?history=true&limit=2 HTTP/1.1
Host: example.com
X-Api-Key: abcdef...
.. sourcecode:: http
HTTP/1.1 200 OK
Content-Type: application/json
{
"bed": {
"actual": 50.221,
"target": 70.0,
"offset": 5
},
"history": [
{
"time": 1395651928,
"bed": {
"actual": 50.221,
"target": 70.0
}
},
{
"time": 1395651926,
"bed": {
"actual": 49.1123,
"target": 70.0
}
}
]
}
:query history: If set to ``true`` (or: ``yes``, ``y``, ``1``), history information will be included in the response
too. If no ``limit`` parameter is given, all available temperature history data will be returned.
:query limit: If set to an integer (``n``), only the last ``n`` data points from the printer's temperature history
will be returned. Will be ignored if ``history`` is not enabled.
:statuscode 200: No error
:statuscode 409: If the printer is not operational.
2013-12-21 12:01:18 +00:00
.. _sec-api-printer-sdcommand:
Issue an SD command
===================
2013-12-21 12:01:18 +00:00
.. http:post:: /api/printer/sd
2013-12-21 12:01:18 +00:00
SD commands allow initialization, refresh and release of the printer's SD card (if available).
Available commands are:
init
Initializes the printer's SD card, making it available for use. This also includes an initial retrieval of the
list of files currently stored on the SD card, so after issueing that command a :ref:`retrieval of the files
on SD card <sec-api-fileops-retrievelocation>` will return a successful result.
2013-12-21 12:01:18 +00:00
.. note::
If OctoPrint detects the availability of a SD card on the printer during connection, it will automatically attempt
to initialize it.
refresh
Refreshes the list of files stored on the printer's SD card. Will return a :http:statuscode:`409` if the card
has not been initialized yet (see the ``init`` command and :ref:`SD state <sec-api-printer-sdstate>`).
release
Releases the SD card from the printer. The reverse operation to ``init``. After issuing this command, the SD
card won't be available anymore, hence and operations targeting files stored on it will fail. Will return a :http:statuscode:`409`
if the card has not been initialized yet (see the ``init`` command and :ref:`SD state <sec-api-printer-sdstate>`).
Upon success, a status code of :http:statuscode:`204` and an empty body is returned.
**Example Init Request**
Initialize the SD card.
2013-12-21 12:01:18 +00:00
.. sourcecode:: http
POST /api/printer/sd HTTP/1.1
2013-12-21 12:01:18 +00:00
Host: example.com
Content-Type: application/json
X-Api-Key: abcdef...
{
"command": "init"
}
.. sourcecode:: http
HTTP/1.1 204 No Content
2013-12-21 12:01:18 +00:00
**Example Refresh Request**
Refresh the file list of the SD card
2013-12-21 12:01:18 +00:00
.. sourcecode:: http
POST /api/printer/sd HTTP/1.1
2013-12-21 12:01:18 +00:00
Host: example.com
Content-Type: application/json
X-Api-Key: abcdef...
{
"command": "refresh"
}
.. sourcecode:: http
HTTP/1.1 204 No Content
2013-12-21 12:01:18 +00:00
**Example Release Request**
Release the SD card
2013-12-21 12:01:18 +00:00
.. sourcecode:: http
POST /api/printer/sd HTTP/1.1
2013-12-21 12:01:18 +00:00
Host: example.com
Content-Type: application/json
X-Api-Key: abcdef...
{
"command": "release"
}
.. sourcecode:: http
HTTP/1.1 204 No Content
2013-12-21 12:01:18 +00:00
:json string command: The command to issue, either ``init``, ``refresh`` or ``release``.
:statuscode 204: No error
:statuscode 409: If a ``refresh`` or ``release`` command is issued but the SD card has not been initialized (e.g.
via ``init``.
.. _sec-api-printer-sdstate:
Retrieve the current SD state
=============================
.. http:get:: /api/printer/sd
2013-12-21 12:01:18 +00:00
Retrieves the current state of the printer's SD card. For this request no authentication is needed.
If SD support has been disabled in OctoPrint's settings, a :http:statuscode:`404` is returned.
Returns a :http:statuscode:`200` with an :ref:`SD State Response <sec-api-printer-datamodel-sdstate>` in the body
upon success.
**Example**
Read the current state of the SD card.
2013-12-21 12:01:18 +00:00
.. sourcecode:: http
GET /api/printer/sd HTTP/1.1
2013-12-21 12:01:18 +00:00
Host: example.com
X-Api-Key: abcdef...
2013-12-21 12:01:18 +00:00
.. sourcecode:: http
HTTP/1.1 200 OK
Content-Type: application/json
{
"ready": true
}
:statuscode 200: No error
:statuscode 404: If SD support has been disabled in OctoPrint's config.
2014-12-30 11:18:39 +00:00
.. _sec-api-printer-arbcommand:
Send an arbitrary command to the printer
========================================
2014-12-30 11:18:39 +00:00
.. http:post:: /api/printer/command
Sends any command to the printer via the serial interface. Should be used with some care as some commands can interfere with
or even stop a running print job.
Expects a :ref:`Arbitrary Command Request <sec-api-printer-datamodel-arbcommand>` as the request's body.
2014-12-30 11:18:39 +00:00
If successful returns a :http:statuscode:`204` and an empty body.
**Example for sending a single command**
.. sourcecode:: http
POST /api/printer/command HTTP/1.1
Host: example.com
Content-Type: application/json
X-Api-Key: abcdef...
{
"command": "M106"
}
2014-12-30 11:18:39 +00:00
.. sourcecode:: http
HTTP/1.1 204 No Content
**Example for sending multiple commands**
.. sourcecode:: http
2014-12-30 11:18:39 +00:00
POST /api/printer/command HTTP/1.1
Host: example.com
Content-Type: application/json
X-Api-Key: abcdef...
{
"commands": [
"M18",
"M106 S0"
]
2014-12-30 11:18:39 +00:00
}
.. sourcecode:: http
HTTP/1.1 204 No Content
2014-12-30 11:18:39 +00:00
:json string command: Single command to send to the printer, mutually exclusive with ``commands``.
:json string commands: List of commands to send to the printer, mutually exclusive with ``command``.
:statuscode 204: No error
2014-12-30 11:18:39 +00:00
2013-12-21 12:01:18 +00:00
.. _sec-api-printer-datamodel:
Datamodel
=========
.. _sec-api-printer-datamodel-fullstate:
Full State Response
-------------------
.. list-table::
:widths: 15 5 10 30
:header-rows: 1
2013-12-21 12:01:18 +00:00
* - Name
- Multiplicity
- Type
- Description
* - ``temperature``
- 0..1
- :ref:`Temperature State <sec-api-printer-datamodel-temps>`
- The printer's temperature state data
* - ``sd``
- 0..1
- :ref:`SD State <sec-api-printer-datamodel-sdstate>`
- The printer's sd state data
* - ``state``
- 0..1
- :ref:`Printer State <sec-api-datamodel-printer-state>`
- The printer's general state
.. _sec-api-printer-datamodel-temps:
Temperature State
2013-12-21 12:01:18 +00:00
-----------------
.. list-table::
:widths: 15 5 10 30
:header-rows: 1
* - Name
- Multiplicity
- Type
- Description
* - ``tool{n}``
- 0..*
- :ref:`Temperature Data <sec-api-datamodel-printer-tempdata>`
- Current temperature stats for tool *n*. Enumeration starts at 0 for the first tool. Not included if querying
only bed state.
* - ``bed``
- 0..1
- :ref:`Temperature Data <sec-api-datamodel-printer-tempdata>`
- Current temperature stats for the printer's heated bed. Not included if querying only tool state.
* - ``history``
- 0..1
- List of :ref:`Historic Temperature Datapoint <sec-api-datamodel-printer-temphistory>`
- Temperature history
.. _sec-api-printer-datamodel-sdstate:
SD State
--------
2013-12-21 12:01:18 +00:00
.. list-table::
:widths: 15 5 10 30
:header-rows: 1
* - Name
- Multiplicity
- Type
- Description
* - ``ready``
- 1
- Boolean
- Whether the SD card has been initialized (``true``) or not (``false``).
.. _sec-api-printer-datamodel-arbcommand:
Arbitrary Command Request
-------------------------
.. list-table::
:widths: 15 5 10 30
:header-rows: 1
* - Name
- Multiplicity
- Type
- Description
* - ``command``
- 0..1
- String
- Single command to send to the printer, mutually exclusive with ``commands`` and ``script``.
* - ``commands``
- 0..*
- Array of String
- Multiple commands to send to the printer (in the given order), mutually exclusive with ``command`` and ``script``.
* - ``script``
- 0..*
- String
- Name of the GCODE script template to send to the printer, mutually exclusive with ``command`` and ``commands``.
* - ``parameters``
- 0..1
- Map of key value pairs
- Key value pairs of parameters to replace in sent commands/provide to the script renderer
* - ``context``
- 0..1
- Map of key value pairs
- (only if ``script`` is set) additional template variables to provide to the script renderer