settings-settings-logs.php 3.1 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100
  1. <?php
  2. $GLOBALS['organizrPages'][] = 'settings_settings_logs';
  3. function get_page_settings_settings_logs($Organizr)
  4. {
  5. if (!$Organizr) {
  6. $Organizr = new Organizr();
  7. }
  8. if ((!$Organizr->hasDB())) {
  9. return false;
  10. }
  11. if (!$Organizr->qualifyRequest(1, true)) {
  12. return false;
  13. }
  14. $logsDropdown = $Organizr->buildLogDropdown();
  15. return '
  16. <div class="btn-group m-b-20 pull-left">' . $logsDropdown . '</div>
  17. <button class="btn btn-danger waves-effect waves-light pull-right purgeLog" type="button" data-toggle="tooltip" data-placement="bottom" title="" data-original-title="Purge Log"><i class="fa fa-trash"></i></span></button>
  18. <button onclick="organizrLogTable.clear().draw().ajax.reload(null, false)" class="btn btn-info waves-effect waves-light pull-right reloadLog m-r-5" type="button" data-toggle="tooltip" data-placement="bottom" title="" data-original-title="Reload Log"><i class="fa fa-refresh"></i></span></button>
  19. <button onclick="toggleKillOrganizrLiveUpdate(' . $Organizr->config['logLiveUpdateRefresh'] . ');" class="btn btn-primary waves-effect waves-light pull-right organizr-log-live-update m-r-5" type="button" data-toggle="tooltip" data-placement="bottom" title="" data-original-title="Live Update"><i class="fa fa-clock-o"></i></span></button>
  20. <div class="clearfix"></div>
  21. <div class="white-box bg-org logTable orgLogDiv">
  22. <h3 class="box-title m-b-0" lang="en">Organizr Logs</h3>
  23. <div class="table-responsive">
  24. <table id="organizrLogTable" class="table table-striped compact nowrap">
  25. <thead>
  26. <tr>
  27. <th lang="en">Date</th>
  28. <th lang="en">Severity</th>
  29. <th lang="en">Function</th>
  30. <th lang="en">Message</th>
  31. <th lang="en">IP Address</th>
  32. <th lang="en">User</th>
  33. <th></th>
  34. </tr>
  35. </thead>
  36. <tbody></tbody>
  37. </table>
  38. </div>
  39. </div>
  40. <!-- /.container-fluid -->
  41. <script>
  42. clearTimeout(timeouts[\'organizr-log\']);
  43. $.fn.dataTable.ext.errMode = "none";
  44. var organizrLogTable = $("#organizrLogTable")
  45. .on("error.dt", function(e, settings, techNote, message) {
  46. console.log("An error has been reported by DataTables: ", message);
  47. organizrLogTable.draw();
  48. })
  49. .DataTable({
  50. "ajax": {
  51. "url": "api/v2/log/0",
  52. "dataSrc": function(json) {
  53. return json.response.data.results;
  54. }
  55. },
  56. "deferRender": true,
  57. "pageLength": ' . (int)$Organizr->config['logPageSize'] . ',
  58. "columns": [{
  59. data: "datetime",
  60. render: function(data, type, row) {
  61. if (type === "display" || type === "filter") {
  62. var m = moment.tz(data + "Z", activeInfo.timezone);
  63. return moment(m).format("LLL");
  64. }
  65. return data;
  66. }
  67. }, {
  68. data: "log_level",
  69. render: function(data, type, row) {
  70. if (type === "display" || type === "filter") {
  71. return logIcon(data);
  72. }
  73. return logIcon(data);
  74. }
  75. }, {
  76. data: "channel"
  77. }, {
  78. data: "message"
  79. }, {
  80. data: "remote_ip_address",
  81. "width": "5%",
  82. render: function(data, type, row) {
  83. return ipInfoSpan(data);
  84. }
  85. }, {
  86. "data": "trace_id"
  87. }, {
  88. data: "context",
  89. render: function(data, type, row) {
  90. return logContext(row);
  91. },
  92. orderable: false
  93. }, ],
  94. "order": [
  95. [0, "desc"]
  96. ],
  97. })
  98. </script>
  99. ';
  100. }