This commit is contained in:
@@ -70,10 +70,11 @@ namespace AyaNova.Api.Controllers
|
|||||||
return BadRequest(new ApiErrorResponse(ModelState));
|
return BadRequest(new ApiErrorResponse(ModelState));
|
||||||
|
|
||||||
var UserRoles = UserRolesFromContext.Roles(HttpContext.Items);
|
var UserRoles = UserRolesFromContext.Roles(HttpContext.Items);
|
||||||
|
var UserId = UserIdFromContext.Id(HttpContext.Items);
|
||||||
|
|
||||||
try
|
try
|
||||||
{
|
{
|
||||||
ApiDataListResponse r = await DataListFetcher.GetResponseAsync(listOptions.DataListKey, ct, listOptions, UserRoles, log);
|
ApiDataListResponse r = await DataListFetcher.GetResponseAsync(listOptions.DataListKey, ct, listOptions, UserRoles, log, UserId);
|
||||||
return Ok(r);
|
return Ok(r);
|
||||||
}
|
}
|
||||||
catch (System.UnauthorizedAccessException)
|
catch (System.UnauthorizedAccessException)
|
||||||
|
|||||||
@@ -70,7 +70,7 @@ namespace AyaNova.Api.Controllers
|
|||||||
if (format != "csv" && format != "json")
|
if (format != "csv" && format != "json")
|
||||||
return BadRequest(new ApiErrorResponse(ApiErrorCode.VALIDATION_INVALID_VALUE, null, "format not valid, must be 'csv' or 'json'"));
|
return BadRequest(new ApiErrorResponse(ApiErrorCode.VALIDATION_INVALID_VALUE, null, "format not valid, must be 'csv' or 'json'"));
|
||||||
|
|
||||||
await dataListSelection.RehydrateIdList(ct, UserRolesFromContext.Roles(HttpContext.Items), log);
|
await dataListSelection.RehydrateIdList(ct, UserRolesFromContext.Roles(HttpContext.Items), log, UserIdFromContext.Id(HttpContext.Items));
|
||||||
if (dataListSelection.SelectedRowIds.Length == 0)
|
if (dataListSelection.SelectedRowIds.Length == 0)
|
||||||
return BadRequest(new ApiErrorResponse(ApiErrorCode.VALIDATION_REQUIRED, null, "List of ids"));
|
return BadRequest(new ApiErrorResponse(ApiErrorCode.VALIDATION_REQUIRED, null, "List of ids"));
|
||||||
|
|
||||||
|
|||||||
@@ -211,7 +211,7 @@ namespace AyaNova.Api.Controllers
|
|||||||
return StatusCode(403, new ApiNotAuthorizedResponse());
|
return StatusCode(403, new ApiNotAuthorizedResponse());
|
||||||
|
|
||||||
|
|
||||||
await dataListSelection.RehydrateIdList(ct, UserRolesFromContext.Roles(HttpContext.Items), log);
|
await dataListSelection.RehydrateIdList(ct, UserRolesFromContext.Roles(HttpContext.Items), log, UserIdFromContext.Id(HttpContext.Items));
|
||||||
if (dataListSelection.SelectedRowIds.Length == 0)
|
if (dataListSelection.SelectedRowIds.Length == 0)
|
||||||
return BadRequest(new ApiErrorResponse(ApiErrorCode.VALIDATION_REQUIRED, null, "List of ids"));
|
return BadRequest(new ApiErrorResponse(ApiErrorCode.VALIDATION_REQUIRED, null, "List of ids"));
|
||||||
|
|
||||||
|
|||||||
@@ -103,7 +103,7 @@ namespace AyaNova.Api.Controllers
|
|||||||
if (string.IsNullOrWhiteSpace(tag))
|
if (string.IsNullOrWhiteSpace(tag))
|
||||||
return BadRequest(new ApiErrorResponse(ApiErrorCode.VALIDATION_REQUIRED, null, "tag required"));
|
return BadRequest(new ApiErrorResponse(ApiErrorCode.VALIDATION_REQUIRED, null, "tag required"));
|
||||||
|
|
||||||
await dataListSelection.RehydrateIdList(ct, UserRolesFromContext.Roles(HttpContext.Items), log);
|
await dataListSelection.RehydrateIdList(ct, UserRolesFromContext.Roles(HttpContext.Items), log, UserIdFromContext.Id(HttpContext.Items));
|
||||||
if (dataListSelection.SelectedRowIds.Length == 0)
|
if (dataListSelection.SelectedRowIds.Length == 0)
|
||||||
return BadRequest(new ApiErrorResponse(ApiErrorCode.VALIDATION_REQUIRED, null, "List of ids"));
|
return BadRequest(new ApiErrorResponse(ApiErrorCode.VALIDATION_REQUIRED, null, "List of ids"));
|
||||||
|
|
||||||
@@ -192,7 +192,7 @@ namespace AyaNova.Api.Controllers
|
|||||||
if (string.IsNullOrWhiteSpace(tag))
|
if (string.IsNullOrWhiteSpace(tag))
|
||||||
return BadRequest(new ApiErrorResponse(ApiErrorCode.VALIDATION_REQUIRED, null, "tag"));
|
return BadRequest(new ApiErrorResponse(ApiErrorCode.VALIDATION_REQUIRED, null, "tag"));
|
||||||
|
|
||||||
await dataListSelection.RehydrateIdList(ct, UserRolesFromContext.Roles(HttpContext.Items), log);
|
await dataListSelection.RehydrateIdList(ct, UserRolesFromContext.Roles(HttpContext.Items), log, UserIdFromContext.Id(HttpContext.Items));
|
||||||
if (dataListSelection.SelectedRowIds.Length == 0)
|
if (dataListSelection.SelectedRowIds.Length == 0)
|
||||||
return BadRequest(new ApiErrorResponse(ApiErrorCode.VALIDATION_REQUIRED, null, "List of ids"));
|
return BadRequest(new ApiErrorResponse(ApiErrorCode.VALIDATION_REQUIRED, null, "List of ids"));
|
||||||
|
|
||||||
@@ -284,7 +284,7 @@ namespace AyaNova.Api.Controllers
|
|||||||
toTag = TagBiz.NormalizeTag(toTag);
|
toTag = TagBiz.NormalizeTag(toTag);
|
||||||
if (string.IsNullOrWhiteSpace(toTag))
|
if (string.IsNullOrWhiteSpace(toTag))
|
||||||
return BadRequest(new ApiErrorResponse(ApiErrorCode.VALIDATION_REQUIRED, null, "toTag"));
|
return BadRequest(new ApiErrorResponse(ApiErrorCode.VALIDATION_REQUIRED, null, "toTag"));
|
||||||
await dataListSelection.RehydrateIdList(ct, UserRolesFromContext.Roles(HttpContext.Items), log);
|
await dataListSelection.RehydrateIdList(ct, UserRolesFromContext.Roles(HttpContext.Items), log, UserIdFromContext.Id(HttpContext.Items));
|
||||||
if (dataListSelection.SelectedRowIds.Length == 0)
|
if (dataListSelection.SelectedRowIds.Length == 0)
|
||||||
return BadRequest(new ApiErrorResponse(ApiErrorCode.VALIDATION_REQUIRED, null, "List of ids"));
|
return BadRequest(new ApiErrorResponse(ApiErrorCode.VALIDATION_REQUIRED, null, "List of ids"));
|
||||||
|
|
||||||
|
|||||||
@@ -16,7 +16,7 @@ namespace AyaNova.DataList
|
|||||||
//CoreBizObject add here
|
//CoreBizObject add here
|
||||||
//well, not here exactly but add a new DATALIST class if it will be displayed as a list anywhere in the UI or reported on
|
//well, not here exactly but add a new DATALIST class if it will be displayed as a list anywhere in the UI or reported on
|
||||||
public AyaDataList()
|
public AyaDataList()
|
||||||
{
|
{
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|
||||||
@@ -26,6 +26,8 @@ namespace AyaNova.DataList
|
|||||||
public AyaType DefaultListObjectType { get; set; }
|
public AyaType DefaultListObjectType { get; set; }
|
||||||
|
|
||||||
public string DefaultListView { get; set; }
|
public string DefaultListView { get; set; }
|
||||||
|
public string AdditionalCriteriaInternalListView { get; set; }
|
||||||
|
public long CurrentUserId { get; set; }
|
||||||
|
|
||||||
|
|
||||||
//return array of field keys in list view
|
//return array of field keys in list view
|
||||||
|
|||||||
@@ -18,7 +18,7 @@ namespace AyaNova.DataList
|
|||||||
// Get the data list data requested
|
// Get the data list data requested
|
||||||
//
|
//
|
||||||
//
|
//
|
||||||
internal static async Task<ApiDataListResponse> GetResponseAsync(string DataListKey, AyContext ct, ListOptions listOptions, AuthorizationRoles UserRoles, ILogger log)
|
internal static async Task<ApiDataListResponse> GetResponseAsync(string DataListKey, AyContext ct, ListOptions listOptions, AuthorizationRoles UserRoles, ILogger log, long userId)
|
||||||
{
|
{
|
||||||
|
|
||||||
var DataList = DataListFactory.GetAyaDataList(DataListKey);
|
var DataList = DataListFactory.GetAyaDataList(DataListKey);
|
||||||
@@ -27,6 +27,7 @@ namespace AyaNova.DataList
|
|||||||
if (DataList == null)
|
if (DataList == null)
|
||||||
throw new System.ArgumentOutOfRangeException($"DataList \"{DataListKey}\" specified does not exist");
|
throw new System.ArgumentOutOfRangeException($"DataList \"{DataListKey}\" specified does not exist");
|
||||||
|
|
||||||
|
|
||||||
//check rights
|
//check rights
|
||||||
if (!UserRoles.HasAnyFlags(DataList.AllowedRoles))
|
if (!UserRoles.HasAnyFlags(DataList.AllowedRoles))
|
||||||
throw new System.UnauthorizedAccessException("User roles insufficient for this datalist");
|
throw new System.UnauthorizedAccessException("User roles insufficient for this datalist");
|
||||||
@@ -39,8 +40,20 @@ namespace AyaNova.DataList
|
|||||||
//This one is for the return list to the Client for grid column display
|
//This one is for the return list to the Client for grid column display
|
||||||
var PublicListViewArray = JArray.Parse(listOptions.ListView);
|
var PublicListViewArray = JArray.Parse(listOptions.ListView);
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
//this one is for internal use here to build the filter and sort etc
|
//this one is for internal use here to build the filter and sort etc
|
||||||
var InternalListViewArray = JArray.Parse(listOptions.ListView);
|
var InternalListViewArray = JArray.Parse(listOptions.ListView);
|
||||||
|
|
||||||
|
//Hard coded extra criteria from server end
|
||||||
|
if (DataList is IAyaDataListViewServerCriteria)
|
||||||
|
{
|
||||||
|
var ServerCriteriaListView = ((IAyaDataListViewServerCriteria)DataList).ListViewServerCriteria(userId);
|
||||||
|
foreach (JToken jt in ServerCriteriaListView)
|
||||||
|
InternalListViewArray.Add(jt);
|
||||||
|
}
|
||||||
|
|
||||||
|
//Hard coded extra criteria from Client end
|
||||||
var MetaListViewArray = JArray.Parse(listOptions.MetaView ?? "[]");
|
var MetaListViewArray = JArray.Parse(listOptions.MetaView ?? "[]");
|
||||||
foreach (JToken jt in MetaListViewArray)
|
foreach (JToken jt in MetaListViewArray)
|
||||||
InternalListViewArray.Add(jt);
|
InternalListViewArray.Add(jt);
|
||||||
@@ -216,13 +229,15 @@ namespace AyaNova.DataList
|
|||||||
// Get a list of id's of the datalist results for reporting
|
// Get a list of id's of the datalist results for reporting
|
||||||
//
|
//
|
||||||
//
|
//
|
||||||
internal static async Task<long[]> GetIdListResponseAsync(string dataListKey, string listView, string metaListView, AyContext ct, AuthorizationRoles userRoles, ILogger log)
|
internal static async Task<long[]> GetIdListResponseAsync(string dataListKey, string listView, string metaListView, AyContext ct, AuthorizationRoles userRoles, ILogger log, long userId)
|
||||||
{
|
{
|
||||||
var DataList = DataListFactory.GetAyaDataList(dataListKey);
|
var DataList = DataListFactory.GetAyaDataList(dataListKey);
|
||||||
//was the name not found as a list?
|
//was the name not found as a list?
|
||||||
if (DataList == null)
|
if (DataList == null)
|
||||||
throw new System.ArgumentOutOfRangeException($"DataList \"{dataListKey}\" specified does not exist");
|
throw new System.ArgumentOutOfRangeException($"DataList \"{dataListKey}\" specified does not exist");
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
//check rights
|
//check rights
|
||||||
if (!userRoles.HasAnyFlags(DataList.AllowedRoles))
|
if (!userRoles.HasAnyFlags(DataList.AllowedRoles))
|
||||||
throw new System.UnauthorizedAccessException("User roles insufficient for this datalist");
|
throw new System.UnauthorizedAccessException("User roles insufficient for this datalist");
|
||||||
@@ -234,6 +249,17 @@ namespace AyaNova.DataList
|
|||||||
//parse the list view
|
//parse the list view
|
||||||
var ListViewArray = JArray.Parse(listView);
|
var ListViewArray = JArray.Parse(listView);
|
||||||
|
|
||||||
|
|
||||||
|
//Hard coded extra criteria from server end
|
||||||
|
if (DataList is IAyaDataListViewServerCriteria)
|
||||||
|
{
|
||||||
|
var ServerCriteriaListView = ((IAyaDataListViewServerCriteria)DataList).ListViewServerCriteria(userId);
|
||||||
|
foreach (JToken jt in ServerCriteriaListView)
|
||||||
|
ListViewArray.Add(jt);
|
||||||
|
}
|
||||||
|
|
||||||
|
//Hard coded extra criteria from Client end
|
||||||
|
//parse and combine any additional listview hard coded from Client UI
|
||||||
var MetaListViewArray = JArray.Parse(metaListView ?? "[]");
|
var MetaListViewArray = JArray.Parse(metaListView ?? "[]");
|
||||||
foreach (JToken jt in MetaListViewArray)
|
foreach (JToken jt in MetaListViewArray)
|
||||||
ListViewArray.Add(jt);
|
ListViewArray.Add(jt);
|
||||||
|
|||||||
@@ -21,6 +21,12 @@ namespace AyaNova.DataList
|
|||||||
//Default / STOCK DataListView when none is specified
|
//Default / STOCK DataListView when none is specified
|
||||||
string DefaultListView { get; set; }
|
string DefaultListView { get; set; }
|
||||||
|
|
||||||
|
//Additional criteria for security or other reasons
|
||||||
|
//hard coded into some lists (e.g. MemoDataList so users can't get other people's memos)
|
||||||
|
// string AdditionalCriteriaInternalListView (long userId);
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
Newtonsoft.Json.Linq.JArray GenerateListColumnsJSONFromListView(JArray listViewArray);
|
Newtonsoft.Json.Linq.JArray GenerateListColumnsJSONFromListView(JArray listViewArray);
|
||||||
List<string> GetFieldListFromListView(JArray listViewArray);
|
List<string> GetFieldListFromListView(JArray listViewArray);
|
||||||
|
|
||||||
|
|||||||
9
server/AyaNova/DataList/IAyaDataListExtraCriteria.cs
Normal file
9
server/AyaNova/DataList/IAyaDataListExtraCriteria.cs
Normal file
@@ -0,0 +1,9 @@
|
|||||||
|
namespace AyaNova.DataList
|
||||||
|
{
|
||||||
|
internal interface IAyaDataListViewServerCriteria
|
||||||
|
{
|
||||||
|
//Additional criteria for security or other reasons
|
||||||
|
//hard coded into some lists (e.g. MemoDataList so users can't get other people's memos)
|
||||||
|
string ListViewServerCriteria (long userId);
|
||||||
|
}
|
||||||
|
}
|
||||||
89
server/AyaNova/DataList/MemoDataList.cs
Normal file
89
server/AyaNova/DataList/MemoDataList.cs
Normal file
@@ -0,0 +1,89 @@
|
|||||||
|
using System.Collections.Generic;
|
||||||
|
using Newtonsoft.Json.Linq;
|
||||||
|
using AyaNova.Biz;
|
||||||
|
namespace AyaNova.DataList
|
||||||
|
{
|
||||||
|
internal class MemoDataList : AyaDataList,IAyaDataListViewServerCriteria
|
||||||
|
{
|
||||||
|
public MemoDataList()
|
||||||
|
{
|
||||||
|
|
||||||
|
DefaultListObjectType = AyaType.Memo;
|
||||||
|
SQLFrom = "from amemo left outer join auser on (amemo.fromid=auser.id)";
|
||||||
|
var RoleSet = BizRoles.GetRoleSet(DefaultListObjectType);
|
||||||
|
AllowedRoles = RoleSet.ReadFullRecord | RoleSet.Change;
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
//######## DEFAULT VIEW WHEN NO VIEW CHOSEN ############
|
||||||
|
//Default ListView
|
||||||
|
dynamic dlistView = new JArray();
|
||||||
|
|
||||||
|
|
||||||
|
dynamic cm = new JObject();
|
||||||
|
cm.fld = "MemoSubject";
|
||||||
|
dlistView.Add(cm);
|
||||||
|
|
||||||
|
cm = new JObject();
|
||||||
|
cm.fld = "MemoFromID";
|
||||||
|
dlistView.Add(cm);
|
||||||
|
|
||||||
|
cm = new JObject();
|
||||||
|
cm.fld = "MemoSent";
|
||||||
|
dlistView.Add(cm);
|
||||||
|
DefaultListView = dlistView.ToString(Newtonsoft.Json.Formatting.None);
|
||||||
|
|
||||||
|
|
||||||
|
//NOTE: Due to the join, all the sql id and name fields that can conflict with the joined table need to be specified completely
|
||||||
|
FieldDefinitions = new List<AyaDataListFieldDefinition>();
|
||||||
|
|
||||||
|
FieldDefinitions.Add(new AyaDataListFieldDefinition
|
||||||
|
{
|
||||||
|
TKey = "User",
|
||||||
|
FieldKey = "username",
|
||||||
|
AyaObjectType = (int)AyaType.User,
|
||||||
|
UiFieldDataType = (int)UiFieldDataType.Text,
|
||||||
|
SqlIdColumnName = "auser.id",
|
||||||
|
SqlValueColumnName = "auser.name",
|
||||||
|
IsRowId = false
|
||||||
|
});
|
||||||
|
|
||||||
|
|
||||||
|
FieldDefinitions.Add(new AyaDataListFieldDefinition
|
||||||
|
{
|
||||||
|
TKey = "MemoNotes",
|
||||||
|
FieldKey = "notes",
|
||||||
|
AyaObjectType = (int)AyaType.Memo,
|
||||||
|
UiFieldDataType = (int)UiFieldDataType.Text,
|
||||||
|
SqlIdColumnName = "amemo.id",
|
||||||
|
SqlValueColumnName = "amemo.notes",
|
||||||
|
IsRowId = true
|
||||||
|
});
|
||||||
|
|
||||||
|
FieldDefinitions.Add(new AyaDataListFieldDefinition
|
||||||
|
{
|
||||||
|
TKey = "MemoNoteDate",
|
||||||
|
FieldKey = "notedate",
|
||||||
|
UiFieldDataType = (int)UiFieldDataType.DateTime,
|
||||||
|
SqlValueColumnName = "amemo.notedate"
|
||||||
|
});
|
||||||
|
|
||||||
|
//META column
|
||||||
|
FieldDefinitions.Add(new AyaDataListFieldDefinition
|
||||||
|
{
|
||||||
|
FieldKey = "metacustomer",
|
||||||
|
SqlIdColumnName = "amemo.customerid",
|
||||||
|
SqlValueColumnName = "amemo.customerid",
|
||||||
|
IsMeta = true
|
||||||
|
});
|
||||||
|
}
|
||||||
|
|
||||||
|
string IAyaDataListViewServerCriteria.ListViewServerCriteria(long userId)
|
||||||
|
{
|
||||||
|
//todo: take user id here and return additional criteria listview
|
||||||
|
throw new System.NotImplementedException();
|
||||||
|
}
|
||||||
|
|
||||||
|
}//eoc
|
||||||
|
}//eons
|
||||||
@@ -598,7 +598,7 @@ namespace AyaNova.Biz
|
|||||||
////////////////////////////////////////////////////////////
|
////////////////////////////////////////////////////////////
|
||||||
//MEMO
|
//MEMO
|
||||||
// (everyone but outside users Customer and HO can send and receive memos)
|
// (everyone but outside users Customer and HO can send and receive memos)
|
||||||
roles.Add(AyaType.Widget, new BizRoleSet()
|
roles.Add(AyaType.Memo, new BizRoleSet()
|
||||||
{
|
{
|
||||||
Change = AuthorizationRoles.AllInsideUserRoles,
|
Change = AuthorizationRoles.AllInsideUserRoles,
|
||||||
ReadFullRecord = AuthorizationRoles.AllInsideUserRoles,
|
ReadFullRecord = AuthorizationRoles.AllInsideUserRoles,
|
||||||
|
|||||||
@@ -331,7 +331,7 @@ namespace AyaNova.Biz
|
|||||||
|
|
||||||
//Do we need to rehydrate the ID List from a DataList?
|
//Do we need to rehydrate the ID List from a DataList?
|
||||||
if (reportDataParam.SelectedRowIds.Length == 0)
|
if (reportDataParam.SelectedRowIds.Length == 0)
|
||||||
reportDataParam.SelectedRowIds = await AyaNova.DataList.DataListFetcher.GetIdListResponseAsync(reportDataParam.DataListKey, reportDataParam.ListView, reportDataParam.MetaView, ct, effectiveRoles, log);
|
reportDataParam.SelectedRowIds = await AyaNova.DataList.DataListFetcher.GetIdListResponseAsync(reportDataParam.DataListKey, reportDataParam.ListView, reportDataParam.MetaView, ct, effectiveRoles, log, UserId);
|
||||||
|
|
||||||
log.LogDebug($"Instantiating biz object handler for {reportDataParam.ObjectType}");
|
log.LogDebug($"Instantiating biz object handler for {reportDataParam.ObjectType}");
|
||||||
var biz = BizObjectFactory.GetBizObject(reportDataParam.ObjectType, ct);
|
var biz = BizObjectFactory.GetBizObject(reportDataParam.ObjectType, ct);
|
||||||
|
|||||||
@@ -22,10 +22,10 @@ namespace AyaNova.Models
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
public async Task RehydrateIdList(AyContext ct, AuthorizationRoles userRoles, Microsoft.Extensions.Logging.ILogger log)
|
public async Task RehydrateIdList(AyContext ct, AuthorizationRoles userRoles, Microsoft.Extensions.Logging.ILogger log, long userId)
|
||||||
{
|
{
|
||||||
if (SelectedRowIds.Length == 0)
|
if (SelectedRowIds.Length == 0)
|
||||||
SelectedRowIds = await AyaNova.DataList.DataListFetcher.GetIdListResponseAsync(DataListKey, ListView, MetaView, ct, userRoles, log);
|
SelectedRowIds = await AyaNova.DataList.DataListFetcher.GetIdListResponseAsync(DataListKey, ListView, MetaView, ct, userRoles, log, userId);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|||||||
@@ -22,8 +22,8 @@ namespace AyaNova.Util
|
|||||||
//!!!!WARNING: BE SURE TO UPDATE THE DbUtil::EmptyBizDataFromDatabaseForSeedingOrImporting WHEN NEW TABLES ADDED!!!!
|
//!!!!WARNING: BE SURE TO UPDATE THE DbUtil::EmptyBizDataFromDatabaseForSeedingOrImporting WHEN NEW TABLES ADDED!!!!
|
||||||
private const int DESIRED_SCHEMA_LEVEL = 15;
|
private const int DESIRED_SCHEMA_LEVEL = 15;
|
||||||
|
|
||||||
internal const long EXPECTED_COLUMN_COUNT = 500;
|
internal const long EXPECTED_COLUMN_COUNT = 511;
|
||||||
internal const long EXPECTED_INDEX_COUNT = 145;
|
internal const long EXPECTED_INDEX_COUNT = 148;
|
||||||
|
|
||||||
//!!!!WARNING: BE SURE TO UPDATE THE DbUtil::EmptyBizDataFromDatabaseForSeedingOrImporting WHEN NEW TABLES ADDED!!!!
|
//!!!!WARNING: BE SURE TO UPDATE THE DbUtil::EmptyBizDataFromDatabaseForSeedingOrImporting WHEN NEW TABLES ADDED!!!!
|
||||||
|
|
||||||
|
|||||||
Reference in New Issue
Block a user