import httpx
|
|
from app.config.config import settings
|
from app.utils.rsa_crypto import RagflowCrypto
|
|
|
class RagflowService:
|
def __init__(self, base_url: str):
|
self.base_url = base_url
|
|
async def register(self, username: str, password: str):
|
password = RagflowCrypto(settings.PUBLIC_KEY, settings.PRIVATE_KEY).encrypt(password)
|
async with httpx.AsyncClient() as client:
|
response = await client.post(
|
f"{self.base_url}/v1/user/register",
|
json={"nickname": username, "email": f"{username}@example.com", "password": password},
|
headers={'Content-Type': 'application/json'}
|
)
|
if response.status_code != 200:
|
raise Exception(f"Ragflow registration failed: {response.text}")
|
|
async def login(self, username: str, password: str) -> str:
|
password = RagflowCrypto(settings.PUBLIC_KEY, settings.PRIVATE_KEY).encrypt(password)
|
async with httpx.AsyncClient() as client:
|
response = await client.post(
|
f"{self.base_url}/v1/user/login",
|
json={"email": f"{username}@example.com", "password": password},
|
headers={'Content-Type': 'application/json'}
|
)
|
if response.status_code != 200:
|
raise Exception(f"Ragflow login failed: {response.text}")
|
return response.json().get('data', {}).get('access_token')
|