Manage persistent ssh tunnels and port forwards.
Project description
Manage persistent ssh tunnels and port forwards.
Latest release 20210316:
- Portfwds: accept any iterable for target_list.
- Portability fix.
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.
Method FlagCondition.test(self, trace=False)
Core test, before inversion.
Function main(argv=None, environ=None)
Command line main programme.
Class PingCondition(_PortfwdCondition)
A ping based condition.
Method PingCondition.test(self, trace=False)
Ping the target as a test.
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 ofConditions 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; defaultFalseverbose: be verbose; defaultFalseflags: optional preexistingFlagsinstance
Method Portfwd.on_reap(self)
Actions to perform after the ssh tunnel exits.
Method Portfwd.on_spawn(self)
Actions to perform before commencing the ssh tunnel.
Initially remove local socket paths.
Method Portfwd.ssh_argv(self, bare=False)
An ssh command line argument list.
bare: just to command and options, no trailing "--".
Method Portfwd.ssh_options(self)
Return a defaultdict(list) of {option: values}
representing the ssh configuration.
Method Portfwd.start(self)
Call the service start method.
Method Portfwd.stop(self)
Call the service stop method.
Method Portfwd.test_func(self)
Servuice test function: probe all the conditions.
Method Portfwd.wait(self)
Call the service wait method.
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.environtarget_list: an iterable ofPortfwdtarget namesauto_mode: also derive target names from the set of truePORTFWD_name_AUTOflagstrace: trace mode, defaultFalseverbose: verbose mode, defaultFalseflags: thecs.app.flags.Flagsinstance to use, default is to construct a new one
Method Portfwds.forward(self, target)
Obtain the named Portfwd, creating it if necessary.
Property Portfwds.forwards
A list of the existing Portfwd instances.
Method Portfwds.resolve_target_spec(self, spec)
Accept a target spec and expand it if it is a group. Return a set of targets.
Method Portfwds.start(self)
Start all nonrunning targets, stop all running nonrequired targets.
Method Portfwds.stop(self)
Stop all running targets.
Method Portfwds.targets_required(self)
The concrete list of targets.
Computed from the target spec and, if in auto mode, the PORTFWD_*_AUTO flags.
Method Portfwds.wait(self)
Wait for all running targets to stop.
Release Log
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
bareparam. - New method
ssh_optionsto 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
File details
Details for the file cs.app.portfwd-20210316.tar.gz.
File metadata
- Download URL: cs.app.portfwd-20210316.tar.gz
- Upload date:
- Size: 10.8 kB
- Tags: Source
- Uploaded using Trusted Publishing? No
- Uploaded via: twine/3.3.0 pkginfo/1.6.1 requests/2.25.1 setuptools/49.2.1 requests-toolbelt/0.9.1 tqdm/4.55.0 CPython/3.9.2
File hashes
| Algorithm | Hash digest | |
|---|---|---|
| SHA256 |
320141c2edf514653f6374492ec1a89b6aed225e0827fdd30807307d80f880bd
|
|
| MD5 |
7bb982f4f4ef9d374c0fc50b3eade7a6
|
|
| BLAKE2b-256 |
aa0137d57a6a78db17986e09a2cf7e637f1edd6ffba4510aba3caa960a6e529d
|