main #17
| @@ -2,11 +2,9 @@ from fastapi import FastAPI | |||||||
| from fastapi.encoders import jsonable_encoder | from fastapi.encoders import jsonable_encoder | ||||||
| from fastapi.responses import JSONResponse | from fastapi.responses import JSONResponse | ||||||
| from contextlib import asynccontextmanager | from contextlib import asynccontextmanager | ||||||
| from typing import Tuple, Callable |  | ||||||
| import sqlite3 | import sqlite3 | ||||||
| import asyncio | import asyncio | ||||||
| import time | import time | ||||||
| import random |  | ||||||
|  |  | ||||||
| @asynccontextmanager | @asynccontextmanager | ||||||
| async def lifespan(app: FastAPI): | async def lifespan(app: FastAPI): | ||||||
| @@ -28,7 +26,7 @@ cursor.execute('''CREATE TABLE IF NOT EXISTS nodes ( | |||||||
|                )''') |                )''') | ||||||
|  |  | ||||||
| def init(): | def init(): | ||||||
|     task = asyncio.create_task(receive_heartbeat_internal()) |     asyncio.create_task(receive_heartbeat_internal()) | ||||||
|  |  | ||||||
| def clean_env(): | def clean_env(): | ||||||
|     # 关闭游标和连接 |     # 关闭游标和连接 | ||||||
| @@ -93,16 +91,13 @@ async def receive_heartbeat(ip: str): | |||||||
|         cursor.execute("UPDATE nodes SET last_heartbeat = ? WHERE ip = ?", (time.time(), ip)) |         cursor.execute("UPDATE nodes SET last_heartbeat = ? WHERE ip = ?", (time.time(), ip)) | ||||||
|         return {"status": "received"}      |         return {"status": "received"}      | ||||||
|      |      | ||||||
| async def receive_heartbeat_internal() -> int: | async def receive_heartbeat_internal(): | ||||||
|     while 1: |     while 1: | ||||||
|         print('successful delete1') |         timeout = 70 | ||||||
|         timeout = 10 |  | ||||||
|         # 删除超时的节点 |         # 删除超时的节点 | ||||||
|         cursor.execute("DELETE FROM nodes WHERE last_heartbeat < ?", (time.time() - timeout,)) |         cursor.execute("DELETE FROM nodes WHERE last_heartbeat < ?", (time.time() - timeout,)) | ||||||
|         conn.commit() |         conn.commit() | ||||||
|         print('successful delete') |  | ||||||
|         await asyncio.sleep(timeout) |         await asyncio.sleep(timeout) | ||||||
|     return 1 |  | ||||||
|  |  | ||||||
| @app.get("/server/send_nodes_list") | @app.get("/server/send_nodes_list") | ||||||
| async def send_nodes_list(count: int) -> JSONResponse: | async def send_nodes_list(count: int) -> JSONResponse: | ||||||
|   | |||||||
| @@ -272,7 +272,7 @@ def f(x: int, f_modulus: list, T: int) -> int: | |||||||
|     return res |     return res | ||||||
|  |  | ||||||
|  |  | ||||||
| def GenerateReKey(sk_A: int, pk_B: point, N: int, T: int) -> list: | def GenerateReKey(sk_A: int, pk_B: point, N: int, T: int, id_tuple: Tuple[int,...]) -> list: | ||||||
|     """ |     """ | ||||||
|     param: |     param: | ||||||
|     skA, pkB, N(节点总数), T(阈值) |     skA, pkB, N(节点总数), T(阈值) | ||||||
| @@ -288,7 +288,7 @@ def GenerateReKey(sk_A: int, pk_B: point, N: int, T: int) -> list: | |||||||
|     # d是Bob的密钥对与临时密钥对的非交互式Diffie-Hellman密钥交换的结果 |     # d是Bob的密钥对与临时密钥对的非交互式Diffie-Hellman密钥交换的结果 | ||||||
|     d = hash3((X_A, pk_B, multiply(pk_B, x_A))) |     d = hash3((X_A, pk_B, multiply(pk_B, x_A))) | ||||||
|  |  | ||||||
|     # 计算多项式系数, 确定代理节点的ID(一个点) |     # 计算多项式系数 | ||||||
|     f_modulus = [] |     f_modulus = [] | ||||||
|     # 计算f0 |     # 计算f0 | ||||||
|     # f0 = (sk_A * inv(d, G.P)) % G.P |     # f0 = (sk_A * inv(d, G.P)) % G.P | ||||||
| @@ -305,10 +305,10 @@ def GenerateReKey(sk_A: int, pk_B: point, N: int, T: int) -> list: | |||||||
|     for i in range(N): |     for i in range(N): | ||||||
|         y = random.randint(0, sm2p256v1.N - 1) |         y = random.randint(0, sm2p256v1.N - 1) | ||||||
|         Y = multiply(g, y) |         Y = multiply(g, y) | ||||||
|         s_x = hash5(i, D)  # id需要设置 |         s_x = hash5(id_tuple[i], D)  # id需要设置 | ||||||
|         r_k = f(s_x, f_modulus, T) |         r_k = f(s_x, f_modulus, T) | ||||||
|         U1 = multiply(U, r_k) |         U1 = multiply(U, r_k) | ||||||
|         kFrag = (i, r_k, X_A, U1) |         kFrag = (id_tuple[i], r_k, X_A, U1) | ||||||
|         KF.append(kFrag) |         KF.append(kFrag) | ||||||
|  |  | ||||||
|     return KF |     return KF | ||||||
|   | |||||||
		Reference in New Issue
	
	Block a user