MireaBackend/Endpoint/Controllers/V1/ScheduleController.cs

203 lines
8.4 KiB
C#
Raw Normal View History

2024-09-18 06:00:07 +03:00
using Asp.Versioning;
using MediatR;
2024-02-19 11:20:49 +03:00
using Microsoft.AspNetCore.Http;
using Microsoft.AspNetCore.Mvc;
using Microsoft.Extensions.Options;
2024-02-19 11:20:49 +03:00
using Mirea.Api.DataAccess.Application.Cqrs.Schedule.Queries.GetScheduleList;
using Mirea.Api.Dto.Common;
2024-02-19 11:20:49 +03:00
using Mirea.Api.Dto.Requests;
using Mirea.Api.Dto.Responses;
using Mirea.Api.Endpoint.Common.Attributes;
using Mirea.Api.Endpoint.Common.Exceptions;
2024-11-02 00:59:37 +03:00
using Mirea.Api.Endpoint.Common.MapperDto;
2024-10-07 02:13:35 +03:00
using Mirea.Api.Endpoint.Configuration.Model;
using System;
2024-02-19 11:20:49 +03:00
using System.Collections.Generic;
using System.Linq;
using System.Threading.Tasks;
namespace Mirea.Api.Endpoint.Controllers.V1;
2024-05-28 07:09:40 +03:00
[ApiVersion("1.0")]
2024-08-12 21:54:05 +03:00
[CacheMaxAge(true)]
public class ScheduleController(IMediator mediator, IOptionsSnapshot<GeneralConfig> config) : BaseController
2024-02-19 11:20:49 +03:00
{
2024-10-25 04:43:18 +03:00
/// <summary>
/// Retrieves the start term for the schedule.
/// </summary>
/// <returns>The start term as a <see cref="DateOnly"/> value.</returns>
2024-08-12 21:54:05 +03:00
[CacheMaxAge(1, 0)]
[HttpGet("StartTerm")]
public ActionResult<DateOnly> GetStartTerm() => config.Value.ScheduleSettings!.StartTerm;
2024-10-25 04:43:18 +03:00
/// <summary>
/// Retrieves the pair periods.
/// </summary>
/// <returns>A dictionary of pair periods, where the key is an integer identifier and the value is a <see cref="PairPeriodTime"/> object.</returns>
2024-08-12 21:54:05 +03:00
[CacheMaxAge(1, 0)]
[HttpGet("PairPeriod")]
public ActionResult<Dictionary<int, PairPeriodTime>> GetPairPeriod() => config.Value.ScheduleSettings!.PairPeriod.ConvertToDto();
2024-02-19 11:20:49 +03:00
/// <summary>
/// Retrieves schedules based on various filters.
/// </summary>
/// <param name="request">The request object containing filter criteria.</param>
/// <returns>A list of schedules matching the filter criteria.</returns>
[HttpPost]
[ProducesResponseType(StatusCodes.Status204NoContent)]
[BadRequestResponse]
public async Task<ActionResult<List<ScheduleResponse>>> Get([FromBody] ScheduleRequest request)
{
2024-05-19 12:30:17 +03:00
if ((request.Groups == null || request.Groups.Length == 0) &&
(request.Disciplines == null || request.Disciplines.Length == 0) &&
(request.Professors == null || request.Professors.Length == 0) &&
(request.LectureHalls == null || request.LectureHalls.Length == 0))
2024-02-19 11:20:49 +03:00
{
throw new ControllerArgumentException("At least one of the arguments must be selected."
+ (request.IsEven.HasValue
? $" \"{nameof(request.IsEven)}\" is not a strong argument"
: string.Empty));
2024-02-19 11:20:49 +03:00
}
var result = (await mediator.Send(new GetScheduleListQuery
2024-02-19 11:20:49 +03:00
{
IsEven = request.IsEven,
DisciplineIds = request.Disciplines,
GroupIds = request.Groups,
LectureHallIds = request.LectureHalls,
ProfessorIds = request.Professors
})).Schedules.ToList();
2024-02-19 11:20:49 +03:00
2024-10-07 01:20:10 +03:00
if (result.Count == 0)
NoContent();
2024-02-19 11:20:49 +03:00
return Ok(result.Select(s => new ScheduleResponse
2024-02-19 11:20:49 +03:00
{
DayOfWeek = s.DayOfWeek,
PairNumber = s.PairNumber,
IsEven = s.IsEven,
Discipline = s.Discipline,
DisciplineId = s.DisciplineId,
2024-05-19 13:53:25 +03:00
IsExcludedWeeks = s.IsExcludedWeeks,
Weeks = s.Weeks,
2024-05-19 12:30:17 +03:00
TypeOfOccupations = s.TypeOfOccupations,
2024-02-19 11:20:49 +03:00
Group = s.Group,
GroupId = s.GroupId,
LectureHalls = s.LectureHalls,
LectureHallsId = s.LectureHallsId,
Professors = s.Professors,
ProfessorsId = s.ProfessorsId,
Campus = s.Campus,
CampusId = s.CampusId,
LinkToMeet = s.LinkToMeet
}));
}
/// <summary>
/// Retrieves schedules for a specific group based on various filters.
/// </summary>
/// <param name="id">The ID of the group.</param>
/// <param name="isEven">A value indicating whether to retrieve schedules for even weeks.</param>
/// <param name="disciplines">An array of discipline IDs.</param>
/// <param name="professors">An array of professor IDs.</param>
/// <param name="lectureHalls">An array of lecture hall IDs.</param>
/// <returns>A response containing schedules for the specified group.</returns>
2024-05-28 07:09:40 +03:00
[HttpGet("GetByGroup/{id:int}")]
2024-02-19 11:20:49 +03:00
[ProducesResponseType(StatusCodes.Status204NoContent)]
[BadRequestResponse]
[NotFoundResponse]
public async Task<ActionResult<List<ScheduleResponse>>> GetByGroup(int id,
2024-02-19 11:20:49 +03:00
[FromQuery] bool? isEven = null,
[FromQuery] int[]? disciplines = null,
[FromQuery] int[]? professors = null,
[FromQuery] int[]? lectureHalls = null) =>
await Get(new ScheduleRequest
2024-08-12 21:54:05 +03:00
{
Disciplines = disciplines,
2024-02-19 11:20:49 +03:00
IsEven = isEven,
Groups = [id],
Professors = professors,
LectureHalls = lectureHalls
2024-02-19 11:20:49 +03:00
});
/// <summary>
/// Retrieves schedules for a specific professor based on various filters.
/// </summary>
/// <param name="id">The ID of the professor.</param>
/// <param name="isEven">A value indicating whether to retrieve schedules for even weeks.</param>
/// <param name="disciplines">An array of discipline IDs.</param>
/// <param name="groups">An array of group IDs.</param>
/// <param name="lectureHalls">An array of lecture hall IDs.</param>
/// <returns>A response containing schedules for the specified professor.</returns>
2024-05-28 07:09:40 +03:00
[HttpGet("GetByProfessor/{id:int}")]
2024-02-19 11:20:49 +03:00
[ProducesResponseType(StatusCodes.Status204NoContent)]
[BadRequestResponse]
[NotFoundResponse]
public async Task<ActionResult<List<ScheduleResponse>>> GetByProfessor(int id,
2024-02-19 11:20:49 +03:00
[FromQuery] bool? isEven = null,
[FromQuery] int[]? disciplines = null,
[FromQuery] int[]? groups = null,
[FromQuery] int[]? lectureHalls = null) =>
await Get(new ScheduleRequest
2024-08-12 21:54:05 +03:00
{
Disciplines = disciplines,
2024-02-19 11:20:49 +03:00
IsEven = isEven,
Groups = groups,
Professors = [id],
LectureHalls = lectureHalls
2024-02-19 11:20:49 +03:00
});
/// <summary>
/// Retrieves schedules for a specific lecture hall based on various filters.
/// </summary>
/// <param name="id">The ID of the lecture hall.</param>
/// <param name="isEven">A value indicating whether to retrieve schedules for even weeks.</param>
/// <param name="disciplines">An array of discipline IDs.</param>
/// <param name="professors">An array of professor IDs.</param>
/// <param name="groups">An array of group IDs.</param>
/// <returns>A response containing schedules for the specified lecture hall.</returns>
2024-05-28 07:09:40 +03:00
[HttpGet("GetByLectureHall/{id:int}")]
2024-02-19 11:20:49 +03:00
[ProducesResponseType(StatusCodes.Status204NoContent)]
[BadRequestResponse]
[NotFoundResponse]
public async Task<ActionResult<List<ScheduleResponse>>> GetByLectureHall(int id,
2024-02-19 11:20:49 +03:00
[FromQuery] bool? isEven = null,
[FromQuery] int[]? disciplines = null,
[FromQuery] int[]? groups = null,
[FromQuery] int[]? professors = null) =>
await Get(new ScheduleRequest
2024-08-12 21:54:05 +03:00
{
Disciplines = disciplines,
2024-02-19 11:20:49 +03:00
IsEven = isEven,
Groups = groups,
Professors = professors,
LectureHalls = [id]
2024-02-19 11:20:49 +03:00
});
/// <summary>
/// Retrieves schedules for a specific discipline based on various filters.
/// </summary>
/// <param name="id">The ID of the discipline.</param>
/// <param name="isEven">A value indicating whether to retrieve schedules for even weeks.</param>
/// <param name="groups">An array of group IDs.</param>
/// <param name="professors">An array of professor IDs.</param>
/// <param name="lectureHalls">An array of lecture hall IDs.</param>
/// <returns>A response containing schedules for the specified discipline.</returns>
2024-05-28 07:09:40 +03:00
[HttpGet("GetByDiscipline/{id:int}")]
2024-02-19 11:20:49 +03:00
[ProducesResponseType(StatusCodes.Status204NoContent)]
[BadRequestResponse]
[NotFoundResponse]
public async Task<ActionResult<List<ScheduleResponse>>> GetByDiscipline(int id,
2024-02-19 11:20:49 +03:00
[FromQuery] bool? isEven = null,
[FromQuery] int[]? groups = null,
[FromQuery] int[]? professors = null,
[FromQuery] int[]? lectureHalls = null) =>
await Get(new ScheduleRequest
2024-08-12 21:54:05 +03:00
{
Disciplines = [id],
2024-02-19 11:20:49 +03:00
IsEven = isEven,
Groups = groups,
Professors = professors,
LectureHalls = lectureHalls
2024-02-19 11:20:49 +03:00
});
2024-08-12 21:54:05 +03:00
}