// حذف استف public async Task <bool> DeleteStaff(string id) { var staff = await _context.People.SingleOrDefaultAsync(a => a.PersonNational_ID == id); // فالس کردن مقدار اکتیو استف staff.IsActive = false; _context.Entry(staff).State = EntityState.Modified; // ذخیره سازی دیتابیس await _context.SaveChangesAsync(); return(true); }
public async Task <IActionResult> PutServiceType(int id, ServiceType serviceType) { if (id != serviceType.ServiceType_ID) { return(BadRequest()); } _context.Entry(serviceType).State = EntityState.Modified; try { await _context.SaveChangesAsync(); } catch (DbUpdateConcurrencyException) { if (!ServiceTypeExists(id)) { return(NotFound()); } else { throw; } } return(NoContent()); }
/////ویرایش وثبت آیدی فردی که تیکت به آن ارجاع داده میشود////// public async Task <bool> PutResiverDeveloper(int id, DeveloperTicketigViewModel user) { DeveloperTicket a = await _context.DeveloperTickets.SingleOrDefaultAsync(r => r.DeveloperTicket_ID == id); if (user.Resiver == "" || user.Resiver == null) { Person s = await _context.People.SingleOrDefaultAsync(y => y.Role1 == 2 && y.Role2 == 1 && y.Role3 == 1 && y.Role4 == 1); a.Resiver = s.PersonNational_ID; } else { a.Resiver = user.Resiver; } _context.Entry(a).State = EntityState.Modified; await _context.SaveChangesAsync(); return(true); }
//تغییر وضعیت پیام خوانده نشده به پیام خوانده شده public async Task <bool> PutSeen(int id, string userId) { List <TicketingChat> a = await _context.TicketingChats.Where(b => b.Ticket_ID == id && b.Resiver == userId).ToListAsync(); foreach (var item in a) { item.Seen = true; _context.Entry(item).State = EntityState.Modified; await _context.SaveChangesAsync(); } return(true); }
//فعال سازی یا غیر فعال سازی تیکت ها توسط این متد انجام میشود public async Task <bool> PutDiactiveTcket(int id) { Ticket a = await _context.Tickets.FindAsync(id); if (a.Active == true) { a.Active = false; _context.Entry(a).State = EntityState.Modified; await _context.SaveChangesAsync(); return(true); } else { a.Active = true; } _context.Entry(a).State = EntityState.Modified; await _context.SaveChangesAsync(); return(true); }
// متد تغیر پسورد public async Task <bool> ChangePassword(string personNationalId, ChangePassword changePassword) { // پیدا کردن یوزر بر اساس ای دی var user = await _context.People.FindAsync(personNationalId); // هش کردن پسورد قبلی changePassword.OldPassword = PasswordHasher.ComputeSha256Hash($"{user.UserName}seemsys{changePassword.OldPassword}"); // چک کردن درست بودن پسورد if (user.Password == changePassword.OldPassword) { // فالس کردن مقدار الزامی بودن تغیر پسورد user.NeedChangePassword = false; // قرار دادن پسورد جدید در یوزر و ذخیره دیتابیس user.Password = PasswordHasher.ComputeSha256Hash($"{user.UserName}seemsys{changePassword.Password}"); _context.Entry(user).State = EntityState.Modified; await _context.SaveChangesAsync(); return(true); } return(false); }
public async Task <ActionResult <Person> > PostLandingPageStaff(LandingPageViewModel model) { //ایجاد یک شرط برای چک کردن اینکه اطلاعات کاربر داخل دیابیس وجود دارد یا خیر if (await _personService.IsExistNationalId(model.Id)) { //در صورت وجود اطلاعات فرد را به دست می اوریم Person a = await _context.People.SingleOrDefaultAsync(r => r.PersonNational_ID == model.Id); a.Email = model.Email; a.FirstName = model.Fname; a.LastName = model.Lname; a.PersonNational_ID = model.Id; //اطلاعات فرد درصورت بروز تغییرات ویرایش می شود _context.Entry(a).State = EntityState.Modified; await _context.SaveChangesAsync(); //ارسال توکن به مرورگر کاربر Person user = await _context.People.SingleOrDefaultAsync(r => r.PersonNational_ID == model.Id); var tokenHandler = new JwtSecurityTokenHandler(); var key = Encoding.ASCII.GetBytes(_appSettings.Secret); var tokenDescriptor = new SecurityTokenDescriptor { Subject = new ClaimsIdentity(new Claim[] { new Claim("seemsys", model.Id) }), Expires = DateTime.UtcNow.AddDays(7), SigningCredentials = new SigningCredentials(new SymmetricSecurityKey(key), SecurityAlgorithms.HmacSha256Signature) }; var token = tokenHandler.CreateToken(tokenDescriptor); user.Token = tokenHandler.WriteToken(token); user.Password = null; return(user); } else { //اگر اطلاعات فرد مورد نظر در دخل دیتابیس وجود نداشت عملیات درج اطلاعات در دیتابیس آغاز می شود Person person = new Person() { PersonNational_ID = model.Id, FirstName = model.Fname, LastName = model.Lname, Email = FixedText.FixedEmail(model.Email), FatherName = null, Gender = false, UserName = FixedText.FixedEmail(model.Email), ShenasNum = null, ShenasSerial = null, NationalCardSerial = null, CreateTime = DateTime.Now, LastEditTime = DateTime.Now, IsActive = true, NeedChangePassword = false, Password = PasswordHasher.ComputeSha256Hash($"{FixedText.FixedEmail(model.Email)}seemsys123456") }; if (model.type == "Customer") { person.Role1 = 3; } else if (model.type == "") { person.Role1 = 2; person.Role2 = 1; } else { person.Role1 = 2; person.Role2 = 2; } if (model.type == "Customer") { await _personService.AddPerson(person); } else { Staff staff = new Staff() { Address = null, EduDegree = null, EduField = null, PersonNational_ID = await _personService.AddPerson(person), PositionId = null, StaffNumber = model.Id, TeleNumber = null }; await _staffService.AddStaff(staff); } //ارسال توکن به مرورگر کاربر var tokenHandler = new JwtSecurityTokenHandler(); var key = Encoding.ASCII.GetBytes(_appSettings.Secret); var tokenDescriptor = new SecurityTokenDescriptor { Subject = new ClaimsIdentity(new Claim[] { new Claim("seemsys", model.Id) }), Expires = DateTime.UtcNow.AddDays(7), SigningCredentials = new SigningCredentials(new SymmetricSecurityKey(key), SecurityAlgorithms.HmacSha256Signature) }; var token = tokenHandler.CreateToken(tokenDescriptor); person.Token = tokenHandler.WriteToken(token); person.Password = null; return(person); } }