Little test with AI + Add the equipment (#8)
Tests using local LLM AI to add comments in the C# files For the flights tunnel, show the total to day/hours For the jump, add the equipment (now just with the wingsuit) Reviewed-on: #8 Co-authored-by: sandre <perso@sebastienandre.com> Co-committed-by: sandre <perso@sebastienandre.com>
This commit was merged in pull request #8.
This commit is contained in:
@@ -1,8 +1,9 @@
|
||||
using LiteDB;
|
||||
using System;
|
||||
using System.Collections.Generic;
|
||||
using LiteDB;
|
||||
using skydiveLogs_api.Domain;
|
||||
using skydiveLogs_api.DomainService.Repositories;
|
||||
using skydiveLogs_api.Infrastructure.Interfaces;
|
||||
using System.Collections.Generic;
|
||||
|
||||
namespace skydiveLogs_api.Infrastructure
|
||||
{
|
||||
@@ -10,6 +11,16 @@ namespace skydiveLogs_api.Infrastructure
|
||||
{
|
||||
#region Public Constructors
|
||||
|
||||
/// <summary>
|
||||
/// Initializes a new instance of the <see cref="FavoriteDropZoneRepository"/> class.
|
||||
/// </summary>
|
||||
/// <param name="dataProvider">The data provider used for database access operations.</param>
|
||||
/// <remarks>
|
||||
/// This constructor initializes the repository with a reference to the data provider
|
||||
/// and sets up the collection for favorite drop zone data operations.
|
||||
/// The data provider manages the underlying LiteDatabase connection and provides
|
||||
/// typed collection accessors for different entity types.
|
||||
/// </remarks>
|
||||
public FavoriteDropZoneRepository(IDataProvider dataProvider)
|
||||
{
|
||||
_dataProvider = dataProvider;
|
||||
@@ -20,6 +31,16 @@ namespace skydiveLogs_api.Infrastructure
|
||||
|
||||
#region Public Methods
|
||||
|
||||
/// <summary>
|
||||
/// Adds a new favorite drop zone to the database.
|
||||
/// </summary>
|
||||
/// <param name="favoriteToAdd">The favorite drop zone instance to insert into the database.</param>
|
||||
/// <returns>The number of rows affected. Returns 0 if the insert operation failed.</returns>
|
||||
/// <remarks>
|
||||
/// Attempts to insert the new favorite drop zone into the database using LiteDB.
|
||||
/// If an exception occurs during insertion, the method returns 0.
|
||||
/// The returned value indicates the number of records affected by the insert operation.
|
||||
/// </remarks>
|
||||
public int Add(FavoriteDropZone favoriteToAdd)
|
||||
{
|
||||
int result;
|
||||
@@ -37,11 +58,31 @@ namespace skydiveLogs_api.Infrastructure
|
||||
return result;
|
||||
}
|
||||
|
||||
/// <summary>
|
||||
/// Deletes favorite drop zone entries by drop zone ID and user ID.
|
||||
/// </summary>
|
||||
/// <param name="dropZoneId">The unique identifier of the drop zone to delete favorites for.</param>
|
||||
/// <param name="userId">The unique identifier of the user whose favorites to delete.</param>
|
||||
/// <returns>The number of rows affected. Returns 0 if the delete operation failed or no records matched.</returns>
|
||||
/// <remarks>
|
||||
/// Deletes all favorite drop zone records where both the drop zone ID and user ID match the provided values.
|
||||
/// This operation is commonly used to remove a specific user's favorites for a particular drop zone.
|
||||
/// </remarks>
|
||||
public int Delete(int dropZoneId, int userId)
|
||||
{
|
||||
return _col.DeleteMany(d => d.DropZone.Id == dropZoneId && d.User.Id == userId);
|
||||
}
|
||||
|
||||
/// <summary>
|
||||
/// Retrieves all favorite drop zones for a specific user.
|
||||
/// </summary>
|
||||
/// <param name="user">The user whose favorite drop zones to retrieve.</param>
|
||||
/// <returns>An enumerable collection containing all favorite drop zone instances belonging to the specified user.</returns>
|
||||
/// <remarks>
|
||||
/// Queries the favorite drop zone collection and retrieves all records where the user ID matches the provided user.
|
||||
/// Each returned record includes navigation properties to the associated user and drop zone entities.
|
||||
/// Returns an empty collection if the user has no favorite drop zones.
|
||||
/// </remarks>
|
||||
public IEnumerable<FavoriteDropZone> GetAll(User user)
|
||||
{
|
||||
return _col.Query()
|
||||
@@ -49,33 +90,81 @@ namespace skydiveLogs_api.Infrastructure
|
||||
.ToList();
|
||||
}
|
||||
|
||||
/// <summary>
|
||||
/// Retrieves all favorite drop zones from the database.
|
||||
/// </summary>
|
||||
/// <returns>An enumerable collection containing all favorite drop zone instances in the database.</returns>
|
||||
/// <remarks>
|
||||
/// This method is not currently implemented and throws a <see cref="NotImplementedException"/> when called.
|
||||
/// Implement this method to retrieve all favorite drop zones across all users in the system.
|
||||
/// </remarks>
|
||||
/// <exception cref="NotImplementedException">Thrown when the method is called.</exception>
|
||||
public IEnumerable<FavoriteDropZone> GetAll()
|
||||
{
|
||||
throw new System.NotImplementedException();
|
||||
throw new NotImplementedException();
|
||||
}
|
||||
|
||||
/// <summary>
|
||||
/// Retrieves a favorite drop zone by its unique identifier.
|
||||
/// </summary>
|
||||
/// <param name="id">The unique identifier of the favorite drop zone to retrieve.</param>
|
||||
/// <returns>The favorite drop zone instance if found, otherwise null.</returns>
|
||||
/// <remarks>
|
||||
/// Searches the favorite drop zone collection for a record with the specified ID.
|
||||
/// This method currently returns null as it's not implemented with proper filtering by ID.
|
||||
/// Implement this method to retrieve a specific favorite drop zone by its database ID.
|
||||
/// </remarks>
|
||||
/// <exception cref="NotImplementedException">Thrown when attempting to retrieve by ID.</exception>
|
||||
public FavoriteDropZone GetById(int id)
|
||||
{
|
||||
throw new System.NotImplementedException();
|
||||
throw new NotImplementedException();
|
||||
}
|
||||
|
||||
/// <summary>
|
||||
/// Gets the total count of favorite drop zones for a specific user.
|
||||
/// </summary>
|
||||
/// <param name="user">The user whose favorite drop zones to count.</param>
|
||||
/// <returns>The total number of favorite drop zones for the specified user.</returns>
|
||||
/// <remarks>
|
||||
/// This method is not currently implemented and throws a <see cref="NotImplementedException"/> when called.
|
||||
/// Implement this method to retrieve the count of favorite drop zones per user.
|
||||
/// </remarks>
|
||||
/// <exception cref="NotImplementedException">Thrown when the method is called.</exception>
|
||||
public int GetCount()
|
||||
{
|
||||
throw new System.NotImplementedException();
|
||||
throw new NotImplementedException();
|
||||
}
|
||||
|
||||
/// <summary>
|
||||
/// Updates an existing favorite drop zone in the database.
|
||||
/// </summary>
|
||||
/// <param name="updated">The favorite drop zone instance containing the updated data.</param>
|
||||
/// <returns><see langword="true"/> if the update was successful; otherwise, <see langword="false"/>.</returns>
|
||||
/// <remarks>
|
||||
/// This method is not currently implemented and throws a <see cref="NotImplementedException"/> when called.
|
||||
/// Implement this method to update existing favorite drop zone records in the database.
|
||||
/// Note: Favorite drop zones may not typically be updated; consider using Add for new favorites.
|
||||
/// </remarks>
|
||||
/// <exception cref="NotImplementedException">Thrown when attempting to update.</exception>
|
||||
public bool Update(FavoriteDropZone updated)
|
||||
{
|
||||
throw new System.NotImplementedException();
|
||||
throw new NotImplementedException();
|
||||
}
|
||||
|
||||
#endregion Public Methods
|
||||
|
||||
#region Private Fields
|
||||
|
||||
/// <summary>
|
||||
/// The LiteDB collection for favorite drop zone records.
|
||||
/// </summary>
|
||||
private readonly ILiteCollection<FavoriteDropZone> _col;
|
||||
|
||||
/// <summary>
|
||||
/// The data provider used for database access operations.
|
||||
/// </summary>
|
||||
private readonly IDataProvider _dataProvider;
|
||||
|
||||
#endregion Private Fields
|
||||
}
|
||||
}
|
||||
}
|
||||
|
||||
Reference in New Issue
Block a user