...
This commit is contained in:
@@ -1,9 +1,12 @@
|
||||
using Back.Common.Enums;
|
||||
using Back.Data.Models;
|
||||
using Back.Services;
|
||||
using Back.Validations;
|
||||
using Microsoft.AspNetCore.Authorization;
|
||||
using Microsoft.AspNetCore.Http;
|
||||
using Microsoft.AspNetCore.Mvc;
|
||||
using Shared.DTOs;
|
||||
using System.Security.Cryptography;
|
||||
|
||||
namespace Back.Controllers
|
||||
{
|
||||
@@ -12,12 +15,42 @@ namespace Back.Controllers
|
||||
[ApiController]
|
||||
public class TicketController : ControllerBase
|
||||
{
|
||||
private readonly MobileValidation _mobilevalidation;
|
||||
private readonly servTicket _servTicket;
|
||||
private readonly ServValidatinMsg _servValidatinMsg;
|
||||
public TicketController(MobileValidation mobilevalidation, servTicket servTicket, ServValidatinMsg servValidatinMsg)
|
||||
{
|
||||
_mobilevalidation = mobilevalidation;
|
||||
_servTicket = servTicket;
|
||||
_servValidatinMsg = servValidatinMsg;
|
||||
}
|
||||
|
||||
[HttpPost("NewTicketNoAuthentication")]
|
||||
[AllowAnonymous]
|
||||
public async Task<ActionResult<int>> NewTicketNoAuthentication(CTicketNoAuthenticationDto item)
|
||||
{
|
||||
return Ok();
|
||||
var resultValidationmodel = await _mobilevalidation.ValidateAsync(item.Mobile);
|
||||
if (!resultValidationmodel.IsValid)
|
||||
return BadRequest(resultValidationmodel.Errors.Select(s => s.ErrorMessage).ToList());
|
||||
|
||||
var pid=await _servTicket.NewPepole(item.FullName,item.Mobile);
|
||||
item.CompanyID = pid.Value.ToString();
|
||||
var Ticket = await _servTicket.NewTicket(item, StatusTicket.unknownPerson);
|
||||
|
||||
var code= await _servValidatinMsg.GenerateCode(new VerificationCode
|
||||
{
|
||||
ID = 0,
|
||||
prm = Ticket.ID.ToString(),
|
||||
val = item.Mobile,
|
||||
Type = "NewTicketNoAuthentication"
|
||||
});
|
||||
|
||||
return Ticket == null ? BadRequest() : Ok(new VerificationCodeDto
|
||||
{
|
||||
prm = Ticket.ID.ToString(),
|
||||
val = item.Mobile,
|
||||
Type = "NewTicketNoAuthentication"
|
||||
});
|
||||
}
|
||||
}
|
||||
}
|
||||
|
@@ -21,6 +21,8 @@ builder.Services.AddScoped(typeof(IAsyncRepository<>), typeof(RepositoryBase<>))
|
||||
builder.Services.AddScoped<Back.Services.ServBase>();
|
||||
builder.Services.AddScoped<MobileValidation> ();
|
||||
builder.Services.AddScoped<Service.Main>();
|
||||
builder.Services.AddScoped<servTicket > ();
|
||||
builder.Services.AddScoped < ServValidatinMsg>();
|
||||
string origins = "OriginTaxPayer";
|
||||
builder.Services.AddCors(options =>
|
||||
{
|
||||
|
35
Back/Services/ServValidatinMsg.cs
Normal file
35
Back/Services/ServValidatinMsg.cs
Normal file
@@ -0,0 +1,35 @@
|
||||
using Back.Data.Contracts;
|
||||
using Back.Data.Models;
|
||||
using Microsoft.EntityFrameworkCore;
|
||||
|
||||
namespace Back.Services
|
||||
{
|
||||
public class ServValidatinMsg
|
||||
{
|
||||
private readonly IAsyncRepository<VerificationCode> _verificationCodeRepo;
|
||||
public ServValidatinMsg(IAsyncRepository<VerificationCode> verificationCodeRepo)
|
||||
{
|
||||
_verificationCodeRepo = verificationCodeRepo;
|
||||
}
|
||||
public async Task<VerificationCode> GetCodeByPrm(string Prm)
|
||||
{
|
||||
return await _verificationCodeRepo.Get(w => w.prm == Prm).FirstOrDefaultAsync();
|
||||
|
||||
}
|
||||
public async Task<VerificationCode> GetRegistrationCode(int ID)
|
||||
{
|
||||
return await _verificationCodeRepo.Get(w => w.ID == ID).FirstOrDefaultAsync();
|
||||
}
|
||||
public async Task<int> GenerateCode(VerificationCode code)
|
||||
{
|
||||
code.ID = Random.Shared.Next(1000, 9000);
|
||||
while (await GetRegistrationCode(code.ID) != null)
|
||||
code.ID = Random.Shared.Next(1000, 9000);
|
||||
|
||||
|
||||
await _verificationCodeRepo.AddAsync(code);
|
||||
|
||||
return code.ID;
|
||||
}
|
||||
}
|
||||
}
|
104
Back/Services/servTicket.cs
Normal file
104
Back/Services/servTicket.cs
Normal file
@@ -0,0 +1,104 @@
|
||||
using Back.Common;
|
||||
using Back.Common.Enums;
|
||||
using Back.Data.Contracts;
|
||||
using Back.Data.Models;
|
||||
using Shared.DTOs;
|
||||
|
||||
namespace Back.Services
|
||||
{
|
||||
public class servTicket
|
||||
{
|
||||
private readonly IAsyncRepository<TiceketUnknownPeople> _ticketUnknownPeopleRepo;
|
||||
private readonly IAsyncRepository<Ticket> _ticketRepo;
|
||||
private readonly IAsyncRepository<SubTicket> _subticketRepo;
|
||||
public servTicket(IAsyncRepository<TiceketUnknownPeople> ticketUnknownPeopleRepo
|
||||
,IAsyncRepository<Ticket> ticketRepo
|
||||
,IAsyncRepository<SubTicket> subticketRepo
|
||||
)
|
||||
{
|
||||
_ticketUnknownPeopleRepo = ticketUnknownPeopleRepo;
|
||||
_ticketRepo = ticketRepo;
|
||||
_subticketRepo = subticketRepo;
|
||||
}
|
||||
public async Task<int?> NewPepole(string FullName, string Mobile)
|
||||
{
|
||||
try
|
||||
{
|
||||
var item=await _ticketUnknownPeopleRepo.AddAsync(new TiceketUnknownPeople
|
||||
{
|
||||
FullName = FullName,
|
||||
Mobile = Mobile
|
||||
});
|
||||
//_contextMongodb.InsertItem(new SysLog()
|
||||
//{
|
||||
// TraceIdentifierID = _httpContextAccessor.HttpContext.TraceIdentifier,
|
||||
// Datetime = DateTime.Now.ConvertMiladiToShamsi(),
|
||||
// Method = $"{_httpContextAccessor.HttpContext.Request.Method}/{this.GetType().FullName}/NewPepole",
|
||||
// Value = JsonConvert.SerializeObject(item),
|
||||
// Route = _httpContextAccessor.HttpContext.Request.Path,
|
||||
// Type = "User"
|
||||
//});
|
||||
return item.ID;
|
||||
}
|
||||
catch (Exception ex)
|
||||
{
|
||||
//_contextMongodb.InsertItem(new SysLog()
|
||||
//{
|
||||
// TraceIdentifierID = _httpContextAccessor.HttpContext.TraceIdentifier,
|
||||
// Datetime = DateTime.Now.ConvertMiladiToShamsi(),
|
||||
// Method = $"{_httpContextAccessor.HttpContext.Request.Method}/{this.GetType().FullName}/NewPepole",
|
||||
// Value = ex.Message,
|
||||
// Route = _httpContextAccessor.HttpContext.Request.Path,
|
||||
// Type = "catch"
|
||||
//});
|
||||
return 0;
|
||||
}
|
||||
|
||||
}
|
||||
public async Task<Ticket?> NewTicket(CTicketDto item, StatusTicket status = StatusTicket.Awaitingreview)
|
||||
{
|
||||
try
|
||||
{
|
||||
var ticket=await _ticketRepo.AddAsync(new Ticket
|
||||
{
|
||||
CompanyIDOrMobile = item.CompanyID,
|
||||
CreateDate = DateTime.Now.ConvertMiladiToShamsi(),
|
||||
CreateTime = DateTime.Now.ToString("hh:mm tt"),
|
||||
Title = item.Title,
|
||||
Status = status
|
||||
});
|
||||
await _subticketRepo.AddAsync(new SubTicket
|
||||
{
|
||||
Date = DateTime.Now.ConvertMiladiToShamsi(),
|
||||
Time = DateTime.Now.ToString("hh:mm tt"),
|
||||
TicketID = ticket.ID,
|
||||
Text = item.Text,
|
||||
Type = SideType.Customer
|
||||
});
|
||||
//_contextMongodb.InsertItem(new SysLog()
|
||||
//{
|
||||
// TraceIdentifierID = _httpContextAccessor.HttpContext.TraceIdentifier,
|
||||
// Datetime = DateTime.Now.ConvertMiladiToShamsi(),
|
||||
// Method = $"{_httpContextAccessor.HttpContext.Request.Method}/{this.GetType().FullName}/NewTicket",
|
||||
// Value = JsonConvert.SerializeObject(item),
|
||||
// Route = _httpContextAccessor.HttpContext.Request.Path,
|
||||
// Type = "User"
|
||||
//});
|
||||
return ticket;
|
||||
}
|
||||
catch (Exception ex)
|
||||
{
|
||||
//_contextMongodb.InsertItem(new SysLog()
|
||||
//{
|
||||
// TraceIdentifierID = _httpContextAccessor.HttpContext.TraceIdentifier,
|
||||
// Datetime = DateTime.Now.ConvertMiladiToShamsi(),
|
||||
// Method = $"{_httpContextAccessor.HttpContext.Request.Method}/{this.GetType().FullName}/NewTicket",
|
||||
// Value = ex.Message,
|
||||
// Route = _httpContextAccessor.HttpContext.Request.Path,
|
||||
// Type = "catch"
|
||||
//});
|
||||
return null;
|
||||
}
|
||||
}
|
||||
}
|
||||
}
|
@@ -9,7 +9,7 @@ namespace Shared.DTOs
|
||||
{
|
||||
public class CTicketDto
|
||||
{
|
||||
public string CompanyID { get; set; }
|
||||
public string? CompanyID { get; set; }
|
||||
[Required]
|
||||
public string Title { get; set; }
|
||||
[Required]
|
||||
|
@@ -10,8 +10,10 @@ namespace Shared.DTOs
|
||||
public class CTicketNoAuthenticationDto:CTicketDto
|
||||
{
|
||||
[Required]
|
||||
[StringLength(11)]
|
||||
public string Mobile { get; set; }
|
||||
[Required]
|
||||
[StringLength(5)]
|
||||
public string FullName { get; set; }
|
||||
}
|
||||
}
|
||||
|
15
Shared/DTOs/VerificationCodeDto.cs
Normal file
15
Shared/DTOs/VerificationCodeDto.cs
Normal file
@@ -0,0 +1,15 @@
|
||||
using System;
|
||||
using System.Collections.Generic;
|
||||
using System.Linq;
|
||||
using System.Text;
|
||||
using System.Threading.Tasks;
|
||||
|
||||
namespace Shared.DTOs
|
||||
{
|
||||
public class VerificationCodeDto
|
||||
{
|
||||
public string prm { get; set; }
|
||||
public string val { get; set; }
|
||||
public string Type { get; set; }
|
||||
}
|
||||
}
|
@@ -1,4 +1,8 @@
|
||||
<div class="contact-info-area pb-90" id="contact">
|
||||
@using Front.Pages
|
||||
@using Shared.DTOs
|
||||
@inject HttpClient _hc
|
||||
|
||||
<div class="contact-info-area pb-90" id="contact">
|
||||
<div class="container">
|
||||
<div class="row">
|
||||
</div>
|
||||
@@ -27,62 +31,46 @@
|
||||
<div class="col-xl-7 col-lg-6">
|
||||
<div class="contact-form-right-warp">
|
||||
<div class="postbox__comment-form">
|
||||
<form action="#" class="box">
|
||||
<EditForm EditContext="editContext" OnValidSubmit="newTicket">
|
||||
<DataAnnotationsValidator />
|
||||
<div class="postbox__comment-input mb-35">
|
||||
<ValidationMessage For="()=>model.FullName" />
|
||||
<ValidationMessage For="()=>model.Mobile" />
|
||||
<ValidationMessage For="()=>model.Title" />
|
||||
<ValidationMessage For="()=>model.Text" />
|
||||
</div>
|
||||
<div class="row gx-20">
|
||||
<div class="col-12">
|
||||
<div class="postbox__comment-input mb-30">
|
||||
<input type="text" class="inputText" required="">
|
||||
<InputText @bind-Value="model.FullName" id="FullName" type="text" class="inputText" required="" />
|
||||
<span class="floating-label">نام شما</span>
|
||||
</div>
|
||||
</div>
|
||||
<div class="col-12">
|
||||
<div class="postbox__comment-input mb-30">
|
||||
<input type="text" class="inputText" required="">
|
||||
<span class="floating-label">ایمیل شما</span>
|
||||
<div class="postbox__comment-input mb-35">
|
||||
<InputText @bind-Value="model.Mobile" id="Mobile" type="text" class="inputText" required=""/>
|
||||
<span class="floating-label">موبایل</span>
|
||||
</div>
|
||||
</div>
|
||||
<div class="col-12">
|
||||
<div class="postbox__comment-input mb-35">
|
||||
<input type="text" class="inputText" required="">
|
||||
<span class="floating-label">شماره تماس</span>
|
||||
</div>
|
||||
</div>
|
||||
<div class="col-12">
|
||||
<div class="postbox__select mb-30">
|
||||
<select style="display: none;">
|
||||
<option>موضوع</option>
|
||||
<option>موضوع 1</option>
|
||||
<option>موضوع 2</option>
|
||||
<option>موضوع 3</option>
|
||||
<option>موضوع 4</option>
|
||||
<option>موضوع 5</option>
|
||||
</select>
|
||||
<div class="nice-select" tabindex="0">
|
||||
<span class="current">موضوع</span>
|
||||
<ul class="list">
|
||||
<li data-value="موضوع" class="option selected">موضوع</li>
|
||||
<li data-value="موضوع 1" class="option">موضوع 1</li>
|
||||
<li data-value="موضوع 2" class="option">موضوع 2</li>
|
||||
<li data-value="موضوع 3" class="option">موضوع 3</li>
|
||||
<li data-value="موضوع 4" class="option">موضوع 4</li>
|
||||
<li data-value="موضوع 5" class="option">موضوع 5</li>
|
||||
</ul>
|
||||
</div>
|
||||
<InputText @bind-Value="model.Title" id="Title" type="text" class="inputText" required=""/>
|
||||
<span class="floating-label">عنوان</span>
|
||||
</div>
|
||||
</div>
|
||||
<div class="col-xxl-12">
|
||||
<div class="postbox__comment-input mb-30">
|
||||
<textarea class="textareaText" required=""></textarea>
|
||||
<InputText @bind-Value="model.Text" id="Text" class="textareaText" required=""></InputText>
|
||||
<span class="floating-label-2">پیام شما ...</span>
|
||||
</div>
|
||||
</div>
|
||||
<div class="col-xxl-12">
|
||||
<div class="postbox__btn-box">
|
||||
<button class="submit-btn w-100">ارسال پیام</button>
|
||||
<button type="submit" class="submit-btn w-100">ارسال پیام</button>
|
||||
</div>
|
||||
</div>
|
||||
</div>
|
||||
</form>
|
||||
</EditForm>
|
||||
</div>
|
||||
</div>
|
||||
</div>
|
||||
@@ -91,5 +79,46 @@
|
||||
</div>
|
||||
|
||||
@code {
|
||||
string type = "NewTicketNoAuthentication";
|
||||
private EditContext? editContext;
|
||||
[SupplyParameterFromForm]
|
||||
private CTicketNoAuthenticationDto? model { get; set; } = new CTicketNoAuthenticationDto();
|
||||
|
||||
private ValidationMessageStore? messageStore;
|
||||
|
||||
protected override void OnInitialized()
|
||||
{
|
||||
// modelTaxTools ??= new();
|
||||
// editContext = new(modelTaxTools);
|
||||
// editContext.OnValidationRequested += HandleValidationRequested;
|
||||
// messageStore = new(editContext);
|
||||
|
||||
editContext = new EditContext(model);
|
||||
messageStore = new(editContext);
|
||||
}
|
||||
}
|
||||
@functions{
|
||||
private async Task newTicket(){
|
||||
|
||||
// var request = await _hc.PostAsJsonAsync("Ticket/NewTicketNoAuthentication", model);
|
||||
// if (request.IsSuccessStatusCode)
|
||||
// {
|
||||
// messageStore?.Clear();
|
||||
// var res = await request.Content.ReadFromJsonAsync<VerificationCodeDto>();
|
||||
Verification pa = new Verification();
|
||||
pa.model = new VerificationCodeDto
|
||||
{
|
||||
prm =" Ticket.ID.ToString()",
|
||||
val = "item.Mobile",
|
||||
Type = "NewTicketNoAuthentication"
|
||||
};
|
||||
await Task.Run(()=>pa);
|
||||
// }
|
||||
// else
|
||||
// {
|
||||
// var error = await request.Content.ReadFromJsonAsync<List<string>>();
|
||||
// messageStore?.Add(() => model.Mobile, error);
|
||||
|
||||
// }
|
||||
}
|
||||
}
|
||||
|
@@ -1,5 +1,13 @@
|
||||
<h3>Verification</h3>
|
||||
@using Shared.DTOs
|
||||
@page "/Verification/{model}"
|
||||
<h3>Verification</h3>
|
||||
|
||||
@code {
|
||||
|
||||
[Parameter]
|
||||
public VerificationCodeDto? model { get; set; }
|
||||
protected override async Task OnParametersSetAsync()
|
||||
{
|
||||
var dfsf = model;
|
||||
await base.OnParametersSetAsync();
|
||||
}
|
||||
}
|
||||
|
Reference in New Issue
Block a user