From f7ab0697a5291d69eec69c21a4448590a6a5668a Mon Sep 17 00:00:00 2001 From: Ivan Golikov Date: Thu, 26 Dec 2024 23:25:54 +0100 Subject: [PATCH] API update --- pssecret/main.py | 20 +++++++++++++++++--- pssecret/models.py | 10 ++++++---- 2 files changed, 23 insertions(+), 7 deletions(-) diff --git a/pssecret/main.py b/pssecret/main.py index 0e97ec3..5d2b771 100644 --- a/pssecret/main.py +++ b/pssecret/main.py @@ -8,19 +8,33 @@ from pssecret.utils import get_new_key app = FastAPI() -@app.post("/secret", response_model=SecretSaveResult) +@app.post( + "/secret", + summary="Store secret", + description=( + "Submit secret, it is saved on the server, get retrieval key in response. " + "Use that key to retrieve your data. Key could be used only once, " + "so use it wisely" + ), + response_model=SecretSaveResult, +) async def set_secret(data: Secret): new_key = await get_new_key() await redis.setex(new_key, 60 * 60 * 24, data.data) return { - "status": "saved", - "retrieval_url": f"/secret/{new_key}", + "key": new_key, } @app.get( "/secret/{secret_key}", + summary="Retrieve secret", + description=( + "Returns previously saved data if it is still on the server. " + "Could be the other way around in two cases: " + "either it has already been retrieved, either storage timeout has expired" + ), response_model=Secret, responses={404: {"description": "The item was not found"}}, ) diff --git a/pssecret/models.py b/pssecret/models.py index c51f16d..aa64d3e 100644 --- a/pssecret/models.py +++ b/pssecret/models.py @@ -1,10 +1,12 @@ -from pydantic import BaseModel +from pydantic import BaseModel, Field class Secret(BaseModel): - data: str + data: str = Field(title="Secret", description="Some secret data") class SecretSaveResult(BaseModel): - status: str - retrieval_url: str + key: str = Field( + title="Retrieval key", + description="Key that should be used for retrieval of submitted secret", + )