using FireLance; using FireLance.Models; using Gsm; using System; using System.Collections.Generic; using System.ComponentModel; using System.Linq; namespace DevConsole { class Program { public static GsmMgr gsmMgr = new GsmMgr(); public static GsmRO gsmRO; public static FirelanceMgr flcMgr = new FirelanceMgr(); public static FirelanceCRUD flcCRUD; static void Main(string[] args) { ConnectToGsmDb(); ConnectToFirelanceManager(); Console.WriteLine(""); while (true) { CommandsMenu(); } } private static void CommandsMenu() { Console.WriteLine("Please select an option below:\n"); Console.WriteLine("A. Manage DB Connections --->"); Console.WriteLine("B. GSM Actions --->"); Console.WriteLine("C. FLC Actions --->"); Console.WriteLine("X. Exit application\n"); Console.Write(":"); var userInput = Console.ReadLine(); Console.Write("\n\n"); switch (userInput.ToUpper()) { case "A": CmdDbMgr(); break; case "B": CmdGsmActions(); break; case "C": CmdFlcActions(); break; case "X": Environment.Exit(0); break; default: Console.WriteLine("Invalid selection, please enter a listed command."); break; } } private static void ConnectToGsmDb() { gsmMgr.OpenConnection(@"C:\Users\Dunestorm\Projects\FireLance\GSMParser\games.db", 0); gsmRO = new GsmRO(gsmMgr.Database); Console.WriteLine($"GSMParser Connection State: {gsmMgr.IsConnectionOpen()}"); } private static void ConnectToFirelanceManager() { flcMgr.OpenConnection("sr3", 27017); flcCRUD = new FirelanceCRUD(flcMgr.Database); Console.WriteLine($"FireLance Connection State: {flcMgr.IsConnectionOpen()}"); } #region Command Options private static void CmdDbMgr() { Console.WriteLine("[GsmDb]------------"); Console.WriteLine("A. Open DB"); Console.WriteLine("B. Close DB"); Console.WriteLine("[Firelance]------------"); Console.WriteLine("C. Open DB"); Console.WriteLine("D. Close DB (Unsupported)"); Console.WriteLine("X. <--- Go back\n"); Console.Write(":"); var userInput = Console.ReadLine(); Console.Write("\n\n"); switch (userInput.ToUpper()) { case "A": ConnectToGsmDb(); break; case "B": gsmMgr.CloseCurrentConnection(); break; case "C": ConnectToFirelanceManager(); break; case "D": flcMgr.CloseCurrentConnection(); break; case "X": break; } } private static void CmdGsmActions() { Console.WriteLine("A. Query game by ID"); Console.WriteLine("B. Query directory by ID"); Console.WriteLine("C. Query game by NAME"); Console.WriteLine("X. <--- Go back\n"); Console.Write(":"); var userInput = Console.ReadLine(); Console.Write("\n\n"); switch (userInput.ToUpper()) { case "A": Console.WriteLine("Enter a game ID:"); var queryId = gsmRO.LoadRecords( GsmRO.Columns.GameName, GsmRO.Tables.GameEntry, GsmRO.Columns.ID, Console.ReadLine(), true); foreach (var record in queryId) PrintAllValues(record); break; case "B": Console.WriteLine("Enter a game ID:"); var queryDirectoryId = gsmRO.LoadRecords( "*", GsmRO.Tables.Directories, GsmRO.Columns.GameID, Console.ReadLine(), true); foreach (var record in queryDirectoryId) PrintAllValues(record); break; case "C": Console.WriteLine("Enter game title to search:"); var queryGameByName = gsmRO.LoadRecords( GsmRO.Columns.GameName, GsmRO.Tables.GameEntry, GsmRO.Columns.GameName, Console.ReadLine(), false); foreach (var record in queryGameByName) PrintAllValues(record); break; case "X": break; } } private static void CmdFlcActions() { Console.WriteLine("A. Write predefined MasterGameRecord"); Console.WriteLine("B. Read predefined MasterGameRecord"); Console.WriteLine("C. Insert save entry into existing MasterGameRecord"); Console.WriteLine("D. Remove save entry from existing MasterGameRecord"); Console.WriteLine("E. Upload save entry using GridFS"); Console.WriteLine("F. Download save entry using GridFS"); Console.WriteLine("X. <--- Go back\n"); Console.Write(":"); var userInput = Console.ReadLine(); Console.Write("\n\n"); switch (userInput.ToUpper()) { case "A": FlcWriteMasterGameRecordAction(); break; case "B": FlcReadMasterGameRecordAction(); break; case "C": FlcInsertSaveEntryAction(); break; case "D": FlcRemoveSaveEntryAction(); break; case "E": FlcUploadToGridFsAction(); break; case "F": FlcDownloadToGridFsAction(); break; case "X": break; } } #endregion #region FlcActions private static void FlcWriteMasterGameRecordAction() { var masterGameRecord = new MasterGameRecordModel(); List directories = gsmRO.LoadRecords("*", GsmRO.Tables.Directories, GsmRO.Columns.GameID, "600", true); GameEntryModel gameEntry = gsmRO.LoadRecords(GsmRO.Columns.GameName, GsmRO.Tables.GameEntry, GsmRO.Columns.ID, "600", true).First(); List saveGameEntries = new List(); saveGameEntries.Add(new SaveGameEntriesModel()); masterGameRecord.Directories = directories; masterGameRecord.GameEntry = gameEntry; masterGameRecord.SaveGameEntries = saveGameEntries; flcCRUD.InsertRecord("GameRecords", masterGameRecord); } static void FlcReadMasterGameRecordAction() { var masterGameRecords = flcCRUD.LoadRecordsFromTable("GameRecords"); foreach (var record in masterGameRecords) { Console.WriteLine(record.Id); Console.WriteLine(""); PrintAllValues(record.GameEntry); Console.WriteLine(""); foreach (var subRecord in record.Directories) { PrintAllValues(subRecord); Console.WriteLine(""); } foreach (var subRecord in record.SaveGameEntries) { PrintAllValues(subRecord); Console.WriteLine(""); } } } private static void FlcRemoveSaveEntryAction() { Guid firstMasterGameRecordGuid = flcCRUD.LoadRecordsFromTable("GameRecords").First().Id; var masterGameRecordToRemove = flcCRUD.LoadRecordById("GameRecords", firstMasterGameRecordGuid); Guid firstSaveGameEntryGuid = masterGameRecordToRemove.SaveGameEntries.Select(x => x.Id).First(); masterGameRecordToRemove.SaveGameEntries.RemoveAll(x => x.Id == firstSaveGameEntryGuid); flcCRUD.UpsertRecordById("GameRecords", firstMasterGameRecordGuid, masterGameRecordToRemove); } private static void FlcInsertSaveEntryAction() { Guid firstMasterGameRecordGuid = flcCRUD.LoadRecordsFromTable("GameRecords").First().Id; var masterGameRecordToInsert = flcCRUD.LoadRecordById("GameRecords", firstMasterGameRecordGuid); masterGameRecordToInsert.SaveGameEntries.Add(new SaveGameEntriesModel()); flcCRUD.UpsertRecordById("GameRecords", firstMasterGameRecordGuid, masterGameRecordToInsert); } private static void FlcUploadToGridFsAction() { var flcGFS = new FirelanceGFS(flcMgr.Database); var ulResult = flcGFS.UploadFile("TestFile", @"C:\Users\Dunestorm\Downloads\OpenMW-0.46.0-win64.exe"); Console.WriteLine(ulResult.Result); } private static void FlcDownloadToGridFsAction() { var objId = "5f00a560b65a2f02d0c7996e"; var flcGFC = new FirelanceGFS(flcMgr.Database); var dlResult = flcGFC.DownloadFile(new MongoDB.Bson.ObjectId(objId), @$"D:\Temp\{objId}.exe"); Console.WriteLine($"Download Successful: {dlResult.Result}"); } #endregion private static void PrintAllValues(T data) { foreach (PropertyDescriptor item in TypeDescriptor.GetProperties(data)) { Console.WriteLine($"{item.Name}: {item.GetValue(data)}"); } } } }