Update machine-api spec (#4091)
* YOYO NEW API SPEC! * New machine-api types --------- Co-authored-by: github-actions[bot] <github-actions[bot]@users.noreply.github.com>
This commit is contained in:
committed by
GitHub
parent
bcf2572739
commit
4e0dd12f5a
@ -113,12 +113,21 @@
|
|||||||
],
|
],
|
||||||
"description": "Maximum part size that can be manufactured by this device. This may be some sort of theoretical upper bound, getting close to this limit seems like maybe a bad idea.\n\nThis may be `None` if the maximum size is not knowable by the Machine API.\n\nWhat \"close\" means is up to you!",
|
"description": "Maximum part size that can be manufactured by this device. This may be some sort of theoretical upper bound, getting close to this limit seems like maybe a bad idea.\n\nThis may be `None` if the maximum size is not knowable by the Machine API.\n\nWhat \"close\" means is up to you!",
|
||||||
"nullable": true
|
"nullable": true
|
||||||
|
},
|
||||||
|
"state": {
|
||||||
|
"allOf": [
|
||||||
|
{
|
||||||
|
"$ref": "#/components/schemas/MachineState"
|
||||||
|
}
|
||||||
|
],
|
||||||
|
"description": "Status of the printer -- be it printing, idle, or unreachable. This may dictate if a machine is capable of taking a new job."
|
||||||
}
|
}
|
||||||
},
|
},
|
||||||
"required": [
|
"required": [
|
||||||
"id",
|
"id",
|
||||||
"machine_type",
|
"machine_type",
|
||||||
"make_model"
|
"make_model",
|
||||||
|
"state"
|
||||||
],
|
],
|
||||||
"type": "object"
|
"type": "object"
|
||||||
},
|
},
|
||||||
@ -143,6 +152,67 @@
|
|||||||
},
|
},
|
||||||
"type": "object"
|
"type": "object"
|
||||||
},
|
},
|
||||||
|
"MachineState": {
|
||||||
|
"description": "Current state of the machine -- be it printing, idle or offline. This can be used to determine if a printer is in the correct state to take a new job.",
|
||||||
|
"oneOf": [
|
||||||
|
{
|
||||||
|
"description": "If a print state can not be resolved at this time, an Unknown may be returned.",
|
||||||
|
"enum": [
|
||||||
|
"Unknown"
|
||||||
|
],
|
||||||
|
"type": "string"
|
||||||
|
},
|
||||||
|
{
|
||||||
|
"description": "Idle, and ready for another job.",
|
||||||
|
"enum": [
|
||||||
|
"Idle"
|
||||||
|
],
|
||||||
|
"type": "string"
|
||||||
|
},
|
||||||
|
{
|
||||||
|
"description": "Running a job -- 3D printing or CNC-ing a part.",
|
||||||
|
"enum": [
|
||||||
|
"Running"
|
||||||
|
],
|
||||||
|
"type": "string"
|
||||||
|
},
|
||||||
|
{
|
||||||
|
"description": "Machine is currently offline or unreachable.",
|
||||||
|
"enum": [
|
||||||
|
"Offline"
|
||||||
|
],
|
||||||
|
"type": "string"
|
||||||
|
},
|
||||||
|
{
|
||||||
|
"description": "Job is underway but halted, waiting for some action to take place.",
|
||||||
|
"enum": [
|
||||||
|
"Paused"
|
||||||
|
],
|
||||||
|
"type": "string"
|
||||||
|
},
|
||||||
|
{
|
||||||
|
"description": "Job is finished, but waiting manual action to move back to Idle.",
|
||||||
|
"enum": [
|
||||||
|
"Complete"
|
||||||
|
],
|
||||||
|
"type": "string"
|
||||||
|
},
|
||||||
|
{
|
||||||
|
"additionalProperties": false,
|
||||||
|
"description": "The printer has failed and is in an unknown state that may require manual attention to resolve. The inner value is a human readable description of what specifically has failed.",
|
||||||
|
"properties": {
|
||||||
|
"Failed": {
|
||||||
|
"nullable": true,
|
||||||
|
"type": "string"
|
||||||
|
}
|
||||||
|
},
|
||||||
|
"required": [
|
||||||
|
"Failed"
|
||||||
|
],
|
||||||
|
"type": "object"
|
||||||
|
}
|
||||||
|
]
|
||||||
|
},
|
||||||
"MachineType": {
|
"MachineType": {
|
||||||
"description": "Specific technique by which this Machine takes a design, and produces a real-world 3D object.",
|
"description": "Specific technique by which this Machine takes a design, and produces a real-world 3D object.",
|
||||||
"oneOf": [
|
"oneOf": [
|
||||||
|
13
src/lib/machine-api.d.ts
vendored
13
src/lib/machine-api.d.ts
vendored
@ -126,6 +126,8 @@ export interface components {
|
|||||||
*
|
*
|
||||||
* What "close" means is up to you! */
|
* What "close" means is up to you! */
|
||||||
max_part_volume?: components['schemas']['Volume'] | null
|
max_part_volume?: components['schemas']['Volume'] | null
|
||||||
|
/** @description Status of the printer -- be it printing, idle, or unreachable. This may dictate if a machine is capable of taking a new job. */
|
||||||
|
state: components['schemas']['MachineState']
|
||||||
}
|
}
|
||||||
/** @description Information regarding the make/model of a discovered endpoint. */
|
/** @description Information regarding the make/model of a discovered endpoint. */
|
||||||
MachineMakeModel: {
|
MachineMakeModel: {
|
||||||
@ -136,6 +138,17 @@ export interface components {
|
|||||||
/** @description The unique serial number of the connected Machine. */
|
/** @description The unique serial number of the connected Machine. */
|
||||||
serial?: string | null
|
serial?: string | null
|
||||||
}
|
}
|
||||||
|
/** @description Current state of the machine -- be it printing, idle or offline. This can be used to determine if a printer is in the correct state to take a new job. */
|
||||||
|
MachineState:
|
||||||
|
| 'Unknown'
|
||||||
|
| 'Idle'
|
||||||
|
| 'Running'
|
||||||
|
| 'Offline'
|
||||||
|
| 'Paused'
|
||||||
|
| 'Complete'
|
||||||
|
| {
|
||||||
|
Failed: string | null
|
||||||
|
}
|
||||||
/** @description Specific technique by which this Machine takes a design, and produces a real-world 3D object. */
|
/** @description Specific technique by which this Machine takes a design, and produces a real-world 3D object. */
|
||||||
MachineType: 'Stereolithography' | 'FusedDeposition' | 'Cnc'
|
MachineType: 'Stereolithography' | 'FusedDeposition' | 'Cnc'
|
||||||
/** @description The response from the `/ping` endpoint. */
|
/** @description The response from the `/ping` endpoint. */
|
||||||
|
Reference in New Issue
Block a user