SSH commands to provide Secondary DNS self-service.
Project description
SSH Zone Handler
- You run your own DNS server(s), providing Secondary DNS to others?
- You want to provide your DNS tenants with a bit of debugging self-service?
- You like SSH, but you don't want to grant people not-you full shell access?
If so, then this might just be the tool for you. It supports dumping out zone content, viewing server logs as well as triggering full AXFR zone (re)transfers.
Usage
Usage example, based on local Multipass setup.
make vm-create
alias ssh='ssh -F devel/.dynamic/ssh_conf'
$ ssh zones@szh-named help
usage: command [ZONE]
help Display this help message
list List available zones
dump ZONE Output full content of ZONE
logs ZONE1 [ZONE2] Output the last five days' log entries for ZONE(s)
retransfer ZONE Trigger a full (AXFR) retransfer of ZONE
$
$ ssh zones@szh-named list
example.com
example.net
$
$ ssh zones@szh-named logs example.net
Apr 28 17:52:00 szh-named named[2821]: zone example.net/IN: Transfer started.
Apr 28 17:52:00 szh-named named[2821]: transfer of 'example.net/IN' from 192.168.63.10#53: connected using 192.168.63.10#53
Apr 28 17:52:00 szh-named named[2821]: zone example.net/IN: transferred serial 26281038
Apr 28 17:52:00 szh-named named[2821]: transfer of 'example.net/IN' from 192.168.63.10#53: Transfer status: success
Apr 28 17:52:00 szh-named named[2821]: transfer of 'example.net/IN' from 192.168.63.10#53: Transfer completed: 1 messages, 6 records, 190 bytes, 0.008 secs (23750 bytes/sec) (serial 26281038)
$
Setup instructions
Create user accounts
adduser --comment "SSH Zone Handler journalctl sudo access" --ingroup systemd-journal --system szh-logviewer
adduser --comment "SSH Zone Handler OpenSSH AuthorizedKeysCommandUser" --system szh-sshdcmd
adduser --comment "SSH Zone Handler shared login user" --disabled-password zones
Create configuration
Create /etc/zone-handler.yaml based on either
zone-handler.yaml.bind.example or
zone-handler.yaml.knot.example.
Install application
python3 -m venv /opt/ssh-zone-handler
/opt/ssh-zone-handler/bin/pip3 install ssh-zone-handler
Generate sudoers rules
/opt/ssh-zone-handler/bin/szh-sudoers | EDITOR="tee" visudo -f /etc/sudoers.d/zone-handler
Configure sshd
Match User zones
AuthorizedKeysFile none
AuthorizedKeysCommandUser szh-sshdcmd
AuthorizedKeysCommand /opt/ssh-zone-handler/bin/szh-sshkeys
DisableForwarding yes
PermitTTY no
Known limitations
- Might be Debian/Ubuntu distro specific
- Currently only supports BIND 9 and Knot
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
Filter files by name, interpreter, ABI, and platform.
If you're not sure about the file name format, learn more about wheel file names.
Copy a direct link to the current filters
File details
Details for the file ssh_zone_handler-0.4.1.tar.gz.
File metadata
- Download URL: ssh_zone_handler-0.4.1.tar.gz
- Upload date:
- Size: 8.1 kB
- Tags: Source
- Uploaded using Trusted Publishing? Yes
- Uploaded via: twine/6.1.0 CPython/3.13.7
File hashes
| Algorithm | Hash digest | |
|---|---|---|
| SHA256 |
dcf1c78d2f87ddb0adb3c44903474cc3deda5e969f1b16ea49fb7ca23d96e9d3
|
|
| MD5 |
e4adacf8c55056ec28ce9f34c261554c
|
|
| BLAKE2b-256 |
3cfb21b922dcedee11744caf01dbc4a015f23b6176ad538314c4671e93c167ee
|
Provenance
The following attestation bundles were made for ssh_zone_handler-0.4.1.tar.gz:
Publisher:
publish.yaml on andreaso/ssh-zone-handler
-
Statement:
-
Statement type:
https://in-toto.io/Statement/v1 -
Predicate type:
https://docs.pypi.org/attestations/publish/v1 -
Subject name:
ssh_zone_handler-0.4.1.tar.gz -
Subject digest:
dcf1c78d2f87ddb0adb3c44903474cc3deda5e969f1b16ea49fb7ca23d96e9d3 - Sigstore transparency entry: 715656214
- Sigstore integration time:
-
Permalink:
andreaso/ssh-zone-handler@b98dd8791d2a91f48a885dd6eb1f3e30caf50468 -
Branch / Tag:
refs/tags/v0.4.1 - Owner: https://github.com/andreaso
-
Access:
public
-
Token Issuer:
https://token.actions.githubusercontent.com -
Runner Environment:
github-hosted -
Publication workflow:
publish.yaml@b98dd8791d2a91f48a885dd6eb1f3e30caf50468 -
Trigger Event:
push
-
Statement type:
File details
Details for the file ssh_zone_handler-0.4.1-py3-none-any.whl.
File metadata
- Download URL: ssh_zone_handler-0.4.1-py3-none-any.whl
- Upload date:
- Size: 11.4 kB
- Tags: Python 3
- Uploaded using Trusted Publishing? Yes
- Uploaded via: twine/6.1.0 CPython/3.13.7
File hashes
| Algorithm | Hash digest | |
|---|---|---|
| SHA256 |
67ec160957f8cfaae7c8ebd556cdf1450f37bce8c8dfa925e8f34bba855f2829
|
|
| MD5 |
db7bfca7b9b91674bb1775486497785e
|
|
| BLAKE2b-256 |
d1fc0f676b12007c58fb051666f823c73fbd7d33c4122b2fbc95e95e1ec7d266
|
Provenance
The following attestation bundles were made for ssh_zone_handler-0.4.1-py3-none-any.whl:
Publisher:
publish.yaml on andreaso/ssh-zone-handler
-
Statement:
-
Statement type:
https://in-toto.io/Statement/v1 -
Predicate type:
https://docs.pypi.org/attestations/publish/v1 -
Subject name:
ssh_zone_handler-0.4.1-py3-none-any.whl -
Subject digest:
67ec160957f8cfaae7c8ebd556cdf1450f37bce8c8dfa925e8f34bba855f2829 - Sigstore transparency entry: 715656216
- Sigstore integration time:
-
Permalink:
andreaso/ssh-zone-handler@b98dd8791d2a91f48a885dd6eb1f3e30caf50468 -
Branch / Tag:
refs/tags/v0.4.1 - Owner: https://github.com/andreaso
-
Access:
public
-
Token Issuer:
https://token.actions.githubusercontent.com -
Runner Environment:
github-hosted -
Publication workflow:
publish.yaml@b98dd8791d2a91f48a885dd6eb1f3e30caf50468 -
Trigger Event:
push
-
Statement type: