Manage persistent ssh tunnels and port forwards.
Project description
Manage persistent ssh tunnels and port forwards.
Latest release 20221228: get_ssh_options: be quiet.
Portfwd runs a collection of ssh tunnel commands persistently,
each in its own cs.app.svcd <https://pypi.org/project/cs.app.svcd>
_ instance
with all the visibility and process control that SvcD brings.
It reads tunnel preconditions from special comments within the ssh config file.
It uses the configuration options from the config file
as the SvcD signature function
thus restarting particular ssh tunnels when their specific configuration changes.
It has an "automatic" mode (the -A option)
which monitors the desired list of tunnels
from statuses expressed via cs.app.flag <https://pypi.org/project/cs.app.flag>
_
which allows live addition or removal of tunnels as needed.
Function Condition(portfwd, op, invert, *args)
Factory to construct a condition from a specification.
Class FlagCondition(_PortfwdCondition)
A flag based condition.
Function main(argv=None, environ=None)
Command line main programme.
Class PingCondition(_PortfwdCondition)
A ping based condition.
Class Portfwd(cs.app.flag.FlaggedMixin)
An ssh tunnel built on a SvcD.
Method Portfwd.__init__(self, target, ssh_config=None, conditions=(), test_shcmd=None, trace=False, verbose=False, flags=None)
:
Initialise the Portfwd.
Parameters:
target
: the tunnel name, and also the name of the ssh configuration usedssh_config
: ssh configuration file if not the defaultconditions
: an iterable ofCondition
s which must hold before the tunnel is set up; the tunnel also aborts if these cease to holdtest_shcmd
: a shell command which must succeed before the tunnel is set up; the tunnel also aborts if this command subsequently failstrace
: issue tracing messages; defaultFalse
verbose
: be verbose; defaultFalse
flags
: optional preexistingFlags
instance
Class Portfwds
A collection of Portfwd
instances and associated control methods.
Method Portfwds.__init__(self, ssh_config=None, environ=None, target_list=None, auto_mode=None, trace=False, verbose=False, flags=None)
:
Initialise the Portfwds
instance.
Parameters:
ssh_config
: the ssh configuration file if not the defaultenviron
: the environment mapping to use; default:os.environ
target_list
: an iterable ofPortfwd
target namesauto_mode
: also derive target names from the set of truePORTFWD_
name_AUTO
flagstrace
: trace mode, defaultFalse
verbose
: verbose mode, defaultFalse
flags
: thecs.app.flags.Flags
instance to use, default is to construct a new one
Release Log
Release 20221228: get_ssh_options: be quiet.
Release 20210316:
- Portfwds: accept any iterable for target_list.
- Portability fix.
Release 20190602:
- Support alert groups.
- ssh_argv no longer a property in order to support
bare
param. - New method
ssh_options
to wrap ssh_argv. - Drop sig_func, use ssh_options instead.
- Remove local UNIX domain socket forward endpoints before starting ssh tunnel.
- Improve option parse.
Release 20170906: Initial PyPI release.
Project details
Download files
Download the file for your platform. If you're not sure which to choose, learn more about installing packages.
Source Distribution
Built Distribution
Hashes for cs.app.portfwd-20221228-py3-none-any.whl
Algorithm | Hash digest | |
---|---|---|
SHA256 | 611d5885593e05e98484957fffeaca43f962b8ec91bd25d445d562dce7ad0dfc |
|
MD5 | 0106a0b0af9f2a17baa65eb8813011c3 |
|
BLAKE2b-256 | 9a3913b0922efa68c44826d4d27de521704f32e0f84beeae51a188cb5b96b477 |