Logs page now has paging (#136)
This commit is contained in:
@@ -13,9 +13,9 @@ namespace gaseous_server.Controllers
|
|||||||
{
|
{
|
||||||
[HttpGet]
|
[HttpGet]
|
||||||
[ProducesResponseType(StatusCodes.Status200OK)]
|
[ProducesResponseType(StatusCodes.Status200OK)]
|
||||||
public List<Logging.LogItem> Logs()
|
public List<Logging.LogItem> Logs(long? StartIndex, int PageNumber = 1, int PageSize = 100)
|
||||||
{
|
{
|
||||||
return Logging.GetLogs();
|
return Logging.GetLogs(StartIndex, PageNumber, PageSize);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
@@ -7,30 +7,53 @@
|
|||||||
|
|
||||||
</table>
|
</table>
|
||||||
|
|
||||||
|
<div style="width: 960px; text-align: center;">
|
||||||
|
<button value="Load More" onclick="loadLogs(lastStartIndex, currentPage);">Load More</button>
|
||||||
|
</div>
|
||||||
|
|
||||||
<script type="text/javascript">
|
<script type="text/javascript">
|
||||||
function loadLogs() {
|
var lastStartIndex = 0;
|
||||||
|
var currentPage = 1;
|
||||||
|
|
||||||
|
function loadLogs(StartIndex, PageNumber) {
|
||||||
|
var apiQuery = '';
|
||||||
|
|
||||||
|
if (StartIndex && PageNumber) {
|
||||||
|
currentPage += 1;
|
||||||
|
apiQuery = '?StartIndex=' + StartIndex + '&PageNumber=' + PageNumber;
|
||||||
|
} else {
|
||||||
|
currentPage = 1;
|
||||||
|
}
|
||||||
|
|
||||||
ajaxCall(
|
ajaxCall(
|
||||||
'/api/v1/Logs',
|
'/api/v1/Logs' + apiQuery,
|
||||||
'GET',
|
'GET',
|
||||||
function (result) {
|
function (result) {
|
||||||
var newTable = document.getElementById('settings_events_table');
|
var newTable = document.getElementById('settings_events_table');
|
||||||
newTable.innerHTML = '';
|
if (currentPage == 1) {
|
||||||
newTable.appendChild(
|
newTable.innerHTML = '';
|
||||||
createTableRow(
|
|
||||||
true,
|
newTable.appendChild(
|
||||||
[
|
createTableRow(
|
||||||
['Event Time', 'logs_table_cell_150px'],
|
true,
|
||||||
['Severity', 'logs_table_cell_150px'],
|
[
|
||||||
'Process',
|
//'Id',
|
||||||
'Message'
|
['Event Time', 'logs_table_cell_150px'],
|
||||||
],
|
['Severity', 'logs_table_cell_150px'],
|
||||||
'',
|
'Process',
|
||||||
''
|
'Message'
|
||||||
)
|
],
|
||||||
);
|
'',
|
||||||
|
''
|
||||||
|
)
|
||||||
|
);
|
||||||
|
}
|
||||||
|
|
||||||
for (var i = 0; i < result.length; i++) {
|
for (var i = 0; i < result.length; i++) {
|
||||||
|
lastStartIndex = result[i].id;
|
||||||
|
|
||||||
var newRow = [
|
var newRow = [
|
||||||
|
//result[i].id,
|
||||||
moment(result[i].eventTime).fromNow(),
|
moment(result[i].eventTime).fromNow(),
|
||||||
result[i].eventType,
|
result[i].eventType,
|
||||||
result[i].process,
|
result[i].process,
|
||||||
|
@@ -111,17 +111,30 @@ namespace gaseous_tools
|
|||||||
File.AppendAllText(Config.LogFilePath, TraceOutput);
|
File.AppendAllText(Config.LogFilePath, TraceOutput);
|
||||||
}
|
}
|
||||||
|
|
||||||
static public List<LogItem> GetLogs()
|
static public List<LogItem> GetLogs(long? StartIndex, int PageNumber = 1, int PageSize = 100)
|
||||||
{
|
{
|
||||||
Database db = new gaseous_tools.Database(Database.databaseType.MySql, Config.DatabaseConfiguration.ConnectionString);
|
Database db = new gaseous_tools.Database(Database.databaseType.MySql, Config.DatabaseConfiguration.ConnectionString);
|
||||||
string sql = "SELECT * FROM ServerLogs ORDER BY Id DESC";
|
string sql = "";
|
||||||
DataTable dataTable = db.ExecuteCMD(sql);
|
if (StartIndex == null)
|
||||||
|
{
|
||||||
|
sql = "SELECT * FROM ServerLogs ORDER BY Id DESC LIMIT @PageSize OFFSET @PageNumber;";
|
||||||
|
}
|
||||||
|
else
|
||||||
|
{
|
||||||
|
sql = "SELECT * FROM ServerLogs WHERE Id < @StartIndex ORDER BY Id DESC LIMIT @PageSize OFFSET @PageNumber;";
|
||||||
|
}
|
||||||
|
Dictionary<string, object> dbDict = new Dictionary<string, object>();
|
||||||
|
dbDict.Add("StartIndex", StartIndex);
|
||||||
|
dbDict.Add("PageNumber", (PageNumber - 1) * PageSize);
|
||||||
|
dbDict.Add("PageSize", PageSize);
|
||||||
|
DataTable dataTable = db.ExecuteCMD(sql, dbDict);
|
||||||
|
|
||||||
List<LogItem> logs = new List<LogItem>();
|
List<LogItem> logs = new List<LogItem>();
|
||||||
foreach (DataRow row in dataTable.Rows)
|
foreach (DataRow row in dataTable.Rows)
|
||||||
{
|
{
|
||||||
LogItem log = new LogItem
|
LogItem log = new LogItem
|
||||||
{
|
{
|
||||||
|
Id = (long)row["Id"],
|
||||||
EventTime = DateTime.Parse(((DateTime)row["EventTime"]).ToString("yyyy-MM-ddThh:mm:ss") + 'Z'),
|
EventTime = DateTime.Parse(((DateTime)row["EventTime"]).ToString("yyyy-MM-ddThh:mm:ss") + 'Z'),
|
||||||
EventType = (LogType)row["EventType"],
|
EventType = (LogType)row["EventType"],
|
||||||
Process = (string)row["Process"],
|
Process = (string)row["Process"],
|
||||||
@@ -145,6 +158,7 @@ namespace gaseous_tools
|
|||||||
|
|
||||||
public class LogItem
|
public class LogItem
|
||||||
{
|
{
|
||||||
|
public long Id { get; set; }
|
||||||
public DateTime EventTime { get; set; }
|
public DateTime EventTime { get; set; }
|
||||||
public LogType? EventType { get; set; }
|
public LogType? EventType { get; set; }
|
||||||
public string Process { get; set; } = "";
|
public string Process { get; set; } = "";
|
||||||
|
Reference in New Issue
Block a user