BaseClient.cs 9.9 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357
  1. using System;
  2. using System.Collections.Generic;
  3. using System.Data;
  4. using System.Linq;
  5. using System.Threading.Tasks;
  6. using InABox.Core;
  7. namespace InABox.Clients
  8. {
  9. public abstract class BaseClient<TEntity> : IClient<TEntity>, IClient where TEntity : Entity, new()
  10. {
  11. public BaseClient()
  12. {
  13. Timeout = new TimeSpan(0, 1, 0);
  14. }
  15. public TimeSpan Timeout { get; set; }
  16. public abstract IEnumerable<string> SupportedTypes();
  17. public abstract bool IsConnected();
  18. public event LogEvent? OnLog;
  19. protected void RaiseLogEvent(LogType type, String userid, string format, params object[] parameters) => OnLog?.Invoke(type, userid, format, parameters);
  20. public DataTable LoadDataTable(Columns<TEntity> columns, object[][] data)
  21. {
  22. var result = new DataTable(typeof(TEntity).EntityName());
  23. var cols = CoreUtils.GetColumns(columns);
  24. foreach (var col in cols.Items)
  25. result.Columns.Add(col.Property, col.Expression.Type);
  26. result.BeginLoadData();
  27. foreach (var row in data.AsEnumerable())
  28. result.LoadDataRow(row, true);
  29. result.EndLoadData();
  30. return result;
  31. }
  32. #region Validation
  33. public virtual IValidationData Validate(string userid, string password, Guid session)
  34. {
  35. return DoValidate(userid, password, session);
  36. }
  37. protected abstract IValidationData DoValidate(string userid, string password, Guid session = default);
  38. public virtual IValidationData Validate(string pin, Guid session)
  39. {
  40. return DoValidate(pin, session);
  41. }
  42. protected abstract IValidationData DoValidate(string pin, Guid session = default);
  43. public virtual IValidationData Validate(Guid session)
  44. {
  45. return DoValidate(session);
  46. }
  47. protected abstract IValidationData DoValidate(Guid session = default);
  48. #endregion
  49. #region Query
  50. public CoreTable Query(object? filter = null, object? columns = null, object? sort = null)
  51. {
  52. return DoQuery((Filter<TEntity>?)filter, (Columns<TEntity>?)columns, (SortOrder<TEntity>?)sort);
  53. }
  54. public CoreTable Query(Filter<TEntity>? filter = null, Columns<TEntity>? columns = null, SortOrder<TEntity>? sort = null)
  55. {
  56. return DoQuery(filter, columns, sort);
  57. }
  58. public void Query(Filter<TEntity>? filter, Columns<TEntity>? columns, SortOrder<TEntity>? sort, Action<CoreTable?, Exception?> callback)
  59. {
  60. Task.Run(() =>
  61. {
  62. Exception? err = null;
  63. CoreTable? result = null;
  64. try
  65. {
  66. result = DoQuery(filter, columns, sort);
  67. }
  68. catch (Exception e)
  69. {
  70. err = e;
  71. }
  72. finally
  73. {
  74. callback.Invoke(result, err);
  75. }
  76. });
  77. }
  78. protected abstract CoreTable DoQuery(Filter<TEntity>? filter, Columns<TEntity>? columns, SortOrder<TEntity>? sort = null);
  79. #endregion
  80. #region Load
  81. public Entity[] Load(object? filter = null, object? sort = null)
  82. {
  83. return DoLoad((Filter<TEntity>?)filter, (SortOrder<TEntity>?)sort);
  84. }
  85. public TEntity[] Load(Filter<TEntity>? filter = null, SortOrder<TEntity>? sort = null)
  86. {
  87. return DoLoad(filter, sort);
  88. }
  89. public void Load(Filter<TEntity>? filter, SortOrder<TEntity>? sort, Action<TEntity[]?, Exception?> callback)
  90. {
  91. Task.Run(() =>
  92. {
  93. Exception? err = null;
  94. TEntity[]? result = null;
  95. try
  96. {
  97. result = DoLoad(filter, sort);
  98. }
  99. catch (Exception e)
  100. {
  101. err = e;
  102. }
  103. finally
  104. {
  105. callback.Invoke(result, err);
  106. }
  107. });
  108. }
  109. protected abstract TEntity[] DoLoad(Filter<TEntity>? filter = null, SortOrder<TEntity>? sort = null);
  110. #endregion
  111. #region Save
  112. public void Save(object entity, string auditnote)
  113. {
  114. var e = (TEntity)entity;
  115. DoSave(e, auditnote);
  116. }
  117. public void Save(IEnumerable<object> entities, string auditnote)
  118. {
  119. var items = entities.Select(x => (TEntity)x);
  120. DoSave(items, auditnote);
  121. }
  122. public void Save(TEntity entity, string auditnote)
  123. {
  124. DoSave(entity, auditnote);
  125. }
  126. public void Save(IEnumerable<TEntity> entities, string auditnote)
  127. {
  128. DoSave(entities, auditnote);
  129. }
  130. public void Save(TEntity entity, string auditnote, Action<TEntity, Exception?> callback)
  131. {
  132. Task.Run(() =>
  133. {
  134. Exception? err = null;
  135. try
  136. {
  137. DoSave(entity, auditnote);
  138. }
  139. catch (Exception e)
  140. {
  141. err = e;
  142. }
  143. finally
  144. {
  145. callback.Invoke(entity, err);
  146. }
  147. });
  148. }
  149. public void Save(IEnumerable<TEntity> entities, string auditnote, Action<IEnumerable<TEntity>, Exception?> callback)
  150. {
  151. Task.Run(() =>
  152. {
  153. Exception? err = null;
  154. var items = entities.AsArray();
  155. try
  156. {
  157. DoSave(items, auditnote);
  158. }
  159. catch (Exception e)
  160. {
  161. err = e;
  162. }
  163. finally
  164. {
  165. callback.Invoke(items, err);
  166. }
  167. });
  168. }
  169. protected abstract void DoSave(TEntity entity, string auditnote);
  170. protected abstract void DoSave(IEnumerable<TEntity> entities, string auditnote);
  171. #endregion
  172. #region Delete
  173. public void Delete(object entity, string auditnote)
  174. {
  175. DoDelete((TEntity)entity, auditnote);
  176. }
  177. public void Delete(IEnumerable<object> entities, string auditnote)
  178. {
  179. var items = entities.Select(x => (TEntity)x).ToList();
  180. DoDelete(items, auditnote);
  181. }
  182. public void Delete(TEntity entity, string auditnote)
  183. {
  184. DoDelete(entity, auditnote);
  185. }
  186. public void Delete(IEnumerable<TEntity> entities, string auditnote)
  187. {
  188. DoDelete(entities, auditnote);
  189. }
  190. public void Delete(TEntity entity, string auditnote, Action<TEntity, Exception?> callback)
  191. {
  192. Task.Run(() =>
  193. {
  194. Exception? err = null;
  195. try
  196. {
  197. DoDelete(entity, auditnote);
  198. }
  199. catch (Exception e)
  200. {
  201. err = e;
  202. }
  203. finally
  204. {
  205. callback.Invoke(entity, err);
  206. }
  207. }
  208. );
  209. }
  210. public void Delete(IEnumerable<TEntity> entities, string auditnote, Action<IList<TEntity>, Exception?> callback)
  211. {
  212. Task.Run(() =>
  213. {
  214. Exception? err = null;
  215. var items = entities.ToArray();
  216. try
  217. {
  218. DoDelete(items, auditnote);
  219. }
  220. catch (Exception e)
  221. {
  222. err = e;
  223. }
  224. finally
  225. {
  226. callback.Invoke(items, err);
  227. }
  228. });
  229. }
  230. protected abstract void DoDelete(TEntity entity, string auditnote);
  231. protected abstract void DoDelete(IEnumerable<TEntity> entities, string auditnote);
  232. #endregion
  233. #region MultipleTables
  234. public Dictionary<string, CoreTable> QueryMultiple(Dictionary<string, IQueryDef> queries)
  235. {
  236. if(queries.Count == 0)
  237. {
  238. return new Dictionary<string, CoreTable>();
  239. }
  240. else
  241. {
  242. return DoQueryMultiple(queries);
  243. }
  244. }
  245. protected abstract Dictionary<string, CoreTable> DoQueryMultiple(Dictionary<string, IQueryDef> queries);
  246. public void QueryMultiple(Action<Dictionary<string, CoreTable>?, Exception?> callback, Dictionary<string, IQueryDef> queries)
  247. {
  248. Task.Run(() =>
  249. {
  250. Exception? err = null;
  251. Dictionary<string, CoreTable>? result = null;
  252. try
  253. {
  254. result = QueryMultiple(queries);
  255. }
  256. catch (Exception e)
  257. {
  258. err = e;
  259. }
  260. finally
  261. {
  262. callback.Invoke(result, err);
  263. }
  264. });
  265. }
  266. #endregion
  267. #region 2FA
  268. public bool Check2FA(string code, Guid? session)
  269. {
  270. return DoCheck2FA(code, session);
  271. }
  272. protected abstract bool DoCheck2FA(string code, Guid? session);
  273. #endregion
  274. #region Ping
  275. public bool Ping()
  276. {
  277. return DoPing();
  278. }
  279. protected abstract bool DoPing();
  280. #endregion
  281. #region Info
  282. public abstract DatabaseInfo Info();
  283. #endregion
  284. #region Update
  285. public abstract string Version();
  286. public abstract string ReleaseNotes();
  287. public abstract byte[]? Installer();
  288. #endregion
  289. }
  290. }