Exemplo n.º 1
0
        public IActionResult Goruntule(int id)
        {
            //Tek bir günlüğü görüntüler.
            Gunluk gunluk = db.Gunlukler.Find(id);

            return(View(gunluk));
        }
Exemplo n.º 2
0
        public IActionResult Reddet(int id)
        {
            Gunluk gunluk = db.Gunlukler.Find(id);

            gunluk.OnayDurumu = 0;
            db.SaveChanges();

            return(PartialView("_GunlukDurumu", gunluk));
        }
Exemplo n.º 3
0
        public override void OnActionExecuting(ActionExecutingContext context)
        {
            var id       = (int)context.HttpContext.Session.GetInt32("id");
            var yetki    = context.HttpContext.Session.GetInt32("yetki");
            var profilid = context.HttpContext.Session.GetInt32("profilid");
            var kadi     = context.HttpContext.Session.GetString("kadi");

            int gunlukid = (int)context.ActionArguments["id"];

            if (yetki == 4)
            {
                Stajyer stajyer = db.Stajyerler.Where(x => x.ID == id).Include(x => x.Profil).Include(x => x.Gunlukler).FirstOrDefault();
                if (!stajyer.Gunlukler.Any(x => x.ID == gunlukid))
                {
                    context.Result = new RedirectResult("~/Gunluk/Listele/" + id);
                }
            }
            if (yetki == 3)
            {
                //Birim koordinatörünün sadece kendi biriminden olan stajyerlerin günlüklerini görüntülemeye hakkı vardır.

                BirimKoordinatoru koordinator = db.BirimKoordinatorleri.Where(x => x.ID == id).Include(x => x.Profil).Include(x => x.Birimler).FirstOrDefault();
                Gunluk            gunluk      = db.Gunlukler.Find(gunlukid);
                Stajyer           stajyer     = db.Stajyerler.Where(x => x.ID == gunluk.OgrenciID).Include(x => x.Profil).Include(x => x.Birimler).FirstOrDefault();

                foreach (var birim in koordinator.Birimler)
                {
                    if (stajyer.Birimler.Any(x => x.BirimID == birim.BirimID))
                    {
                        return;
                    }
                }
                context.Result = new RedirectResult("~/Error/AuthProblem");
            }
            if (yetki == 2 || yetki == 1)
            {
                //Burada bir şey yapmamıza gerek yok Moderatör ve sistem yöneticisi bütün günlükleri görüntüleyebilir.
            }
            base.OnActionExecuting(context);
        }