Got the new ui flow working and the models updated. Need to get changes written to the database.
This commit is contained in:
@@ -2,6 +2,8 @@
|
||||
using Npgsql;
|
||||
using System;
|
||||
using System.Collections.Generic;
|
||||
using System.Collections.Specialized;
|
||||
using System.ComponentModel;
|
||||
using System.Linq;
|
||||
using System.Text;
|
||||
using System.Threading.Tasks;
|
||||
@@ -17,43 +19,43 @@ public class FilePathProvider : IFilePathProvider
|
||||
_dataSource = dataSource;
|
||||
}
|
||||
|
||||
public async Task<bool> AddFile(string path)
|
||||
public async Task<bool> AddFileInfo(string path, string originalName)
|
||||
{
|
||||
await using var connection = await _dataSource.OpenConnectionAsync();
|
||||
|
||||
var sql = @"INSERT INTO archivefiles (filename, path) VALUES (@Filename, @Path)";
|
||||
var sql = @"INSERT INTO archivefiles (originalname, path) VALUES (@OriginalName, @Path)";
|
||||
|
||||
var rowsAffected = await connection.ExecuteAsync(sql, new { Filename = Path.GetFileName(path), Path = path});
|
||||
var rowsAffected = await connection.ExecuteAsync(sql, new { OriginalName=originalName, Path = path});
|
||||
|
||||
return rowsAffected == 1;
|
||||
}
|
||||
|
||||
public async Task<bool> RemoveFile(string path)
|
||||
public async Task<bool> RemoveFileInfo(string path, string originalName)
|
||||
{
|
||||
await using var connection = await _dataSource.OpenConnectionAsync();
|
||||
|
||||
var sql = @"DELETE FROM archivefiles WHERE path = @Path";
|
||||
var sql = @"DELETE FROM archivefiles WHERE path = @Path AND originalname = @OriginalName";
|
||||
|
||||
var rowsAffected = await connection.ExecuteAsync(sql, new { Path = path });
|
||||
var rowsAffected = await connection.ExecuteAsync(sql, new { Path = path, OriginalName = originalName});
|
||||
|
||||
return rowsAffected == 1;
|
||||
}
|
||||
|
||||
public async Task<IEnumerable<FileInfo>> SearchFiles(string filename)
|
||||
public async Task<IEnumerable<FilePathInfo>> SearchFiles(string filename)
|
||||
{
|
||||
await using var connection = await _dataSource.OpenConnectionAsync();
|
||||
|
||||
var sql = @"SELECT * FROM archivefiles WHERE POSITION(LOWER(@Query) in LOWER(filename)) > 0";
|
||||
|
||||
return await connection.QueryAsync<FileInfo>(sql, new { Query = filename });
|
||||
return await connection.QueryAsync<FilePathInfo>(sql, new { Query = filename });
|
||||
}
|
||||
|
||||
public async Task<IEnumerable<FileInfo>> TopFiles(int resultsCount)
|
||||
public async Task<IEnumerable<FilePathInfo>> TopFiles(int resultsCount)
|
||||
{
|
||||
await using var connection = await _dataSource.OpenConnectionAsync();
|
||||
|
||||
var sql = $@"SELECT * FROM archivefiles ORDER BY filename ASC LIMIT {resultsCount}";
|
||||
|
||||
return await connection.QueryAsync<FileInfo>(sql);
|
||||
return await connection.QueryAsync<FilePathInfo>(sql);
|
||||
}
|
||||
}
|
||||
|
||||
Reference in New Issue
Block a user