Esempio n. 1
0
        //[AllowAnonymous]
        public async Task <int> CreateResume([FromBody] ResumeRequest request)
        {
            //判断request里是否满足前置条件
            if (!ModelState.IsValid)
            {
                return(-5);
            }
            //取得存在cookie的当前账户id
            var resume_stu_id = Int32.Parse(User.Identity.Name);
            //生成resume实例
            var temp_resume = _mapper.Map <ResumeEntity>(request);
            //查找当前id是否存在resume
            var temp = await ResumeAccessor.Find(resume_stu_id);

            if (temp == null)
            {
                //新建resume
                var num = ResumeAccessor.Create(temp_resume);
                return(resume_stu_id);
            }
            return(0);
        }
Esempio n. 2
0
        public async Task <ActionResult <AccountResponse> > PostRegister([FromBody] RegisterRequest request)
        {
            if (!ModelState.IsValid)
            {
                return(BadRequest());
            }

            var account = _mapper.Map <AccountEntity>(request);

            account.Password = BCrypt.Net.BCrypt.HashPassword(Sha512Hmac.HashPassword(request.Password), 10);
            account.Id       = await AccountAccessor.Create(account);

            await UserAccessor.Create(account); // Create user at the same time

            if (request.Role == Constants.Role.Student)
            {
                var resume = new ResumeEntity();
                resume.student_id = account.Id;
                await ResumeAccessor.Create(resume);
            }

            await AnnounceAccessor.SetNewSend(account.Id);//create user's announce

            // issue cookie
            var claims = new Claim[]
            {
                new Claim(ClaimTypes.Name, account.Id.ToString()),
                new Claim(ClaimTypes.Role, account.Role.ToString()),
            };

            var claimsIdentity = new ClaimsIdentity(claims, CookieAuthenticationDefaults.AuthenticationScheme);

            await HttpContext.SignInAsync(CookieAuthenticationDefaults.AuthenticationScheme, new ClaimsPrincipal(claimsIdentity), authProperties);

            return(Ok(_mapper.Map <AccountResponse>(account)));
        }
Esempio n. 3
0
        public async Task <ActionResult <ResumeResponse> > CreateResume([FromBody] ResumeRequest request)
        {
            //判断request里是否满足前置条件
            if (!ModelState.IsValid)
            {
                return(BadRequest());
            }
            //取得存在cookie的当前账户id
            var resume_stu_id = Int32.Parse(User.Identity.Name);
            //生成resume实例
            var temp_resume = _mapper.Map <ResumeEntity>(request);
            //查找当前id是否存在resume
            var temp = await ResumeAccessor.Find(resume_stu_id);

            temp_resume.student_id = resume_stu_id;
            if (temp == null)
            {
                //新建resume
                var num = ResumeAccessor.Create(temp_resume);
                temp_resume.resume_id = num.Result;
                return(Ok(_mapper.Map <ResumeResponse>(temp_resume)));
            }
            return(Ok(-1));
        }