forked from ddrilling/AsbCloudServer
fix emails triggers and bodies
This commit is contained in:
parent
00cfb0909c
commit
24ccc2a128
@ -53,7 +53,8 @@ namespace AsbCloudDb.Model
|
||||
|
||||
DatabaseFacade Database { get; }
|
||||
|
||||
Task<int> RefreshMaterializedViewAsync<TEntity>(string? mwName = null, CancellationToken token = default) where TEntity : class;
|
||||
Task<int> RefreshMaterializedViewAsync(string? mwName = null, CancellationToken token = default);
|
||||
Task<int> RefreshMaterializedViewAsync<TEntity>(CancellationToken token = default) where TEntity : class;
|
||||
int SaveChanges();
|
||||
int SaveChanges(bool acceptAllChangesOnSuccess);
|
||||
Task<int> SaveChangesAsync(CancellationToken cancellationToken);
|
||||
|
@ -57,7 +57,6 @@ namespace AsbCloudInfrastructure.Services.DetectOperations
|
||||
catch (Exception ex)
|
||||
{
|
||||
Trace.TraceError(ex.Message);
|
||||
Console.WriteLine(ex.Message);
|
||||
}
|
||||
GC.Collect();
|
||||
}
|
||||
|
@ -8,58 +8,8 @@ namespace AsbCloudInfrastructure.Services.DrillingProgram
|
||||
{
|
||||
internal class DrillingProgramMaker
|
||||
{
|
||||
|
||||
private const int maxAllowedColumns = 256;
|
||||
|
||||
//public async Task<FileInfoDto> GetOrCreateAsync(int idWell, int idUser, CancellationToken token = default)
|
||||
//{
|
||||
// var programParts = (await fileService.GetInfosByCategoryAsync(idWell, idFileCategoryDrillingProgramItems, token)
|
||||
// .ConfigureAwait(false))
|
||||
// .Where(f => f.FileMarks?.Any(m => m.IdMarkType == 1 && !m.IsDeleted) ?? false);
|
||||
|
||||
// var well = await wellService.GetAsync(idWell, token)
|
||||
// .ConfigureAwait(false);
|
||||
|
||||
// var programs = await fileService.GetInfosByCategoryAsync(idWell, idFileCategoryDrillingProgram, token)
|
||||
// .ConfigureAwait(false);
|
||||
|
||||
// if (programs is not null && programs.Any() && programParts.Any())
|
||||
// {
|
||||
// programs = programs.OrderByDescending(f => f.UploadDate);
|
||||
// var matchFilesIterator = programs.GetEnumerator();
|
||||
// matchFilesIterator.MoveNext();
|
||||
// var matchFile = matchFilesIterator.Current;
|
||||
|
||||
// if (programParts.All(pp => matchFile.UploadDate > pp.UploadDate) &&
|
||||
// File.Exists(fileService.GetUrl(matchFile)))
|
||||
// return matchFile;
|
||||
// else
|
||||
// await fileService.DeleteAsync(matchFile.Id, token)
|
||||
// .ConfigureAwait(false);
|
||||
|
||||
// while (matchFilesIterator.MoveNext())
|
||||
// await fileService.DeleteAsync(matchFilesIterator.Current.Id, token)
|
||||
// .ConfigureAwait(false);
|
||||
// }
|
||||
|
||||
// if (!programParts.Any())
|
||||
// throw new FileNotFoundException("Нет частей для формирования программы бурения");
|
||||
|
||||
// var resultFileName = $"Программа бурения {well.Cluster} {well.Caption}.xlsx";
|
||||
|
||||
// var filteredFilePaths = programParts
|
||||
// .Select(file => fileService.GetUrl(file));
|
||||
|
||||
// var tempResultFilePath = Path.Combine(Path.GetTempPath(), "drillingProgram", resultFileName);
|
||||
|
||||
// UniteExcelFiles(filteredFilePaths, tempResultFilePath);
|
||||
|
||||
// var fileInfo = await fileService.MoveAsync(idWell, null, idFileCategoryDrillingProgram,
|
||||
// resultFileName, tempResultFilePath, token).ConfigureAwait(false);
|
||||
|
||||
// return fileInfo;
|
||||
//}
|
||||
|
||||
public static void UniteExcelFiles(IEnumerable<string> excelFilesNames, string resultExcelPath)
|
||||
{
|
||||
var resultExcelFile = new XLWorkbook(XLEventTracking.Disabled);
|
||||
|
@ -254,7 +254,8 @@ namespace AsbCloudInfrastructure.Services.DrillingProgram
|
||||
if (idUserRole == idUserRoleApprover)
|
||||
await RemoveDrillingProgramAsync(part.IdWell, token);
|
||||
|
||||
await NotifyNewPublisherAsync(idWell, user, part.FileCategory.Name, token);
|
||||
if (idUserRole == idUserRolePublisher)
|
||||
await NotifyNewPublisherAsync(idWell, user, part.FileCategory.Name, token);
|
||||
|
||||
return await context.SaveChangesAsync(token);
|
||||
}
|
||||
@ -291,11 +292,16 @@ namespace AsbCloudInfrastructure.Services.DrillingProgram
|
||||
|
||||
var part = await context.DrillingProgramParts
|
||||
.Include(p => p.RelatedUsers)
|
||||
.ThenInclude(r => r.User)
|
||||
.AsNoTracking()
|
||||
.FirstOrDefaultAsync(p => p.IdWell == fileInfo.IdWell && p.IdFileCategory == fileInfo.IdCategory, token);
|
||||
|
||||
if (!part.RelatedUsers.Any(r => r.IdUser == idUser && r.IdUserRole == idUserRoleApprover))
|
||||
var user = part.RelatedUsers.FirstOrDefault(r => r.IdUser == idUser && r.IdUserRole == idUserRoleApprover)?.User;
|
||||
if (user is null)
|
||||
throw new ForbidException($"User {idUser} is not in the approvers list.");
|
||||
|
||||
fileMarkDto.User = user.Adapt<UserDto>();
|
||||
|
||||
var oldMarksIds = fileInfo.FileMarks
|
||||
?.Where(m => m.User.Id == idUser)
|
||||
.Select(m => m.Id);
|
||||
@ -311,16 +317,22 @@ namespace AsbCloudInfrastructure.Services.DrillingProgram
|
||||
await RemoveDrillingProgramAsync(fileInfo.IdWell, token);
|
||||
await NotifyPublisherOnRejectAsync(fileMarkDto, token);
|
||||
}
|
||||
|
||||
// если все согласованты согласовали - оповещаем публикатора
|
||||
if (part.RelatedUsers
|
||||
.Where(u => u.IdUserRole == idUserRoleApprover)
|
||||
.All(user => fileInfo.FileMarks
|
||||
.Any(mark => mark.IdMarkType == idMarkTypeApprove && mark.User.Id == user.IdUser)))
|
||||
else
|
||||
{
|
||||
await NotifyPublisherOnFullAccepAsync(fileMarkDto, token);
|
||||
// если все согласованты согласовали - оповещаем публикатора
|
||||
var approvers = part.RelatedUsers
|
||||
.Where(u => u.IdUserRole == idUserRoleApprover);
|
||||
if (approvers
|
||||
.All(user => fileInfo.FileMarks
|
||||
.Any(mark => (mark.IdMarkType == idMarkTypeApprove && mark.User.Id == user.IdUser && !mark.IsDeleted)) ||
|
||||
(fileMarkDto.IdMarkType == idMarkTypeApprove && user.IdUser == idUser)))
|
||||
{
|
||||
await NotifyPublisherOnFullAccepAsync(fileMarkDto, token);
|
||||
}
|
||||
}
|
||||
|
||||
|
||||
|
||||
return result;
|
||||
}
|
||||
|
||||
|
@ -7,10 +7,10 @@ namespace AsbCloudInfrastructure
|
||||
{
|
||||
class MailBodyFactory
|
||||
{
|
||||
protected readonly string platformName;
|
||||
private readonly string platformName;
|
||||
private readonly string platformUrl;
|
||||
protected readonly string companyName;
|
||||
protected readonly string supportMail;
|
||||
private readonly string companyName;
|
||||
private readonly string supportMail;
|
||||
|
||||
public MailBodyFactory(IConfiguration configuration)
|
||||
{
|
||||
@ -26,11 +26,11 @@ namespace AsbCloudInfrastructure
|
||||
return subj;
|
||||
}
|
||||
|
||||
public string MakeMailBodyForNewPublisher(WellDto well, string userName, string documentCategory)
|
||||
public string MakeMailBodyForNewPublisher(WellDto well, string publisherName, string documentCategory)
|
||||
{
|
||||
var drillingProgramHref = MakeDrillingProgramHref(well);
|
||||
|
||||
var body = $"<html><body><h2>Здравствуйте, {userName}.</h2>" +
|
||||
var body = $"<html><body><h2>Здравствуйте, {publisherName}.</h2>" +
|
||||
$"На портале {platformName} началось создание программы бурения скважины {drillingProgramHref}," +
|
||||
$" куст {well.Cluster}, месторождение {well.Deposit}." +
|
||||
$"<br><br>От вас ожидается загрузка на портал документа «{documentCategory}» в формате excel (*.xlsx)." +
|
||||
@ -39,13 +39,12 @@ namespace AsbCloudInfrastructure
|
||||
return body;
|
||||
}
|
||||
|
||||
public string MakeMailBodyForApproverNewFile(WellDto well, string userName, int idFile, string fileName)
|
||||
public string MakeMailBodyForApproverNewFile(WellDto well, string approverName, int idFile, string fileName)
|
||||
{
|
||||
var fileDownloadHref = MakeFileDownloadHref(well.Id, idFile, fileName);
|
||||
var drillingProgramHref = MakeDrillingProgramHref(well);
|
||||
|
||||
var body = $"<html><body><h2>Здравствуйте, {userName}.</h2>" +
|
||||
$"На портал {platformName} загружен документ {fileDownloadHref}" +
|
||||
var body = $"<html><body><h2>Здравствуйте, {approverName}.</h2>" +
|
||||
$"На портал {platformName} загружен документ {fileName}" +
|
||||
$" для согласования при создании программы бурения скважины {drillingProgramHref}, куст ({well.Cluster})" +
|
||||
$", месторождение ({well.Deposit}).<br>" +
|
||||
MakeSignatue() +
|
||||
@ -53,28 +52,26 @@ namespace AsbCloudInfrastructure
|
||||
return body;
|
||||
}
|
||||
|
||||
public string MakeMailBodyForPublisherOnReject(WellDto well, string userName, int idFile, string fileName, FileMarkDto fileMark)
|
||||
public string MakeMailBodyForPublisherOnReject(WellDto well, string publisherName, int idFile, string fileName, FileMarkDto fileMark)
|
||||
{
|
||||
var fileDownloadHref = MakeFileDownloadHref(well.Id, idFile, fileName);
|
||||
var drillingProgramHref = MakeDrillingProgramHref(well);
|
||||
|
||||
var body = $"<html><body><h2>Здравствуйте, {userName}.</h2>" +
|
||||
$"На портале {platformName} отклонен загруженный вами документ {fileDownloadHref} " +
|
||||
var body = $"<html><body><h2>Здравствуйте, {publisherName}.</h2>" +
|
||||
$"На портале {platformName} отклонен загруженный вами документ {fileName} " +
|
||||
$" по программе бурения скважины {drillingProgramHref}," +
|
||||
$" куст {well.Cluster}, месторождение {well.Deposit}." +
|
||||
$" Комментарий согласующего ({fileMark.User.Name} {fileMark.User.Surname}):<br>{fileMark.Comment}" +
|
||||
$" Комментарий согласующего ({fileMark.User?.Name} {fileMark.User?.Surname}):<br>{fileMark.Comment}" +
|
||||
MakeSignatue() +
|
||||
$"</body></html>";
|
||||
return body;
|
||||
}
|
||||
|
||||
public string MakeMailBodyForPublisherOnFullAccept(WellDto well, string userName, int idFile, string fileName)
|
||||
public string MakeMailBodyForPublisherOnFullAccept(WellDto well, string publisherName, int idFile, string fileName)
|
||||
{
|
||||
var fileDownloadHref = MakeFileDownloadHref(well.Id, idFile, fileName);
|
||||
var drillingProgramHref = MakeDrillingProgramHref(well);
|
||||
|
||||
var body = $"<html><body><h2>Здравствуйте, {userName}.</h2>" +
|
||||
$"На портале {platformName} полностью согласован документ {fileDownloadHref} " +
|
||||
var body = $"<html><body><h2>Здравствуйте, {publisherName}.</h2>" +
|
||||
$"На портале {platformName} полностью согласован документ {fileName} " +
|
||||
$" по программе бурения скважины {drillingProgramHref}," +
|
||||
$" куст {well.Cluster}, месторождение {well.Deposit}." +
|
||||
MakeSignatue() +
|
||||
@ -82,16 +79,9 @@ namespace AsbCloudInfrastructure
|
||||
return body;
|
||||
}
|
||||
|
||||
private string MakeFileDownloadHref(int idWell, int idFile, string fileName)
|
||||
{
|
||||
var fileDownloadUrl = $"{platformUrl}/api/well/{idWell}/files/{idFile}";
|
||||
var fileDownloadHref = MakeHref(fileDownloadUrl, fileName);
|
||||
return fileDownloadHref;
|
||||
}
|
||||
|
||||
private string MakeDrillingProgramHref(WellDto well)
|
||||
{
|
||||
var drillingProgramUrl = $"{platformUrl}/api/well/{well.Id}/drillingProgram";
|
||||
var drillingProgramUrl = $"{platformUrl}/well/{well.Id}/drillingProgram";
|
||||
var drillingProgramHref = MakeHref(drillingProgramUrl, well.Caption);
|
||||
return drillingProgramHref;
|
||||
}
|
||||
|
@ -337,6 +337,7 @@ namespace AsbCloudInfrastructure.Services
|
||||
newFileMark.Id = default;
|
||||
newFileMark.DateCreated = DateTime.UtcNow;
|
||||
newFileMark.IdUser = idUser;
|
||||
newFileMark.User = null;
|
||||
|
||||
db.FileMarks.Add(newFileMark);
|
||||
return await db.SaveChangesAsync(token);
|
||||
|
@ -125,7 +125,7 @@ namespace AsbCloudWebApi.Controllers
|
||||
|
||||
if (!fileName.EndsWith(".xlsx"))
|
||||
return BadRequest(ArgumentInvalidException.MakeValidationError("file", "Файл должен быть xlsx"));
|
||||
|
||||
|
||||
var fileStream = files[0].OpenReadStream();
|
||||
var result = await drillingProgramService.AddFile(idWell, idFileCategory, (int)idUser, fileName, fileStream, token);
|
||||
|
||||
|
@ -16,7 +16,12 @@
|
||||
"email": {
|
||||
"smtpServer": "smtp.timeweb.ru",
|
||||
"sender": "bot@autodrilling.ru",
|
||||
"password": "xHhgwZ4D"
|
||||
"password": "xHhgwZ4D",
|
||||
|
||||
"platformName": "Цифровое бурение",
|
||||
"platformUrl": "cloud.digitaldrilling.ru",
|
||||
"companyName": "ООО \"Цифровое бурение\"",
|
||||
"supportMail": "support@digitaldrilling.ru"
|
||||
},
|
||||
"Urls": "http://0.0.0.0:5000" //;https://0.0.0.0:5001" //,
|
||||
// See https man: https://docs.microsoft.com/en-us/aspnet/core/fundamentals/servers/kestrel/endpoints?view=aspnetcore-6.0
|
||||
|
Loading…
Reference in New Issue
Block a user