machine: add support for setting a sudo password

Signed-off-by:  Eric Callahan <arksine.code@gmail.com>
This commit is contained in:
Eric Callahan 2022-05-03 08:37:22 -04:00
parent a7b50a8068
commit c154d92499
No known key found for this signature in database
GPG Key ID: 5A1EB336DFB4C71B
1 changed files with 37 additions and 0 deletions

View File

@ -69,6 +69,10 @@ class Machine:
dist_info['release_info'] = distro.distro_release_info() dist_info['release_info'] = distro.distro_release_info()
self.inside_container = False self.inside_container = False
self.moonraker_service_info: Dict[str, Any] = {} self.moonraker_service_info: Dict[str, Any] = {}
self._sudo_password: Optional[str] = None
sudo_template = config.gettemplate("sudo_password", None)
if sudo_template is not None:
self._sudo_password = sudo_template.render()
self.system_info: Dict[str, Any] = { self.system_info: Dict[str, Any] = {
'python': { 'python': {
"version": sys.version_info, "version": sys.version_info,
@ -108,6 +112,9 @@ class Machine:
self.server.register_endpoint( self.server.register_endpoint(
"/machine/system_info", ['GET'], "/machine/system_info", ['GET'],
self._handle_sysinfo_request) self._handle_sysinfo_request)
self.server.register_endpoint(
"/machine/sudo/password", ["POST"],
self._set_sudo_password)
self.server.register_notification("machine:service_state_changed") self.server.register_notification("machine:service_state_changed")
@ -213,9 +220,39 @@ class Machine:
) -> Dict[str, Any]: ) -> Dict[str, Any]:
return {'system_info': self.system_info} return {'system_info': self.system_info}
async def _set_sudo_password(self, web_request: WebRequest) -> str:
self._sudo_password = web_request.get_str("password")
if not await self.check_sudo_access():
self._sudo_password = None
raise self.server.error("Invalid password, sudo access was denied")
self.server.send_event("machine:sudo_password_set")
return "ok"
def get_system_info(self) -> Dict[str, Any]: def get_system_info(self) -> Dict[str, Any]:
return self.system_info return self.system_info
@property
def sudo_password(self) -> Optional[str]:
return self._sudo_password
async def check_sudo_access(self, cmds: List[str] = []) -> bool:
if not cmds:
cmds = ["systemctl --version", "ls /lost+found"]
shell_cmd: SCMDComp = self.server.lookup_component("shell_command")
for cmd in cmds:
proc_input = None
full_cmd = f"sudo {cmd}"
if self._sudo_password is not None:
proc_input = self._sudo_password
full_cmd = f"sudo -S {cmd}"
try:
ret = await shell_cmd.exec_cmd(
full_cmd, proc_input=proc_input, log_complete=False
)
except shell_cmd.error:
return False
return True
def _get_sdcard_info(self) -> Dict[str, Any]: def _get_sdcard_info(self) -> Dict[str, Any]:
sd_info: Dict[str, Any] = {} sd_info: Dict[str, Any] = {}
cid_file = pathlib.Path(SD_CID_PATH) cid_file = pathlib.Path(SD_CID_PATH)