A TOTP based next generation port knocking service.
Project description
c-lock
A TOTP based next generation port knocking service. Every time slot, it generates a sequence of ports that must be knocked (in a correct order) before the final port (it have been designed for protecting a SSH service) becames opened.
Yeah, I'm not very good with graphics...
Table of Contents
Installation
System dependencies
This is the software with wich I have worked:
-
python 3.x
-
iptables >= v1.6
It has been tested in Ubuntu 16.04 and Debian 9, but should work with any other system with theese systems installed.
Software dependencies
As it is just an alpha version, it has no currently an automated installer, because until it comes debugged and improved, it shouldnt have yet integration with the system.
Because python-cryptography
is needed for some dependencies, it must be installed before anything else: Building cryptography on linux
For install dependencies there are two options:
- Option A: Pipenv (Recommended)
pip3 install pipenv
pipenv install -r requeriments.txt
- Option B: requeriments.txt
pip3 install -r requeriments.txt
Usage
Step 1 - Server setup
$ c-lockd --gen-secret
Step 2 - Setup 2fa applications
Step 3 (server) - Start server side
# For example, protecting SSH port
$ c-lockd --secret NPAR2VWV5HX5BI4BIE6PKWUROWYHJE3CCGWZYVBT6AJ2H3DGFKZA -p 22
Step 3 (client) - Port knocking using TOTP pin
$ c-lock --address $SERVER_ADDRESS --pin 084678
Step 3 (client) - Port knocking using secret
$ c-lock --address $SERVER_ADDRESS --secret NPAR2VWV5HX5BI4BIE6PKWUROWYHJE3CCGWZYVBT6AJ2H3DGFKZA
Step 4 - Connect to your protected service =)
ssh $USER@$SERVER_ADDRESS
Server
Must be launched as root (for managing the iptables rules):
usage: c-lockd [-h] [-ts SLOT] [-a ADDRESS] [-s SECRET] [-p PROTECTED_PORTS]
[-o OPENED_PORTS] [--gen-secret] [--clean-firewall]
[--log-level LOG_LEVEL]
Launch TOTP based port knocking protection
optional arguments:
-h, --help show this help message and exit
-ts SLOT, --time-slot SLOT
Time slot for TOTP
-a ADDRESS, --address ADDRESS
Address to protect
-s SECRET, --secret SECRET
Secret part of TOTP
-p PROTECTED_PORTS, --protected-ports PROTECTED_PORTS
Port which has to be protected
-o OPENED_PORTS, --opened-ports OPENED_PORTS
Port which should be opened
--gen-secret Generate random secret
--clean-firewall Clean firewall configuration (e.g., after a bad close)
--log-level LOG_LEVEL
Log level
Client
usage: c-lock [-h] [-ts SLOT] -a ADDRESS [-s SECRET] [-p PIN] [-n PORTS]
Launch TOTP based port knocking protection
optional arguments:
-h, --help show this help message and exit
-ts SLOT, --time-slot SLOT
Time slot for TOTP
-a ADDRESS, --address ADDRESS
Address to knock
-s SECRET, --secret SECRET
Secret part of TOTP
-p PIN, --pin PIN TOTP pin
-n PORTS, --ports PORTS
Number of ports configured
Examples
Client
In this example:
-
Client scans server ports without c-lockd actived
-
When
c-lockd
is working in the server, just the opened ports can be scaned -
Use
c-lock
with pin -
The protected ports are now visible fron the client
Server
This is the server where the client points:
-
Generates the secret for the pin generation
-
Starts
c-lockd
server opening ports80
and5432
, and closing port22
-
When the client uses the correct port combination, it opens the protected port for 30 seconds
Contributing
By now, and until I finish a first stable version, I want to control the code. The best way of contribute to this project is apporting ideas and reviewing code. Any help is welcome!
For example, its obvious that I need help with documentation images, design, logo... :blush:
Credits
-
@ldx python-iptables
-
@jonschlinkert markdown-toc
-
@mnooner256 pyqrcode
License
MIT License
Copyright (c) 2018 Javier Junquera Sánchez
Permission is hereby granted, free of charge, to any person obtaining a copy
of this software and associated documentation files (the "Software"), to deal
in the Software without restriction, including without limitation the rights
to use, copy, modify, merge, publish, distribute, sublicense, and/or sell
copies of the Software, and to permit persons to whom the Software is
furnished to do so, subject to the following conditions:
The above copyright notice and this permission notice shall be included in all
copies or substantial portions of the Software.
THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR
IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,
FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE
AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER
LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM,
OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE
SOFTWARE.
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 c-lock-0.0.7.4.tar.gz
.
File metadata
- Download URL: c-lock-0.0.7.4.tar.gz
- Upload date:
- Size: 13.8 kB
- Tags: Source
- Uploaded using Trusted Publishing? No
- Uploaded via: twine/1.13.0 pkginfo/1.5.0.1 requests/2.21.0 setuptools/40.8.0 requests-toolbelt/0.9.1 tqdm/4.31.1 CPython/3.6.8
File hashes
Algorithm | Hash digest | |
---|---|---|
SHA256 | 99f4d6c0e8a334084340cc6e9e2728bd0e2fbeafba7958feeda341cdd91e53b1 |
|
MD5 | e6d7a581ea323ea4cb0bb9598950fc6d |
|
BLAKE2b-256 | a11fcc046e2cb403eb125a3b8b8e1c0a3112207daa8c6fa734c3bcdbcead4865 |