| 
									
										
										
										
											2024-04-17 15:49:34 +03:30
										 |  |  |  | using Back.Common; | 
					
						
							| 
									
										
										
										
											2024-06-30 19:57:32 +03:30
										 |  |  |  | using Back.Data.Contracts; | 
					
						
							| 
									
										
										
										
											2024-04-17 15:49:34 +03:30
										 |  |  |  | using Back.Data.Models; | 
					
						
							|  |  |  |  | using Back.Services; | 
					
						
							| 
									
										
										
										
											2024-04-05 01:05:32 +03:30
										 |  |  |  | using Back.Validations; | 
					
						
							| 
									
										
										
										
											2024-04-17 15:49:34 +03:30
										 |  |  |  | using FluentValidation; | 
					
						
							|  |  |  |  | using Microsoft.AspNetCore.Authorization; | 
					
						
							| 
									
										
										
										
											2024-03-30 15:10:36 +03:30
										 |  |  |  | using Microsoft.AspNetCore.Http; | 
					
						
							|  |  |  |  | using Microsoft.AspNetCore.Mvc; | 
					
						
							|  |  |  |  | using Shared.DTOs; | 
					
						
							| 
									
										
										
										
											2024-04-29 07:58:41 +03:30
										 |  |  |  | using static Microsoft.EntityFrameworkCore.DbLoggerCategory.Database; | 
					
						
							| 
									
										
										
										
											2024-03-30 15:10:36 +03:30
										 |  |  |  | 
 | 
					
						
							|  |  |  |  | namespace Back.Controllers | 
					
						
							|  |  |  |  | { | 
					
						
							|  |  |  |  |     [Route("api/[controller]")]
 | 
					
						
							|  |  |  |  |     [ApiController] | 
					
						
							|  |  |  |  |     public class BaseController : ControllerBase | 
					
						
							|  |  |  |  |     { | 
					
						
							|  |  |  |  |         private readonly ServBase _sBase; | 
					
						
							| 
									
										
										
										
											2024-04-05 01:05:32 +03:30
										 |  |  |  |         private readonly MobileValidation _mobilevalidation; | 
					
						
							| 
									
										
										
										
											2024-04-17 15:49:34 +03:30
										 |  |  |  |         private readonly servCompany _servCompany; | 
					
						
							|  |  |  |  |         private readonly servUser _servUser; | 
					
						
							|  |  |  |  |         private readonly servPermission _servPermission; | 
					
						
							|  |  |  |  |         private readonly ServValidatinMsg _servValidatinMsg; | 
					
						
							|  |  |  |  |         private readonly servSendMsg _servSendMsg; | 
					
						
							|  |  |  |  |         private readonly CompanyRegistrationValidation _companyRegistrationValidation; | 
					
						
							| 
									
										
										
										
											2024-06-30 19:57:32 +03:30
										 |  |  |  |         private readonly IAsyncRepository<Ulr> _ulrRepo; | 
					
						
							| 
									
										
										
										
											2024-04-17 15:49:34 +03:30
										 |  |  |  |         public BaseController(ServBase sBase, MobileValidation mobilevalidation | 
					
						
							|  |  |  |  |                             , servCompany servCompany, servUser servUser | 
					
						
							|  |  |  |  |                             , servPermission servPermission, ServValidatinMsg servValidatinMsg | 
					
						
							| 
									
										
										
										
											2024-06-30 19:57:32 +03:30
										 |  |  |  |                             , servSendMsg servSendMsg, CompanyRegistrationValidation companyRegistrationValidation | 
					
						
							|  |  |  |  |                             , IAsyncRepository<Ulr> ulrRepo) | 
					
						
							| 
									
										
										
										
											2024-03-30 15:10:36 +03:30
										 |  |  |  |         { | 
					
						
							| 
									
										
										
										
											2024-06-30 19:57:32 +03:30
										 |  |  |  |             _ulrRepo = ulrRepo; | 
					
						
							| 
									
										
										
										
											2024-03-30 15:10:36 +03:30
										 |  |  |  |             _sBase = sBase; | 
					
						
							| 
									
										
										
										
											2024-04-05 01:05:32 +03:30
										 |  |  |  |             _mobilevalidation = mobilevalidation; | 
					
						
							| 
									
										
										
										
											2024-04-17 15:49:34 +03:30
										 |  |  |  |             _servCompany = servCompany; | 
					
						
							|  |  |  |  |             _servUser = servUser; | 
					
						
							|  |  |  |  |             _servPermission = servPermission; | 
					
						
							|  |  |  |  |             _servValidatinMsg = servValidatinMsg; | 
					
						
							|  |  |  |  |             _servSendMsg = servSendMsg; | 
					
						
							|  |  |  |  |             _companyRegistrationValidation = companyRegistrationValidation; | 
					
						
							| 
									
										
										
										
											2024-03-30 15:10:36 +03:30
										 |  |  |  |         } | 
					
						
							| 
									
										
										
										
											2024-03-31 01:33:17 +03:30
										 |  |  |  |         [HttpGet("Pricing")] | 
					
						
							|  |  |  |  |         public async Task<ActionResult<List<BasePriceDto>>> Pricing() | 
					
						
							| 
									
										
										
										
											2024-03-30 15:10:36 +03:30
										 |  |  |  |         => Ok(await _sBase.GetBasePrice()); | 
					
						
							| 
									
										
										
										
											2024-03-31 01:33:17 +03:30
										 |  |  |  |         [HttpGet("DateTimeServer")] | 
					
						
							|  |  |  |  |         public async Task<ActionResult<DateTime>> DateTimeServer() | 
					
						
							|  |  |  |  |        => Ok(DateTime.Now); | 
					
						
							| 
									
										
										
										
											2024-04-02 17:14:18 +03:30
										 |  |  |  |         [HttpGet("LastBlog")] | 
					
						
							| 
									
										
										
										
											2024-09-18 23:52:48 +03:30
										 |  |  |  |         public async Task<ActionResult<PagingDto<BlogDto>>> LastBlog(int PageIndex, int PageSize,string? Tag, string? ItemSearch) | 
					
						
							|  |  |  |  |      => Ok(await _sBase.GetBlog(PageIndex, PageSize,Tag, ItemSearch)); | 
					
						
							| 
									
										
										
										
											2024-04-03 14:36:33 +03:30
										 |  |  |  |         [HttpGet("GetBlogByID/{ID}")] | 
					
						
							|  |  |  |  |         public async Task<ActionResult<BlogDtoFull?>> GetBlogByID(int ID) | 
					
						
							|  |  |  |  |         { | 
					
						
							|  |  |  |  |             var result = await _sBase.GetBlogByID(ID); | 
					
						
							|  |  |  |  |             if (result == null) | 
					
						
							| 
									
										
										
										
											2024-04-17 15:49:34 +03:30
										 |  |  |  |                 return NotFound(); | 
					
						
							| 
									
										
										
										
											2024-04-03 14:36:33 +03:30
										 |  |  |  |             return Ok(result); | 
					
						
							|  |  |  |  |         } | 
					
						
							| 
									
										
										
										
											2024-04-03 17:07:18 +03:30
										 |  |  |  |         [HttpGet("LastQuestion")] | 
					
						
							|  |  |  |  |         public async Task<ActionResult<PagingDto<QuestionDto>>> LastQuestion(int PageIndex, int PageSize) | 
					
						
							|  |  |  |  |             => Ok(await _sBase.GetQuestion(PageIndex, PageSize)); | 
					
						
							| 
									
										
										
										
											2024-04-05 01:05:32 +03:30
										 |  |  |  |         [HttpPost("CreateCsrAndPrivateKey")] | 
					
						
							|  |  |  |  |         public async Task<ActionResult<TaxToolsDTO>> CreateCsrAndPrivateKey(CsrPrivateKeyDto model) | 
					
						
							|  |  |  |  |         { | 
					
						
							| 
									
										
										
										
											2024-04-29 18:15:46 +03:30
										 |  |  |  |             var resultValidationmodel = await _mobilevalidation.ValidateAsync(Tuple.Create(model.Mobile, ActionMobileValidation.No)); | 
					
						
							| 
									
										
										
										
											2024-04-05 01:05:32 +03:30
										 |  |  |  |             if (!resultValidationmodel.IsValid) | 
					
						
							| 
									
										
										
										
											2024-04-17 15:49:34 +03:30
										 |  |  |  |                 return BadRequest(resultValidationmodel.Errors.Select(s => s.ErrorMessage).ToList()); | 
					
						
							| 
									
										
										
										
											2024-04-05 01:05:32 +03:30
										 |  |  |  |             return Ok(await _sBase.CreateCsrAndPrivateKey(model)); | 
					
						
							|  |  |  |  |         } | 
					
						
							|  |  |  |  |         [HttpPost("ReadPublicKeyFromCER")] | 
					
						
							|  |  |  |  |         public async Task<ActionResult<PublicKeyDTO>> ReadPublicKeyFromCER(string modelfromBase64) | 
					
						
							| 
									
										
										
										
											2024-04-05 21:03:40 +03:30
										 |  |  |  |         { | 
					
						
							|  |  |  |  |             var result = await _sBase.ReadPublicKeyFromCER(modelfromBase64); | 
					
						
							| 
									
										
										
										
											2024-04-17 15:49:34 +03:30
										 |  |  |  |             if (result.type == "error") | 
					
						
							| 
									
										
										
										
											2024-04-05 21:03:40 +03:30
										 |  |  |  |                 return BadRequest(); | 
					
						
							| 
									
										
										
										
											2024-04-17 15:49:34 +03:30
										 |  |  |  | 
 | 
					
						
							|  |  |  |  |             return Ok(result); | 
					
						
							| 
									
										
										
										
											2024-04-05 21:03:40 +03:30
										 |  |  |  |         } | 
					
						
							| 
									
										
										
										
											2024-04-17 15:49:34 +03:30
										 |  |  |  |         [HttpPost("CompanyRegistration")] | 
					
						
							|  |  |  |  |         [AllowAnonymous] | 
					
						
							|  |  |  |  |         public async Task<ActionResult<string>> CompanyRegistration([FromBody] CompanyRegistrationDTO item) | 
					
						
							|  |  |  |  |         { | 
					
						
							|  |  |  |  | 
 | 
					
						
							|  |  |  |  |             var resultValidationmodel = await _companyRegistrationValidation.ValidateAsync(item); | 
					
						
							|  |  |  |  |             if (!resultValidationmodel.IsValid) | 
					
						
							|  |  |  |  |                 return BadRequest(resultValidationmodel.Errors.Select(s => s.ErrorMessage).ToList()); | 
					
						
							|  |  |  |  | 
 | 
					
						
							|  |  |  |  | 
 | 
					
						
							|  |  |  |  |             try | 
					
						
							|  |  |  |  |             { | 
					
						
							|  |  |  |  |                 var user = new User() | 
					
						
							|  |  |  |  |                 { | 
					
						
							|  |  |  |  |                     Fullname = item.FullnameUser, | 
					
						
							|  |  |  |  |                     Mobile = item.Mobile, | 
					
						
							|  |  |  |  |                     Username = item.Username, | 
					
						
							|  |  |  |  |                     Password = item.Mobile.encrypted(), | 
					
						
							|  |  |  |  |                     IsActive = false | 
					
						
							|  |  |  |  | 
 | 
					
						
							|  |  |  |  |                 }; | 
					
						
							|  |  |  |  |                 user = await _servUser.AddUser(user); | 
					
						
							|  |  |  |  | 
 | 
					
						
							|  |  |  |  |                 var company =await  _servCompany.GetCompanyOrgByMobileAndCompanynotActive(item.Mobile); | 
					
						
							|  |  |  |  |                 if (company==null) | 
					
						
							|  |  |  |  |                 { | 
					
						
							|  |  |  |  |                     company = new Company() | 
					
						
							|  |  |  |  |                     { | 
					
						
							|  |  |  |  |                         Name = item.CompanyName, | 
					
						
							|  |  |  |  |                         Mobile = item.Mobile, | 
					
						
							|  |  |  |  |                         RegisterDate = DateTime.Now.ConvertMiladiToShamsi(), | 
					
						
							|  |  |  |  |                         IsActive = false | 
					
						
							|  |  |  |  | 
 | 
					
						
							|  |  |  |  |                     }; | 
					
						
							|  |  |  |  |                      | 
					
						
							|  |  |  |  |                 } | 
					
						
							|  |  |  |  |                 else | 
					
						
							|  |  |  |  |                 { | 
					
						
							|  |  |  |  |                     company.Name = item.CompanyName; | 
					
						
							|  |  |  |  |                     company.RegisterDate = DateTime.Now.ConvertMiladiToShamsi(); | 
					
						
							|  |  |  |  |                     company.IsActive = false; | 
					
						
							|  |  |  |  |                 } | 
					
						
							|  |  |  |  | 
 | 
					
						
							|  |  |  |  |                 company = await _servCompany.AddORUpdateCompany(company); | 
					
						
							|  |  |  |  | 
 | 
					
						
							|  |  |  |  |                 var allper = await _servPermission.GetPermissions(); | 
					
						
							|  |  |  |  | 
 | 
					
						
							|  |  |  |  |                 var roluser = new RolUser() | 
					
						
							|  |  |  |  |                 { | 
					
						
							|  |  |  |  |                     CompanyID = company.ID, | 
					
						
							|  |  |  |  |                     UserID = user.ID, | 
					
						
							|  |  |  |  |                     IsAdmin = true | 
					
						
							|  |  |  |  |                 }; | 
					
						
							|  |  |  |  |                 roluser = await _servPermission.AddRolUser(roluser); | 
					
						
							|  |  |  |  | 
 | 
					
						
							|  |  |  |  |                 await _servPermission.AddRangePermissionPeriodByCompany(new List<PermissionPeriod>() | 
					
						
							|  |  |  |  |             { | 
					
						
							|  |  |  |  |                 new PermissionPeriod(){CompanyID=company.ID,PermissionID=2,CalculationTypeID=2,RemainingAmount=0,TotalAmount=0}, | 
					
						
							|  |  |  |  |                 new PermissionPeriod(){CompanyID=company.ID,PermissionID=3,CalculationTypeID=1,RemainingAmount=5,TotalAmount=5}, | 
					
						
							|  |  |  |  |                 new PermissionPeriod(){CompanyID=company.ID,PermissionID=4,CalculationTypeID=1,RemainingAmount=5,TotalAmount=5}, | 
					
						
							|  |  |  |  |                 new PermissionPeriod(){CompanyID=company.ID,PermissionID=5,CalculationTypeID=1,RemainingAmount=5,TotalAmount=5}, | 
					
						
							|  |  |  |  |                 new PermissionPeriod(){CompanyID=company.ID,PermissionID=16,CalculationTypeID=1,RemainingAmount=5,TotalAmount=5}, | 
					
						
							|  |  |  |  |                 new PermissionPeriod(){CompanyID=company.ID,PermissionID=6,CalculationTypeID=2,RemainingAmount=0,TotalAmount=0} | 
					
						
							|  |  |  |  | 
 | 
					
						
							|  |  |  |  |             }); | 
					
						
							|  |  |  |  | 
 | 
					
						
							|  |  |  |  |                 await _servPermission.AddPermissionUser(roluser.ID, allper.Select(s => s.ID).ToArray()); | 
					
						
							|  |  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2024-06-24 11:48:53 +03:30
										 |  |  |  |                 var modelvc = await _servValidatinMsg.GenerateCode(new VerificationCode | 
					
						
							| 
									
										
										
										
											2024-04-17 15:49:34 +03:30
										 |  |  |  |                 { | 
					
						
							|  |  |  |  |                     prm = company.ID.ToString(), | 
					
						
							|  |  |  |  |                     val = user.ID.ToString(), | 
					
						
							|  |  |  |  |                     Type = "CompanyRegistration" | 
					
						
							|  |  |  |  |                 }); | 
					
						
							|  |  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2024-06-24 11:48:53 +03:30
										 |  |  |  |                 _servSendMsg.toContinue(modelvc.Code.ToString(), company.Mobile, "ثبت نام"); | 
					
						
							|  |  |  |  |                 return Ok(modelvc.ID); | 
					
						
							| 
									
										
										
										
											2024-04-17 15:49:34 +03:30
										 |  |  |  |             } | 
					
						
							|  |  |  |  |             catch (Exception ex) | 
					
						
							|  |  |  |  |             { | 
					
						
							|  |  |  |  |                 //SysLog log = new SysLog() | 
					
						
							|  |  |  |  |                 //{ | 
					
						
							|  |  |  |  |                 //    TraceIdentifierID = HttpContext.TraceIdentifier, | 
					
						
							|  |  |  |  |                 //    Datetime = DateTime.Now.ConvertMiladiToShamsi(), | 
					
						
							|  |  |  |  |                 //    Method = HttpContext.Request.Method, | 
					
						
							|  |  |  |  |                 //    Value = ex.Message, | 
					
						
							|  |  |  |  |                 //    Route = HttpContext.Request.Path, | 
					
						
							|  |  |  |  |                 //    Type = "catch" | 
					
						
							|  |  |  |  |                 //}; | 
					
						
							|  |  |  |  |                 //_contextMongodb.InsertItem(log); | 
					
						
							| 
									
										
										
										
											2024-04-29 18:15:46 +03:30
										 |  |  |  |                 return BadRequest(new List<string> { "خطای سیستمی رخ داده" }); | 
					
						
							| 
									
										
										
										
											2024-04-17 15:49:34 +03:30
										 |  |  |  |             } | 
					
						
							|  |  |  |  | 
 | 
					
						
							|  |  |  |  |         } | 
					
						
							| 
									
										
										
										
											2024-04-29 07:58:41 +03:30
										 |  |  |  |         [HttpPost("ForgetPassWord")] | 
					
						
							|  |  |  |  |         [AllowAnonymous] | 
					
						
							|  |  |  |  |         public async Task<ActionResult<string>> ForgetPassWord(ForgetPasswordItem Item)  | 
					
						
							|  |  |  |  |         { | 
					
						
							| 
									
										
										
										
											2024-04-29 18:15:46 +03:30
										 |  |  |  |             var resultValidationmodel = await _mobilevalidation.ValidateAsync(Tuple.Create(Item.Username, ActionMobileValidation.ExistMobile)); | 
					
						
							| 
									
										
										
										
											2024-04-29 07:58:41 +03:30
										 |  |  |  |             if (!resultValidationmodel.IsValid) | 
					
						
							|  |  |  |  |                 return BadRequest(resultValidationmodel.Errors.Select(s => s.ErrorMessage).ToList()); | 
					
						
							| 
									
										
										
										
											2024-04-17 15:49:34 +03:30
										 |  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2024-06-24 11:48:53 +03:30
										 |  |  |  |             var modelvc = await _servValidatinMsg.GenerateCode(new VerificationCode | 
					
						
							| 
									
										
										
										
											2024-04-29 07:58:41 +03:30
										 |  |  |  |             { | 
					
						
							|  |  |  |  |                 prm = Item.Username, | 
					
						
							|  |  |  |  |                 val = Item.PassWord, | 
					
						
							|  |  |  |  |                 Type = "ForgetPassword" | 
					
						
							|  |  |  |  |             }); | 
					
						
							|  |  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2024-06-24 11:48:53 +03:30
										 |  |  |  |             _servSendMsg.toContinue(modelvc.Code.ToString(),Item.Username, "فراموشی کلمه عبور"); | 
					
						
							|  |  |  |  |             return Ok(modelvc.ID); | 
					
						
							| 
									
										
										
										
											2024-04-29 07:58:41 +03:30
										 |  |  |  |         } | 
					
						
							| 
									
										
										
										
											2024-06-30 19:57:32 +03:30
										 |  |  |  |         [HttpPost("Ulr")] | 
					
						
							|  |  |  |  |         [AllowAnonymous] | 
					
						
							|  |  |  |  |         public async Task<ActionResult> Ulr(UlrDto Item) | 
					
						
							|  |  |  |  |         { | 
					
						
							|  |  |  |  |             if (Item.Type=="Panel" || Item.Type == "Main") | 
					
						
							|  |  |  |  |             { | 
					
						
							|  |  |  |  |                await _ulrRepo.AddBoolResultAsync(new Data.Models.Ulr | 
					
						
							|  |  |  |  |                 { | 
					
						
							|  |  |  |  |                     Type = Item.Type, | 
					
						
							|  |  |  |  |                     Date=DateTime.Now.ConvertMiladiToShamsi(), | 
					
						
							|  |  |  |  |                     Time=DateTime.Now.Hour.ToString("00")+ DateTime.Now.Minute.ToString("00"), | 
					
						
							|  |  |  |  |                     Ip= HttpContext.Connection.RemoteIpAddress?.ToString() | 
					
						
							|  |  |  |  |                 }); | 
					
						
							|  |  |  |  |             } | 
					
						
							|  |  |  |  |             return Ok(); | 
					
						
							|  |  |  |  |         } | 
					
						
							| 
									
										
										
										
											2024-03-30 15:10:36 +03:30
										 |  |  |  |     } | 
					
						
							|  |  |  |  | } |