Beispiel #1
0
        private async void btnSacuvaj_Click(object sender, EventArgs e)
        {
            if (ValidateChildren())
            {
                var entity1 = await _korisnici.GetById <OnlineGym_Model.Korisnik>(_id);

                var roleList = clbRole.CheckedItems.Cast <OnlineGym_Model.Uloga>().Select(x => x.UlogaId).ToList();
                var request  = new KorisniciInsertRequest
                {
                    Fotografija     = entity1.Fotografija,
                    FotografijaThum = entity1.FotografijaThum,
                    Email           = txtEmail.Text,
                    Ime             = txtIme.Text,
                    KorisnickoIme   = txtKorisnickoIme.Text,
                    Prezime         = txtPrezime.Text,
                    Telefon         = txtTelefon.Text,
                    Uloge           = roleList
                };
                OnlineGym_Model.Korisnik entity = null;
                entity = await _korisnici.Update <OnlineGym_Model.Korisnik>(_id.Value, request);

                if (entity != null)
                {
                    MessageBox.Show("Uspješno izvršeno");
                    this.Close();
                }
            }
        }
Beispiel #2
0
        protected override async Task <AuthenticateResult> HandleAuthenticateAsync()
        {
            if (!Request.Headers.ContainsKey("Authorization"))
            {
                return(AuthenticateResult.Fail("Missing Authorization Header"));
            }

            OnlineGym_Model.Korisnik user = null;
            OnlineGym_Model.Clan     clan = null;
            var context = "";

            try
            {
                context = Request.Headers["Context"];
                var authHeader      = AuthenticationHeaderValue.Parse(Request.Headers["Authorization"]);
                var credentialBytes = Convert.FromBase64String(authHeader.Parameter);
                var credentials     = Encoding.UTF8.GetString(credentialBytes).Split(':');
                var username        = credentials[0];
                var password        = credentials[1];
                if ("Clan".Equals(context))
                {
                    clan = _clanService.Authenticiraj(username, password);
                }
                else
                {
                    user = _userService.Authenticiraj(username, password);
                }
            }
            catch (Exception e)
            {
                return(AuthenticateResult.Fail("Invalid Authorization Header"));
            }
            var claims = new List <Claim>();

            if ("Clan".Equals(context))
            {
                if (clan == null)
                {
                    return(AuthenticateResult.Fail("Invalid Username or Password"));
                }
            }
            else
            {
                if (user == null)
                {
                    return(AuthenticateResult.Fail("Invalid Username or Password"));
                }

                claims = new List <Claim> {
                    new Claim(ClaimTypes.NameIdentifier, user.KorisnickoIme),
                    new Claim(ClaimTypes.Name, user.Ime),
                };

                foreach (var role in user.KorisniciUloge)
                {
                    claims.Add(new Claim(ClaimTypes.Role, role.Uloga.Naziv));
                }
            }

            var identity  = new ClaimsIdentity(claims, Scheme.Name);
            var principal = new ClaimsPrincipal(identity);
            var ticket    = new AuthenticationTicket(principal, Scheme.Name);

            return(AuthenticateResult.Success(ticket));
        }