Compare commits
3 Commits
Author | SHA1 | Date | |
---|---|---|---|
7f1ae5a24b | |||
5754e81b72 | |||
cd4103cc71 |
@ -72,6 +72,7 @@ class BambuVirtualPrinter:
|
||||
|
||||
self._running = True
|
||||
self._print_status_reporter = None
|
||||
self._print_temp_reporter = None
|
||||
self._printer_thread = threading.Thread(
|
||||
target=self._printer_worker,
|
||||
name="octoprint.plugins.bambu_printer.printer_state",
|
||||
@ -367,8 +368,10 @@ class BambuVirtualPrinter:
|
||||
interval = int(matchS.group(1))
|
||||
if interval > 0:
|
||||
self.start_continuous_status_report(interval)
|
||||
return False
|
||||
else:
|
||||
self.stop_continuous_status_report()
|
||||
return False
|
||||
|
||||
self.report_print_job_status()
|
||||
return True
|
||||
@ -403,10 +406,39 @@ class BambuVirtualPrinter:
|
||||
self._processTemperatureQuery()
|
||||
return True
|
||||
|
||||
@gcode_executor.register("M155")
|
||||
def _auto_report_temperatures(self, data: str) -> bool:
|
||||
matchS = re.search(r"S([0-9]+)", data)
|
||||
if matchS:
|
||||
interval = int(matchS.group(1))
|
||||
if interval > 0:
|
||||
self.start_continuous_temp_report(interval)
|
||||
else:
|
||||
self.stop_continuous_temp_report()
|
||||
|
||||
self.report_print_job_status()
|
||||
return True
|
||||
|
||||
def start_continuous_temp_report(self, interval: int):
|
||||
if self._print_temp_reporter is not None:
|
||||
self._print_temp_reporter.cancel()
|
||||
|
||||
self._print_temp_reporter = RepeatedTimer(
|
||||
interval, self._processTemperatureQuery
|
||||
)
|
||||
self._print_temp_reporter.start()
|
||||
|
||||
def stop_continuous_temp_report(self):
|
||||
if self._print_temp_reporter is not None:
|
||||
self._print_temp_reporter.cancel()
|
||||
self._print_temp_reporter = None
|
||||
|
||||
# noinspection PyUnusedLocal
|
||||
@gcode_executor.register_no_data("M115")
|
||||
def _report_firmware_info(self) -> bool:
|
||||
self.sendIO("Bambu Printer Integration")
|
||||
self.sendIO("Cap:AUTOREPORT_SD_STATUS:1")
|
||||
self.sendIO("Cap:AUTOREPORT_TEMP:1")
|
||||
self.sendIO("Cap:EXTENDED_M20:1")
|
||||
self.sendIO("Cap:LFN_WRITE:1")
|
||||
return True
|
||||
|
@ -85,7 +85,7 @@ class CachedFileView:
|
||||
return file_data
|
||||
|
||||
def _get_file_by_stem_cached(self, file_stem: str, allowed_suffixes: list[str]):
|
||||
for file_path_str in self._file_data_cache.keys():
|
||||
for file_path_str in list(self._file_data_cache.keys()) + list(self._file_alias_cache.keys()):
|
||||
file_path = Path(file_path_str)
|
||||
if file_stem == file_path.with_suffix("").stem and all(
|
||||
suffix in allowed_suffixes for suffix in file_path.suffixes
|
||||
|
@ -117,7 +117,7 @@ class IoTFTPSConnection:
|
||||
# But since we operate in prot p mode
|
||||
# we can close the connection always.
|
||||
# This is cursed but it works.
|
||||
if "vsFTPd" in self.welcome:
|
||||
if "vsFTPd" in self.ftps_session.welcome:
|
||||
conn.unwrap()
|
||||
else:
|
||||
conn.shutdown(socket.SHUT_RDWR)
|
||||
|
@ -1,8 +1,6 @@
|
||||
from __future__ import annotations
|
||||
from pathlib import Path
|
||||
|
||||
from octoprint_bambu_printer.printer.file_system.file_info import FileInfo
|
||||
from octoprint_bambu_printer.printer.print_job import PrintJob
|
||||
from octoprint_bambu_printer.printer.states.a_printer_state import APrinterState
|
||||
|
||||
|
||||
@ -26,7 +24,7 @@ class IdleState(APrinterState):
|
||||
# URL to print. Root path, protocol can vary. E.g., if sd card, "ftp:///myfile.3mf", "ftp:///cache/myotherfile.3mf"
|
||||
filesystem_root = (
|
||||
"file:///mnt/sdcard/"
|
||||
if self._printer._settings.get_boolean(["device_type"]) in ["X1", "X1C"]
|
||||
if self._printer._settings.get(["device_type"]) in ["X1", "X1C"]
|
||||
else "file:///"
|
||||
)
|
||||
|
||||
|
@ -22,6 +22,7 @@ class PrintingState(APrinterState):
|
||||
|
||||
def __init__(self, printer: BambuVirtualPrinter) -> None:
|
||||
super().__init__(printer)
|
||||
self._current_print_job = None
|
||||
self._is_printing = False
|
||||
self._sd_printing_thread = None
|
||||
|
||||
@ -36,6 +37,7 @@ class PrintingState(APrinterState):
|
||||
self._is_printing = False
|
||||
self._sd_printing_thread.join()
|
||||
self._sd_printing_thread = None
|
||||
self._printer.current_print_job = None
|
||||
|
||||
def _start_worker_thread(self):
|
||||
if self._sd_printing_thread is None:
|
||||
|
@ -7,3 +7,10 @@
|
||||
###
|
||||
|
||||
.
|
||||
|
||||
pytest~=7.4.4
|
||||
pybambu~=1.0.1
|
||||
OctoPrint~=1.10.2
|
||||
setuptools~=70.0.0
|
||||
pyserial~=3.5
|
||||
Flask~=2.2.5
|
||||
|
2
setup.py
2
setup.py
@ -14,7 +14,7 @@ plugin_package = "octoprint_bambu_printer"
|
||||
plugin_name = "OctoPrint-BambuPrinter"
|
||||
|
||||
# The plugin's version. Can be overwritten within OctoPrint's internal data via __plugin_version__ in the plugin module
|
||||
plugin_version = "0.1.1"
|
||||
plugin_version = "0.1.4"
|
||||
|
||||
# The plugin's description. Can be overwritten within OctoPrint's internal data via __plugin_description__ in the plugin
|
||||
# module
|
||||
|
Reference in New Issue
Block a user