2024-07-04 11:02:45 +05:00
|
|
|
|
using AsbCloudApp.Data;
|
2023-02-15 17:57:32 +05:00
|
|
|
|
using AsbCloudApp.Requests;
|
2021-10-20 12:52:31 +05:00
|
|
|
|
using System;
|
2021-04-02 17:28:07 +05:00
|
|
|
|
using System.Collections.Generic;
|
2021-08-11 16:54:42 +05:00
|
|
|
|
using System.Threading;
|
2021-08-11 12:11:21 +05:00
|
|
|
|
using System.Threading.Tasks;
|
2021-04-02 17:28:07 +05:00
|
|
|
|
|
2024-08-19 10:01:07 +05:00
|
|
|
|
namespace AsbCloudApp.Services;
|
|
|
|
|
|
|
|
|
|
/// <summary>
|
|
|
|
|
/// сервис скважин
|
|
|
|
|
/// </summary>
|
|
|
|
|
public interface IWellService : ICrudRepository<WellDto>
|
2021-04-02 17:28:07 +05:00
|
|
|
|
{
|
2022-08-09 11:10:01 +05:00
|
|
|
|
/// <summary>
|
2024-08-19 10:01:07 +05:00
|
|
|
|
/// сервис телеметрии
|
2022-08-09 11:10:01 +05:00
|
|
|
|
/// </summary>
|
2024-08-19 10:01:07 +05:00
|
|
|
|
ITelemetryService TelemetryService { get; }
|
2021-12-30 17:05:44 +05:00
|
|
|
|
|
2024-08-19 10:01:07 +05:00
|
|
|
|
/// <summary>
|
|
|
|
|
/// Список скважин доступных компании
|
|
|
|
|
/// </summary>
|
|
|
|
|
/// <param name="request"></param>
|
|
|
|
|
/// <param name="token"></param>
|
|
|
|
|
/// <returns></returns>
|
|
|
|
|
Task<IEnumerable<WellDto>> GetAsync(WellRequest request, CancellationToken token);
|
2022-08-09 11:10:01 +05:00
|
|
|
|
|
2024-08-19 10:01:07 +05:00
|
|
|
|
/// <summary>
|
|
|
|
|
/// Статистика по скважине
|
|
|
|
|
/// </summary>
|
|
|
|
|
/// <param name="idWell"></param>
|
|
|
|
|
/// <param name="token"></param>
|
|
|
|
|
/// <returns></returns>
|
|
|
|
|
Task<WellMapInfoWithTelemetryStat?> GetOrDefaultStatAsync(int idWell, CancellationToken token);
|
2023-07-05 16:00:06 +05:00
|
|
|
|
|
2024-08-19 10:01:07 +05:00
|
|
|
|
/// <summary>
|
|
|
|
|
/// проверяет доступ к скважине для компании
|
|
|
|
|
/// </summary>
|
|
|
|
|
/// <param name="idCompany"></param>
|
|
|
|
|
/// <param name="idWell"></param>
|
|
|
|
|
/// <param name="token"></param>
|
|
|
|
|
/// <returns></returns>
|
|
|
|
|
Task<bool> IsCompanyInvolvedInWellAsync(int idCompany, int idWell, CancellationToken token);
|
2022-08-09 11:10:01 +05:00
|
|
|
|
|
2024-08-19 10:01:07 +05:00
|
|
|
|
//TODO: remove that
|
|
|
|
|
/// <summary>
|
|
|
|
|
/// получить название скважины по id
|
|
|
|
|
/// </summary>
|
|
|
|
|
/// <param name="idWell"></param>
|
|
|
|
|
/// <param name="token"></param>
|
|
|
|
|
/// <returns></returns>
|
|
|
|
|
Task<string> GetWellCaptionByIdAsync(int idWell, CancellationToken token);
|
2022-08-09 11:10:01 +05:00
|
|
|
|
|
2024-08-19 10:01:07 +05:00
|
|
|
|
/// <summary>
|
|
|
|
|
/// список компаний участвующих в скважине
|
|
|
|
|
/// </summary>
|
|
|
|
|
/// <param name="idWell"></param>
|
|
|
|
|
/// <param name="token"></param>
|
|
|
|
|
/// <returns></returns>
|
|
|
|
|
Task<IEnumerable<CompanyDto>> GetCompaniesAsync(int idWell, CancellationToken token);
|
2022-08-09 11:10:01 +05:00
|
|
|
|
|
2024-08-19 10:01:07 +05:00
|
|
|
|
//TODO: remove that
|
|
|
|
|
/// <summary>
|
|
|
|
|
///
|
|
|
|
|
/// </summary>
|
|
|
|
|
/// <param name="state"></param>
|
|
|
|
|
/// <returns></returns>
|
|
|
|
|
string GetStateText(int state);
|
2022-08-09 11:10:01 +05:00
|
|
|
|
|
2024-08-19 10:01:07 +05:00
|
|
|
|
/// <summary>
|
|
|
|
|
/// дата получения последних данных от панели
|
|
|
|
|
/// </summary>
|
|
|
|
|
/// <param name="idWell"></param>
|
|
|
|
|
/// <returns></returns>
|
|
|
|
|
DateTimeOffset GetLastTelemetryDate(int idWell);
|
2022-08-09 11:10:01 +05:00
|
|
|
|
|
2024-08-19 10:01:07 +05:00
|
|
|
|
//TODO: выяснить и удалить отсюда
|
|
|
|
|
/// <summary>
|
|
|
|
|
/// получение списка скважин куста в котором находится указанная скважина
|
|
|
|
|
/// </summary>
|
|
|
|
|
/// <param name="idWell"></param>
|
|
|
|
|
/// <param name="token"></param>
|
|
|
|
|
/// <returns></returns>
|
|
|
|
|
Task<IEnumerable<int>> GetClusterWellsIdsAsync(int idWell, CancellationToken token);
|
2022-08-09 11:10:01 +05:00
|
|
|
|
|
2024-08-19 10:01:07 +05:00
|
|
|
|
/// <summary>
|
|
|
|
|
/// часовой пояс скважины
|
|
|
|
|
/// </summary>
|
|
|
|
|
/// <param name="idWell"></param>
|
|
|
|
|
/// <returns></returns>
|
|
|
|
|
SimpleTimezoneDto GetTimezone(int idWell);
|
2022-08-09 11:10:01 +05:00
|
|
|
|
|
2024-08-19 10:01:07 +05:00
|
|
|
|
/// <summary>
|
|
|
|
|
/// диапазон дат с данными телеметрии
|
|
|
|
|
/// </summary>
|
|
|
|
|
/// <param name="idWell"></param>
|
|
|
|
|
/// <returns></returns>
|
|
|
|
|
DatesRangeDto GetDatesRange(int idWell);
|
2022-08-09 11:10:01 +05:00
|
|
|
|
|
2024-08-19 10:01:07 +05:00
|
|
|
|
/// <summary>
|
|
|
|
|
/// ВРЕМЕННЫЙ метод
|
|
|
|
|
/// </summary>
|
|
|
|
|
/// <param name="idCompany"></param>
|
|
|
|
|
/// <param name="token"></param>
|
|
|
|
|
/// <returns></returns>
|
|
|
|
|
Task<IEnumerable<DepositBranchDto>> GetWellTreeAsync(int idCompany, CancellationToken token);
|
2021-04-02 17:28:07 +05:00
|
|
|
|
}
|