Files
satellite-provider/SatelliteProvider.DataAccess/Repositories/RegionRepository.cs
T
Oleksandr Bezdieniezhnykh 534ab41b8e
ci/woodpecker/push/01-test Pipeline was successful
ci/woodpecker/push/02-build-push Pipeline was successful
[AZ-372] Apply dotnet format whitespace cleanup; archive batch 22
Pure whitespace-only cleanup uncovered by the new format gate from the
previous commit. Verified via `git diff -w --stat`: only 4 files differ
when whitespace is ignored, and those differ only by the BOM byte.

Cleanup kinds applied across 22 source files:
- BOM removal (MapConfig.cs, SatTile.cs, GeoUtils.cs,
  IntegrationTests/Program.cs)
- CRLF -> LF (IntegrationTests/Program.cs)
- Trailing whitespace on blank lines (Common, Api, DataAccess,
  IntegrationTests, Services.RegionProcessing,
  Services.TileDownloader)
- Final newline added (RoutePoint.cs, GeoPoint.cs, others)

After this commit `dotnet format whitespace SatelliteProvider.sln
--verify-no-changes` exits 0; AC-1 is enforceable from `scripts/
run-tests.sh` going forward.

Also lands the batch 22 report, code-review report
(PASS_WITH_WARNINGS, 2 Low findings — both deferred per spec),
dependency-table status update (AZ-372 -> Done (In Testing)), task
archive (todo/ -> done/), and autodev state update.

Co-authored-by: Cursor <cursoragent@cursor.com>
2026-05-11 04:43:08 +03:00

100 lines
3.9 KiB
C#

using Dapper;
using Microsoft.Extensions.Logging;
using Npgsql;
using SatelliteProvider.Common.Enums;
using SatelliteProvider.DataAccess.Models;
namespace SatelliteProvider.DataAccess.Repositories;
public class RegionRepository : IRegionRepository
{
private readonly string _connectionString;
private readonly ILogger<RegionRepository> _logger;
public RegionRepository(string connectionString, ILogger<RegionRepository> logger)
{
_connectionString = connectionString;
_logger = logger;
}
public async Task<RegionEntity?> GetByIdAsync(Guid id)
{
using var connection = new NpgsqlConnection(_connectionString);
const string sql = @"
SELECT id, latitude, longitude, size_meters as SizeMeters,
zoom_level as ZoomLevel, status,
csv_file_path as CsvFilePath, summary_file_path as SummaryFilePath,
tiles_downloaded as TilesDownloaded, tiles_reused as TilesReused,
stitch_tiles as StitchTiles,
created_at as CreatedAt, updated_at as UpdatedAt
FROM regions
WHERE id = @Id";
var region = await connection.QuerySingleOrDefaultAsync<RegionEntity>(sql, new { Id = id });
return region;
}
public async Task<IEnumerable<RegionEntity>> GetByStatusAsync(RegionStatus status)
{
using var connection = new NpgsqlConnection(_connectionString);
const string sql = @"
SELECT id, latitude, longitude, size_meters as SizeMeters,
zoom_level as ZoomLevel, status,
csv_file_path as CsvFilePath, summary_file_path as SummaryFilePath,
tiles_downloaded as TilesDownloaded, tiles_reused as TilesReused,
stitch_tiles as StitchTiles,
created_at as CreatedAt, updated_at as UpdatedAt
FROM regions
WHERE status = @Status
ORDER BY created_at ASC";
return await connection.QueryAsync<RegionEntity>(sql, new { Status = status });
}
public async Task<Guid> InsertAsync(RegionEntity region)
{
using var connection = new NpgsqlConnection(_connectionString);
const string sql = @"
INSERT INTO regions (id, latitude, longitude, size_meters, zoom_level,
status, csv_file_path, summary_file_path,
tiles_downloaded, tiles_reused, stitch_tiles,
created_at, updated_at)
VALUES (@Id, @Latitude, @Longitude, @SizeMeters, @ZoomLevel,
@Status, @CsvFilePath, @SummaryFilePath,
@TilesDownloaded, @TilesReused, @StitchTiles,
@CreatedAt, @UpdatedAt)
RETURNING id";
return await connection.ExecuteScalarAsync<Guid>(sql, region);
}
public async Task<int> UpdateAsync(RegionEntity region)
{
using var connection = new NpgsqlConnection(_connectionString);
const string sql = @"
UPDATE regions
SET latitude = @Latitude,
longitude = @Longitude,
size_meters = @SizeMeters,
zoom_level = @ZoomLevel,
status = @Status,
csv_file_path = @CsvFilePath,
summary_file_path = @SummaryFilePath,
tiles_downloaded = @TilesDownloaded,
tiles_reused = @TilesReused,
stitch_tiles = @StitchTiles,
updated_at = @UpdatedAt
WHERE id = @Id";
return await connection.ExecuteAsync(sql, region);
}
public async Task<int> DeleteAsync(Guid id)
{
using var connection = new NpgsqlConnection(_connectionString);
const string sql = "DELETE FROM regions WHERE id = @Id";
return await connection.ExecuteAsync(sql, new { Id = id });
}
}