from ......Internal.Core import Core
from ......Internal.CommandsGroup import CommandsGroup
from ......Internal import Conversions
from ......Internal.Types import DataType
from ......Internal.ArgSingleList import ArgSingleList
from ......Internal.ArgSingle import ArgSingle
# noinspection PyPep8Naming,PyAttributeOutsideInit,SpellCheckingInspection
class StateCls:
"""
| Commands in total: 1
| Subgroups: 0
| Direct child commands: 1
"""
def __init__(self, core: Core, parent):
self._core = core
self._cmd_group = CommandsGroup("state", core, parent)
[docs]
def set(self, sec_pass_word: str, ssh_state: bool) -> None:
"""
``SYSTem:SECurity:NETWork:SSH:[STATe]`` \n
Snippet: ``driver.system.security.network.ssh.state.set(sec_pass_word = 'abc', ssh_state = False)`` \n
Disables control of the instrument over LAN using the SSH network protocol.
:param sec_pass_word: string Current security password.
:param ssh_state: 1 | ON | 0| OFF
"""
param = ArgSingleList().compose_cmd_string(ArgSingle('sec_pass_word', sec_pass_word, DataType.String), ArgSingle('ssh_state', ssh_state, DataType.Boolean))
self._core.io.write(f'SYSTem:SECurity:NETWork:SSH:STATe {param}'.rstrip())
[docs]
def get(self) -> bool:
"""
``SYSTem:SECurity:NETWork:SSH:[STATe]`` \n
Snippet: ``value: bool = driver.system.security.network.ssh.state.get()`` \n
Disables control of the instrument over LAN using the SSH network protocol.
:return: ssh_state: 1 | ON | 0| OFF
"""
response = self._core.io.query_str(f'SYSTem:SECurity:NETWork:SSH:STATe?')
return Conversions.str_to_bool(response)