fix: add reducers to raise error, handle complete_stream()

This commit is contained in:
ManishMadan2882 2024-06-20 00:10:29 +05:30
parent 69287c5198
commit ad29d2765f
2 changed files with 55 additions and 30 deletions

View File

@ -173,6 +173,7 @@ def get_prompt(prompt_id):
def complete_stream(question, retriever, conversation_id, user_api_key):
try:
response_full = ""
source_log_docs = []
answer = retriever.gen()
@ -196,7 +197,9 @@ def complete_stream(question, retriever, conversation_id, user_api_key):
yield f"data: {data}\n\n"
data = json.dumps({"type": "end"})
yield f"data: {data}\n\n"
except Exception:
data = json.dumps({"type": "error","error":"Please try again later. We apologize for any inconvenience."})
yield f"data: {data}\n\n"
@answer.route("/stream", methods=["POST"])
def stream():
@ -274,23 +277,29 @@ def stream():
),
mimetype="text/event-stream",
)
except ValueError:
message = "Malformed request body"
return Response(
error_stream_generate(message),
status=400,
mimetype="text/event-stream",
)
except Exception as e:
print("err",str(e))
message = e.args[0]
status_code = 400
# # Custom exceptions with two arguments, index 1 as status code
if(len(e.args) >= 2):
status_code = e.args[1]
def error_stream_generate():
data = json.dumps({"type": "error", "error":message})
yield f"data: {data}\n\n"
return Response(
error_stream_generate(),
error_stream_generate(message),
status=status_code,
mimetype="text/event-stream",
)
def error_stream_generate(err_response):
data = json.dumps({"type": "error", "error":err_response})
yield f"data: {data}\n\n"
@answer.route("/api/answer", methods=["POST"])
def api_answer():

View File

@ -68,6 +68,15 @@ export const fetchAnswer = createAsyncThunk<Answer, { question: string }>(
query: { conversationId: data.id },
}),
);
} else if (data.type === 'error') {
// set status to 'failed'
dispatch(conversationSlice.actions.setStatus('failed'));
dispatch(
conversationSlice.actions.raiseError({
index: state.conversation.queries.length - 1,
message: data.error,
}),
);
} else {
const result = data.answer;
dispatch(
@ -191,6 +200,13 @@ export const conversationSlice = createSlice({
setStatus(state, action: PayloadAction<Status>) {
state.status = action.payload;
},
raiseError(
state,
action: PayloadAction<{ index: number; message: string }>,
) {
const { index, message } = action.payload;
state.queries[index].error = message;
},
},
extraReducers(builder) {
builder