-
Notifications
You must be signed in to change notification settings - Fork 0
/
ftpdhoney.py
31 lines (22 loc) · 864 Bytes
/
ftpdhoney.py
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
#!/usr/bin/python3
import logging
import pyftpdlib.authorizers
from pyftpdlib.authorizers import DummyAuthorizer
from pyftpdlib.handlers import FTPHandler
from pyftpdlib.servers import FTPServer
class DummyAuthorizerCollectCreds(DummyAuthorizer):
def validate_authentication(self, username, password, handler):
with open("/opt/honeyftpd/ftpdhoney-credentials.txt", 'a') as file_obj:
file_obj.write(f"{handler.addr[0]}:{username}:{password}\n")
raise pyftpdlib.authorizers.AuthenticationFailed
def main():
logging.basicConfig(level=logging.FATAL)
authorizer = DummyAuthorizerCollectCreds()
handler = FTPHandler
handler.authorizer = authorizer
handler.banner = "vsFTPD 2.3.4"
address = ('', 21)
server = FTPServer(address, handler)
server.serve_forever()
if __name__ == '__main__':
main()