Vitalick Kovalenko a1019db433
All checks were successful
Create and publish a Docker image / Publish image (push) Successful in 1m23s
Create and publish a Docker image / Deploy image (push) Successful in 36s
фиксы
2023-12-23 17:39:46 +03:00

447 lines
11 KiB
C#

using System.IdentityModel.Tokens.Jwt;
using Mapster;
using Microsoft.AspNetCore.Authentication;
using Microsoft.AspNetCore.Authentication.Google;
using Microsoft.AspNetCore.Authentication.JwtBearer;
using Microsoft.AspNetCore.Identity;
using Microsoft.AspNetCore.Mvc;
using Microsoft.EntityFrameworkCore;
using Microsoft.IdentityModel.Tokens;
namespace CyberBoom.Controllers;
[ApiController]
[Route("/api/[controller]")]
public class UsersController : ControllerBase
{
private readonly ApplicationContext _applicationContext;
private readonly UserManager<User> _userManager;
public UsersController(ApplicationContext applicationContext, UserManager<User> userManager)
{
_applicationContext = applicationContext;
_userManager = userManager;
}
[HttpPost]
public async Task<IActionResult> Post([FromForm]UserPost user)
{
await user.Avatar.WriteFileToDirectory();
var userWr = new User {
AvatarUrl = user.Avatar.FileName,
Fio = user.Fio,
Specialities = user.Specialities,
TelegramBotUrl = user.TelegramBotUrl,
UserName = user.Username
};
var result = await _userManager.CreateAsync(userWr);
if(result.Succeeded)
return Ok(
new {
userWr.Id
}
);
return BadRequest(result.Errors);
}
// [HttpGet("google-auth")]
// public IActionResult Regiester()
// {
// var properties = new AuthenticationProperties{
// RedirectUri = Url.Action("GoogleResponse")
// };
// return Challenge(properties, GoogleDefaults.AuthenticationScheme);
// }
// [Route("google-response")]
// public async Task<IActionResult> GoogleResponse()
// {
// var result = await HttpContext.AuthenticateAsync(JwtBearerDefaults.AuthenticationScheme);
// var claims = result?.Principal?.Identities.First().Claims;
// var jwt = new JwtSecurityToken(
// issuer: AuthOptions.ISSUER,
// audience: AuthOptions.AUDIENCE,
// claims: claims,
// expires: DateTime.UtcNow.Add(TimeSpan.FromMinutes(2)),
// signingCredentials: new SigningCredentials(AuthOptions.GetSymmetricSecurityKey(), SecurityAlgorithms.HmacSha256));
// var strJwt = new JwtSecurityTokenHandler().WriteToken(jwt);
// return Ok(new {
// Token = strJwt
// });
// }
}
[ApiController]
[Route("/api/[controller]")]
public class MeetingsController : ControllerBase
{
private readonly ApplicationContext _applicationContext;
public MeetingsController(ApplicationContext applicationContext)
{
_applicationContext = applicationContext;
}
[HttpPost]
public async Task<IActionResult> Post([FromForm]PostMeetingDto meeting)
{
await meeting.SpeackerImage.WriteFilesToDirectory();
await meeting.PlaceImages.WriteFilesToDirectory();
var meetingWrite = meeting.Adapt<Meeting>();
meetingWrite.SpeackerImage = meeting.SpeackerImage.JoinFileNames();
meetingWrite.PlaceImages = meeting.PlaceImages.JoinFileNames();
await _applicationContext.Meetings.AddAsync(meetingWrite);
await _applicationContext.SaveChangesAsync();
return Ok(new {
meetingWrite.Id
});
}
[HttpPut]
public async Task<IActionResult> Put([FromForm]PutMeetingDto meeting)
{
await meeting.SpeackerImage.WriteFilesToDirectory();
await meeting.PlaceImages.WriteFilesToDirectory();
var meetingWrite = meeting.Adapt<Meeting>();
meetingWrite.SpeackerImage = meeting.SpeackerImage.JoinFileNames();
meetingWrite.PlaceImages = meeting.PlaceImages.JoinFileNames();
var findedMeeting = await _applicationContext.Meetings.FirstAsync(s => s.Id == meeting.Id);
findedMeeting = meetingWrite;
await _applicationContext.SaveChangesAsync();
return Ok();
}
[HttpGet]
public async Task<IActionResult> Get(string id)
{
var meeting = await _applicationContext.Meetings.FirstOrDefaultAsync(s => s.Id == id);
return Ok(meeting);
}
[HttpGet("list")]
public IActionResult GetList(int offset, int limit)
{
var meetings = _applicationContext.Meetings.Skip(offset).Take(limit);
return Ok(meetings);
}
}
[ApiController]
[Route("/api/[controller]")]
public class ReviewsController : ControllerBase
{
private readonly ApplicationContext _applicationContext;
public ReviewsController(ApplicationContext applicationContext)
{
_applicationContext = applicationContext;
}
[HttpPost]
public async Task<IActionResult> Post([FromBody] PostReviewDto review)
{
var dbWr = review.Adapt<Review>();
await _applicationContext.Reviews.AddAsync(dbWr);
await _applicationContext.SaveChangesAsync();
return Ok(new {
dbWr.Id
});
}
[HttpPut]
public async Task<IActionResult> Put([FromBody]PutReviewDto review)
{
var fReview = await _applicationContext.Reviews.FirstAsync(r => r.Id == review.Id);
fReview.Text = review.Text;
fReview.Score = review.Score;
fReview.Date = review.Date;
await _applicationContext.SaveChangesAsync();
return Ok();
}
[HttpGet]
public async Task<IActionResult> Get(string id)
{
var review = await _applicationContext.Reviews.FirstAsync(s => s.Id == id);
var user = await _applicationContext.Users.FirstAsync(s => s.Id == review.UserId);
return Ok(new {
review,
user
});
}
[HttpGet("list")]
public IActionResult GetList(int offset, int limit)
{
var reviews = _applicationContext.Reviews
.Include(c => c.User)
.Skip(offset)
.Take(limit);
// var userIds = reviews.Select(u => u.UserId).ToArray();
// var users = _applicationContext.Users.Where(u => userIds.Contains(u.Id));
return Ok(
reviews
);
}
}
[ApiController]
[Route("/api/[controller]")]
public class QuestionsController : ControllerBase
{
private readonly ApplicationContext _applicationContext;
public QuestionsController(ApplicationContext applicationContext)
{
_applicationContext = applicationContext;
}
[HttpPost]
public async Task<IActionResult> Post([FromBody] PostQuestionDto question)
{
var dbWr = question.Adapt<Question>();
await _applicationContext.Questions.AddAsync(dbWr);
await _applicationContext.SaveChangesAsync();
return Ok(new {
dbWr.Id
});
}
[HttpPut]
public async Task<IActionResult> Put([FromBody]PutQuestionDto question)
{
var fReview = await _applicationContext.Questions.FirstAsync(r => r.Id == question.Id);
fReview.Text = question.Text;
await _applicationContext.SaveChangesAsync();
return Ok();
}
[HttpGet]
public async Task<IActionResult> Get(string id)
{
var question = await _applicationContext.Questions
.FirstAsync(s => s.Id == id);
return Ok(question);
}
[HttpGet("list")]
public IActionResult GetList(int offset, int limit)
{
var questions = _applicationContext.Questions
.Include(c => c.User)
.Skip(offset)
.Take(limit);
return Ok(questions);
}
}
[ApiController]
[Route("/api/[controller]")]
public class ReactionsController : ControllerBase
{
private readonly ApplicationContext _applicationContext;
public ReactionsController(ApplicationContext applicationContext)
{
_applicationContext = applicationContext;
}
[HttpPost]
public async Task<IActionResult> Post([FromBody] PostReactionDto reaction)
{
var dbWr = reaction.Adapt<Reaction>();
await _applicationContext.Reactions.AddAsync(dbWr);
await _applicationContext.SaveChangesAsync();
return Ok(new {
dbWr.Id
});
}
[HttpDelete]
public async Task<IActionResult> Delete(string id)
{
var fReview = await _applicationContext.Reactions.FirstAsync(r => r.Id == id);
_applicationContext.Reactions.Remove(fReview);
await _applicationContext.SaveChangesAsync();
return Ok();
}
[HttpGet]
public async Task<IActionResult> Get(string id)
{
var review = await _applicationContext.Reviews
.FirstAsync(s => s.Id == id);
var user = await _applicationContext.Users.FirstAsync(s => s.Id == review.UserId);
return Ok(new {
review,
user
});
}
[HttpGet("list")]
public IActionResult GetList(int offset, int limit)
{
var reviews = _applicationContext.Reviews
.Skip(offset)
.Take(limit);
var users = _applicationContext.Users.Where(u => reviews.Select(u => u.UserId).Contains(u.Id));
return Ok(
reviews.Select(s => new {
review = s,
user = users.First(u => u.Id == s.UserId)
})
);
}
}
[ApiController]
[Route("/api/users/meetings")]
public class UserWriteToMetingController : ControllerBase
{
private readonly ApplicationContext _applicationContext;
public UserWriteToMetingController(ApplicationContext applicationContext)
{
_applicationContext = applicationContext;
}
[HttpPost]
public async Task<IActionResult> Post([FromBody] PostUserWriteToMetingDto write)
{
var dbWr = write.Adapt<UserWriteToMeting>();
await _applicationContext.UserWriteToMetings.AddAsync(dbWr);
await _applicationContext.SaveChangesAsync();
return Ok(new {
dbWr.Id
});
}
[HttpDelete]
public async Task<IActionResult> Delete(string id)
{
var fReview = await _applicationContext.UserWriteToMetings.FirstAsync(r => r.Id == id);
_applicationContext.UserWriteToMetings.Remove(fReview);
await _applicationContext.SaveChangesAsync();
return Ok();
}
[HttpGet]
public async Task<IActionResult> Get(string id)
{
var review = await _applicationContext.UserWriteToMetings
.FirstAsync(s => s.Id == id);
return Ok(review);
}
[HttpGet("list")]
public IActionResult GetList(int offset, int limit)
{
var reviews = _applicationContext.UserWriteToMetings
.Skip(offset)
.Take(limit);
return Ok(reviews);
}
}