modified: client/dnssender.py
modified: database/initdb.py new file: database/test.py modified: server/xiaomiandns.py
This commit is contained in:
		| @@ -16,7 +16,9 @@ def resolver(domain): | |||||||
|         print("can't find IP") |         print("can't find IP") | ||||||
|          |          | ||||||
|  |  | ||||||
| if __name__ = "__main__": |  | ||||||
|  |  | ||||||
|  | if __name__ == "__main__": | ||||||
|     domain = 'mamahaha.work' |     domain = 'mamahaha.work' | ||||||
|     ip = resolver(domain) |     ip = resolver(domain) | ||||||
|     print(ip) |     print(ip) | ||||||
| @@ -1,6 +1,6 @@ | |||||||
| import sqlite3 | import sqlite3 | ||||||
|  |  | ||||||
| db_file = 'dns.db' | db_file = 'database/dns.db' | ||||||
| if __name__ == '__main__': | if __name__ == '__main__': | ||||||
|     conn = sqlite3.connect(db_file) |     conn = sqlite3.connect(db_file) | ||||||
|     cursor = conn.cursor() |     cursor = conn.cursor() | ||||||
|   | |||||||
							
								
								
									
										23
									
								
								database/test.py
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										23
									
								
								database/test.py
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,23 @@ | |||||||
|  | import sqlite3 | ||||||
|  |  | ||||||
|  | db_file = 'database/dns.db' | ||||||
|  | if __name__ == '__main__': | ||||||
|  |     conn = sqlite3.connect(db_file) | ||||||
|  |     cursor = conn.cursor() | ||||||
|  |     domain = 'mamahaha.wor12' | ||||||
|  |     ip = "1.1.1.11" | ||||||
|  |     pubkey = "asdfasdfadfsdf" | ||||||
|  |     cursor.execute("SELECT * FROM xiaomiandns WHERE domain = ? OR ip = ? OR pubkey = ?", | ||||||
|  |               (domain, ip, pubkey)) | ||||||
|  |     existing_data = cursor.fetchall() | ||||||
|  |     if existing_data: | ||||||
|  |         print("qqqqqq") | ||||||
|  |     else: | ||||||
|  |         # Insert the new data | ||||||
|  |         cursor.execute( | ||||||
|  |             "INSERT INTO xiaomiandns (domain, ip, pubkey) VALUES (?, ?, ?)", (domain, ip, pubkey)) | ||||||
|  |         print("Data inserted successfully") | ||||||
|  |          | ||||||
|  |     conn.commit() | ||||||
|  |     cursor.close() | ||||||
|  |     conn.close() | ||||||
| @@ -86,15 +86,14 @@ class DNSServer: | |||||||
|  |  | ||||||
|  |  | ||||||
| class DNSAPI: | class DNSAPI: | ||||||
|     # usage: /add?domian=xxxx&ip=xx.xx.xx.xx&key=xxxxx |     # usage: /add?domian=xxxx&ip=xx.xx.xx.xx&pubkey=xxxxx | ||||||
|     #        /delete?domian=xxxx&ip=xx.xx.xx.xx&key=xxxxx |     #        /delete?domian=xxxx&ip=xx.xx.xx.xx&prikey=xxxxx | ||||||
|  |  | ||||||
|     def __init__(self, hostname, port, db_file): |     def __init__(self, hostname, port, db_file): | ||||||
|         self.hostname = hostname |         self.hostname = hostname | ||||||
|         self.port = port |         self.port = port | ||||||
|         self.db_file = db_file |         self.db_file = db_file | ||||||
|  |  | ||||||
|  |  | ||||||
|     def run(self): |     def run(self): | ||||||
|         server_socket = socket.socket(socket.AF_INET, socket.SOCK_STREAM) |         server_socket = socket.socket(socket.AF_INET, socket.SOCK_STREAM) | ||||||
|         # 绑定 IP 地址和端口号 |         # 绑定 IP 地址和端口号 | ||||||
| @@ -109,16 +108,16 @@ class DNSAPI: | |||||||
|             t = threading.Thread(target=self.handle_tcp_request, args=(conn,)) |             t = threading.Thread(target=self.handle_tcp_request, args=(conn,)) | ||||||
|             t.start() |             t.start() | ||||||
|  |  | ||||||
|     def handle_tcp_request(self,conn): |     def handle_tcp_request(self, conn): | ||||||
|         request = conn.recv(1024).decode('utf-8') |         request = conn.recv(1024).decode('utf-8') | ||||||
|         response = self.handle_http_request(request) |         response = self.handle_http_request(request) | ||||||
|         conn.send(response) |         conn.send(response) | ||||||
|         conn.close() |         conn.close() | ||||||
|  |  | ||||||
|     def handle_http_request(self, request): |     def handle_http_request(self, request): | ||||||
|         request_line, headers= request.split('\r\n\r\n', 2) |         request_line, headers = request.split('\r\n\r\n', 2) | ||||||
|         method, url, version = request_line.split(' ', 2) |         method, url, version = request_line.split(' ', 2) | ||||||
|         print(method,url) |         print(method, url) | ||||||
|         if method == 'GET': |         if method == 'GET': | ||||||
|             response = self.handle_get_request(url) |             response = self.handle_get_request(url) | ||||||
|         else: |         else: | ||||||
| @@ -127,16 +126,16 @@ class DNSAPI: | |||||||
|  |  | ||||||
|     def handle_get_request(self, url): |     def handle_get_request(self, url): | ||||||
|         # check url start with /add |         # check url start with /add | ||||||
|         if re.match(r'^/add\?',url): |         if re.match(r'^/add\?', url): | ||||||
|             status_code = self.add_data(url[5:]) |             status_code = self.add_data(url[5:]) | ||||||
|             if status_code = 200: |             if status_code == 200: | ||||||
|                 reason_phrase = 'Add data successful' |                 reason_phrase = 'Add data successful' | ||||||
|             else: |             else: | ||||||
|                 reason_phrase = 'Add data unsuccessful' |                 reason_phrase = 'Add data unsuccessful' | ||||||
|         # check url start with /delete |         # check url start with /delete | ||||||
|         elif re.match(r'^/delete\?',url): |         elif re.match(r'^/delete\?', url): | ||||||
|             status_code = self.delete_data(url[9:]) |             status_code = self.delete_data(url[9:]) | ||||||
|             if status_code = 200: |             if status_code == 200: | ||||||
|                 reason_phrase = 'Delete data successful' |                 reason_phrase = 'Delete data successful' | ||||||
|             else: |             else: | ||||||
|                 reason_phrase = 'Delete data unsuccessful' |                 reason_phrase = 'Delete data unsuccessful' | ||||||
| @@ -164,16 +163,29 @@ class DNSAPI: | |||||||
|     def add_data(self, url): |     def add_data(self, url): | ||||||
|         domain = re.search(r'domain=([^&]+)', url) |         domain = re.search(r'domain=([^&]+)', url) | ||||||
|         ip = re.search(r'ip=([^&]+)', url) |         ip = re.search(r'ip=([^&]+)', url) | ||||||
|         key = re.search(r'ip=([^&]+)', url) |         pubkey = re.search(r'pubkey=([^&]+)', url) | ||||||
|         if domain and ip and key: |         if domain and ip and key: | ||||||
|             domain = domain.group(1) |             domain = domain.group(1) | ||||||
|             ip = ip.group(1) |             ip = ip.group(1) | ||||||
|             key = key.group(1) |             pubkey = pubkey.group(1) | ||||||
|         else: |         else: | ||||||
|             return 400 |             return 400 | ||||||
|  |         conn = sqlite3.connect(self.db_file) | ||||||
|  |         c = conn.cursor() | ||||||
|  |  | ||||||
|  |         # Check if the data already exists | ||||||
|  |         c.execute( | ||||||
|  |             "SELECT * FROM xiaomiandns WHERE domain = ? OR ip = ? OR pubkey = ?", (domain, ip, pubkey)) | ||||||
|  |         existing_data = c.fetchall() | ||||||
|  |         if existing_data: | ||||||
|  |             return 400 | ||||||
|  |         else: | ||||||
|  |             # Insert the new data | ||||||
|  |             c.execute( | ||||||
|  |                 "INSERT INTO xiaomiandns (domain, ip, pubkey) VALUES (?, ?, ?)", (domain, ip, pubkey)) | ||||||
|             return 200 |             return 200 | ||||||
|  |  | ||||||
|     def delete_data(self,url): |     def delete_data(self, url): | ||||||
|         m = re.search(r'domain=([^&]+)', url) |         m = re.search(r'domain=([^&]+)', url) | ||||||
|         if m: |         if m: | ||||||
|             domain = m.group(1) |             domain = m.group(1) | ||||||
| @@ -183,7 +195,6 @@ class DNSAPI: | |||||||
|         return 200 |         return 200 | ||||||
|  |  | ||||||
|  |  | ||||||
|  |  | ||||||
| if __name__ == '__main__': | if __name__ == '__main__': | ||||||
|     # some config |     # some config | ||||||
|     db_file = '../database/dns.db' |     db_file = '../database/dns.db' | ||||||
|   | |||||||
		Reference in New Issue
	
	Block a user