Add base file support :trollface:

This commit is contained in:
j4ck 2022-06-02 22:55:16 +03:00
parent 7780ff809e
commit dc906379da
5 changed files with 51 additions and 44 deletions

View File

@ -7,18 +7,46 @@ namespace RSND.Core;
public class Database public class Database
{ {
List<Table> tables = new(); private string Name { get; set; }
private List<Table> _tables = new();
public Database(string name)
{
Name = name;
}
public void SetupFiles()
{
if (File.Exists($"{Name}.json"))
{
Console.WriteLine($"{Name} flag123");
var json = File.ReadAllText($"{Name}.json");
var db = JsonConvert.DeserializeObject<List<Table>>(json);
if (db != null)
_tables = db;
}
else
{
Console.WriteLine($"{Name} flag");
File.Create($"{Name}.json");
}
}
public void Save()
{
var json = JsonConvert.SerializeObject(_tables);
File.WriteAllText($"{Name}.json", json);
}
public void CreateTable(Table query) public void CreateTable(Table query)
{ {
var matches = tables.FirstOrDefault(x => x.Name == query.Name); if (_tables.Any(x => x.Name == query.Name))
if (matches != null)
{ {
tables.Remove(matches); _tables.RemoveAll(x => x.Name == query.Name);
} }
tables.Add(query); _tables.Add(query);
Save();
} }
private static string GetRowsJson(Row[]? rows) private static string GetRowsJson(Row[]? rows)
@ -28,20 +56,19 @@ public class Database
public string GetValue(GetQuery? query) public string GetValue(GetQuery? query)
{ {
Console.WriteLine(tables.Count.ToString().Pastel("#ff0000")); Console.WriteLine(_tables.Count.ToString().Pastel("#ff0000"));
var table = query?.Table; var table = query?.Table;
var where = query?.Where; var where = query?.Where;
var split = where?.Split("|"); var split = where?.Split("|");
var colName = split?[0]; var colName = split?[0];
var condition = split?[1]; var condition = split?[1];
var param = split?[2]; var value = split?[2];
if (query?.Select != "*") return ""; if (query?.Select != "*") return "";
var tableToReturn = _tables.Find(x => x.Name == table);
var tableToReturn = tables.Find(x => x.Name == table); var rows = tableToReturn?.Rows?.Where(x => x.Columns?.FirstOrDefault(y => y.Name == colName)?.Value == value).ToArray();
var rows = tableToReturn?.Rows?.Where(x => x.Columns?.FirstOrDefault(y => y.Data.Key == colName)?.Data.Value == param).ToArray();
return GetRowsJson(rows); return GetRowsJson(rows);
} }

View File

@ -14,30 +14,6 @@ public class DbClient
public DbClient(IWebSocketConnection socket) public DbClient(IWebSocketConnection socket)
{ {
_socket = socket; _socket = socket;
RsndMain.Db.CreateTable(new Table
{
Name = "j4ces.table",
Rows = new []
{
new Row
{
Columns = new []
{
new Column("id", "1"),
new Column("amog us", "is THE GAME")
}
},
new Row
{
Columns = new []
{
new Column("id", "1"),
new Column("fortnite", "is THE GAME")
}
}
}
});
} }
private void InvalidQuery() private void InvalidQuery()
@ -63,8 +39,7 @@ public class DbClient
{ {
if (query == null || queryType == null) if (query == null || queryType == null)
InvalidQuery(); InvalidQuery();
// check if
switch (queryType) switch (queryType)
{ {
case QueryType.GetValue: case QueryType.GetValue:

View File

@ -2,10 +2,12 @@
public class Column public class Column
{ {
public KeyValuePair<string, string> Data; public Column(string? name, string? value)
public Column(string name, string value)
{ {
Data = new KeyValuePair<string, string>(name, value); Name = name;
Value = value;
} }
public string? Name { get; set; }
public string? Value { get; set; }
} }

View File

@ -3,5 +3,5 @@
public class Response public class Response
{ {
public bool Success { get; set; } public bool Success { get; set; }
public string Message { get; set; } public string? Message { get; set; }
} }

View File

@ -5,10 +5,13 @@ namespace RSND;
public static class RsndMain public static class RsndMain
{ {
public static Database Db = new(); public static Database Db = new(Environment.GetCommandLineArgs()[1]);
public static void Run() public static void Run()
{ {
Db.SetupFiles();
Db.Save();
WebSocketServer server = new WebSocketServer("ws://0.0.0.0:7878"); WebSocketServer server = new WebSocketServer("ws://0.0.0.0:7878");
FleckLog.Level = LogLevel.Error; FleckLog.Level = LogLevel.Error;