协议修订版:draft
取消流程
当一方想要取消进行中的请求时,它发送一个包含以下内容的notifications/cancelled通知:
- 要取消的请求的ID
- 可选的原因字符串,可以记录或显示
行为要求
- 取消通知必须仅引用:
- 在同一方向上之前发出的请求
- 被认为仍在进行中的请求
- 客户端不得取消
initialize请求 - 取消通知的接收者应该:
- 停止处理已取消的请求
- 释放关联的资源
- 不为已取消的请求发送响应
- 接收者可以忽略取消通知,如果:
- 引用的请求未知
- 处理已完成
- 请求无法取消
- 取消通知的发送者应该忽略随后到达的对请求的任何响应
时间考虑
Due to network latency, cancellation notifications may arrive after request processing has completed, and potentially after a response has already been sent. Both parties MUST handle these race conditions gracefully:实施说明
- 双方应该记录取消原因以进行调试
- 应用程序UI应该指示何时请求取消
错误处理
无效的取消通知应该被忽略:- 未知的请求ID
- 已完成的请求
- 格式错误的通知