refactor(HomeController): Ändern Sie den Routenparameter „EnvelopeReceiverReadOnly” von einem String-Schlüssel zu einer langen ID
- Aktualisieren Sie „MainAsync”, um mit einer geparsten schreibgeschützten ID anstelle eines String-Schlüssels zu „EnvelopeReceiverReadOnly” umzuleiten - Ändern Sie die Aktionssignatur „EnvelopeReceiverReadOnly”, um „long readOnlyId” anstelle von „[FromRoute] string readOnlyKey” zu akzeptieren - Inline-Schlüssel-Decodierungs-/Validierungslogik entfernt und Decodierung an `MainAsync` delegiert - Protokollmeldungen angepasst, um `ReadOnly-Id` anstelle von `ReadOnly-key` widerzuspiegeln
This commit is contained in:
parent
10b1de4cf0
commit
d0bfe795d7
@ -76,7 +76,7 @@ public class HomeController : ViewControllerBase
|
|||||||
}
|
}
|
||||||
|
|
||||||
if(decoded.GetEncodeType() == EncodeType.EnvelopeReceiverReadOnly)
|
if(decoded.GetEncodeType() == EncodeType.EnvelopeReceiverReadOnly)
|
||||||
return Redirect($"{envelopeReceiverId}/ReadOnly");
|
return await EnvelopeReceiverReadOnly(decoded.ParseReadOnlyId());
|
||||||
|
|
||||||
ViewData["EnvelopeKey"] = envelopeReceiverId;
|
ViewData["EnvelopeKey"] = envelopeReceiverId;
|
||||||
|
|
||||||
@ -371,73 +371,57 @@ public class HomeController : ViewControllerBase
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
[HttpGet("{readOnlyKey}/ReadOnly")]
|
[NonAction]
|
||||||
[Obsolete("Use MediatR")]
|
[Obsolete("Use MediatR")]
|
||||||
public async Task<IActionResult> EnvelopeReceiverReadOnly([FromRoute] string readOnlyKey)
|
public async Task<IActionResult> EnvelopeReceiverReadOnly([FromRoute] long readOnlyId)
|
||||||
{
|
{
|
||||||
try
|
var erro_res = await _readOnlyService.ReadByIdAsync(readOnlyId);
|
||||||
|
if (erro_res.IsFailed)
|
||||||
{
|
{
|
||||||
// check if the readOnlyId is valid
|
_logger.LogNotice(erro_res.Notices);
|
||||||
if (!readOnlyKey.TryDecode(out var decodedKeys) || decodedKeys.GetEncodeType() != EncodeType.EnvelopeReceiverReadOnly)
|
|
||||||
{
|
|
||||||
Response.StatusCode = StatusCodes.Status401Unauthorized;
|
|
||||||
return this.ViewDocumentNotFound();
|
|
||||||
}
|
|
||||||
|
|
||||||
var readOnlyId = decodedKeys.ParseReadOnlyId();
|
|
||||||
var erro_res = await _readOnlyService.ReadByIdAsync(readOnlyId);
|
|
||||||
if (erro_res.IsFailed)
|
|
||||||
{
|
|
||||||
_logger.LogNotice(erro_res.Notices);
|
|
||||||
return this.ViewInnerServiceError();
|
|
||||||
}
|
|
||||||
|
|
||||||
var erro = erro_res.Data;
|
|
||||||
|
|
||||||
if (DateTime.Now > erro.DateValid)
|
|
||||||
return View("EnvelopeExpired");
|
|
||||||
|
|
||||||
return await _envRcvService.ReadByUuidSignatureAsync(uuid: erro.Envelope!.Uuid, erro.Receiver!.Signature).ThenAsync(
|
|
||||||
SuccessAsync: async er =>
|
|
||||||
{
|
|
||||||
var envelopeKey = (er.Envelope!.Uuid, er.Receiver!.Signature).ToEnvelopeKey();
|
|
||||||
|
|
||||||
//TODO: implement multi-threading to history process (Task)
|
|
||||||
var hist_res = await _historyService.RecordAsync((int)erro.EnvelopeId, erro.AddedWho, EnvelopeStatus.EnvelopeViewed);
|
|
||||||
if (hist_res.IsFailed)
|
|
||||||
{
|
|
||||||
_logger.LogError(
|
|
||||||
"Although the envelope was sent as read-only, the EnvelopeShared hisotry could not be saved. ReadOnly-key: {readOnlyKey}\nEnvelope Receiver:\n{envelopeReceiver}",
|
|
||||||
readOnlyKey, JsonConvert.SerializeObject(er));
|
|
||||||
_logger.LogNotice(hist_res.Notices);
|
|
||||||
}
|
|
||||||
|
|
||||||
if (er.Envelope.Documents?.FirstOrDefault() is DocumentDto doc && doc.ByteData is not null)
|
|
||||||
{
|
|
||||||
ViewData["DocumentBytes"] = doc.ByteData;
|
|
||||||
ViewData["EnvelopeKey"] = envelopeKey;
|
|
||||||
ViewData["IsReadOnly"] = true;
|
|
||||||
ViewData["ReadOnly"] = erro;
|
|
||||||
ViewData["PSPDFKitLicenseKey"] = _configuration["PSPDFKitLicenseKey"];
|
|
||||||
return View("ShowEnvelope", er);
|
|
||||||
}
|
|
||||||
else
|
|
||||||
{
|
|
||||||
_logger.LogEnvelopeError(envelopeReceiverId: envelopeKey, message: "No document byte-data was found in ENVELOPE_DOCUMENT table.");
|
|
||||||
return this.ViewDocumentNotFound();
|
|
||||||
}
|
|
||||||
},
|
|
||||||
Fail: (messages, notices) =>
|
|
||||||
{
|
|
||||||
_logger.LogNotice(notices);
|
|
||||||
return this.ViewEnvelopeNotFound();
|
|
||||||
});
|
|
||||||
}
|
|
||||||
catch (Exception ex)
|
|
||||||
{
|
|
||||||
_logger.LogError(ex, "An unexpected error occurred while displaying a read-only envelope. Read-only key is {readOnlyKey}. {message}", readOnlyKey, ex.Message);
|
|
||||||
return this.ViewInnerServiceError();
|
return this.ViewInnerServiceError();
|
||||||
}
|
}
|
||||||
|
|
||||||
|
var erro = erro_res.Data;
|
||||||
|
|
||||||
|
if (DateTime.Now > erro.DateValid)
|
||||||
|
return View("EnvelopeExpired");
|
||||||
|
|
||||||
|
return await _envRcvService.ReadByUuidSignatureAsync(uuid: erro.Envelope!.Uuid, erro.Receiver!.Signature).ThenAsync(
|
||||||
|
SuccessAsync: async er =>
|
||||||
|
{
|
||||||
|
var envelopeKey = (er.Envelope!.Uuid, er.Receiver!.Signature).ToEnvelopeKey();
|
||||||
|
|
||||||
|
//TODO: implement multi-threading to history process (Task)
|
||||||
|
var hist_res = await _historyService.RecordAsync((int)erro.EnvelopeId, erro.AddedWho, EnvelopeStatus.EnvelopeViewed);
|
||||||
|
if (hist_res.IsFailed)
|
||||||
|
{
|
||||||
|
_logger.LogError(
|
||||||
|
"Although the envelope was sent as read-only, the EnvelopeShared hisotry could not be saved. ReadOnly-Id: {readOnlyKey}\nEnvelope Receiver:\n{envelopeReceiver}",
|
||||||
|
readOnlyId, JsonConvert.SerializeObject(er));
|
||||||
|
_logger.LogNotice(hist_res.Notices);
|
||||||
|
}
|
||||||
|
|
||||||
|
if (er.Envelope.Documents?.FirstOrDefault() is DocumentDto doc && doc.ByteData is not null)
|
||||||
|
{
|
||||||
|
ViewData["DocumentBytes"] = doc.ByteData;
|
||||||
|
ViewData["EnvelopeKey"] = envelopeKey;
|
||||||
|
ViewData["IsReadOnly"] = true;
|
||||||
|
ViewData["ReadOnly"] = erro;
|
||||||
|
ViewData["PSPDFKitLicenseKey"] = _configuration["PSPDFKitLicenseKey"];
|
||||||
|
return View("ShowEnvelope", er);
|
||||||
|
}
|
||||||
|
else
|
||||||
|
{
|
||||||
|
_logger.LogEnvelopeError(envelopeReceiverId: envelopeKey, message: "No document byte-data was found in ENVELOPE_DOCUMENT table.");
|
||||||
|
return this.ViewDocumentNotFound();
|
||||||
|
}
|
||||||
|
},
|
||||||
|
Fail: (messages, notices) =>
|
||||||
|
{
|
||||||
|
_logger.LogNotice(notices);
|
||||||
|
return this.ViewEnvelopeNotFound();
|
||||||
|
});
|
||||||
}
|
}
|
||||||
|
|
||||||
[HttpGet("Error404")]
|
[HttpGet("Error404")]
|
||||||
|
|||||||
Loading…
x
Reference in New Issue
Block a user