예제 #1
0
        // حذف استف
        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);
        }
예제 #4
0
        //تغییر وضعیت پیام خوانده نشده به پیام خوانده شده
        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);
        }
예제 #5
0
        //فعال سازی یا غیر فعال سازی تیکت ها توسط این متد انجام میشود
        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);
        }
예제 #6
0
        // متد تغیر پسورد
        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);
        }
예제 #7
0
        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);
            }
        }