You can not select more than 25 topics Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.

192 lines
6.3 KiB

  1. package controller.admin;
  2. import haxe.web.Dispatch;
  3. import Common;
  4. class Admin extends Controller {
  5. public function new() {
  6. super();
  7. view.category = 'admin';
  8. // trigger a "Nav" event
  9. var nav = new Array<Link>();
  10. var e = Nav(nav, "admin");
  11. app.event(e);
  12. view.nav = e.getParameters()[0];
  13. }
  14. @tpl("admin/default.mtt")
  15. function doDefault() {
  16. view.now = Date.now();
  17. }
  18. @tpl("admin/emails.mtt")
  19. function doEmails() {
  20. var browse = function(index:Int, limit:Int) {
  21. return sugoi.db.BufferedMail.manager.search($sdate == null, {limit: [index, limit], orderBy: -cdate}, false);
  22. }
  23. var count = sugoi.db.BufferedMail.manager.count($sdate == null);
  24. view.browser = new sugoi.tools.ResultsBrowser(count, 10, browse);
  25. view.num = count;
  26. }
  27. @tpl("form.mtt")
  28. function doSmtp() {
  29. var f = new sugoi.form.Form("emails");
  30. var data = [{label: "SMTP", value: "smtp"}, {label: "Mandrill API", value: "mandrill"},];
  31. var mailer = sugoi.db.Variable.get("mailer") == null ? "smtp" : sugoi.db.Variable.get("mailer");
  32. var host = sugoi.db.Variable.get("smtp_host") == null ? "<SMTP_SERVER>" : sugoi.db.Variable.get("smtp_host");
  33. var port = sugoi.db.Variable.get("smtp_port") == null ? "587" : sugoi.db.Variable.get("smtp_port");
  34. var user = sugoi.db.Variable.get("smtp_user") == null ? "" : sugoi.db.Variable.get("smtp_user");
  35. var pass = sugoi.db.Variable.get("smtp_pass") == null ? "" : sugoi.db.Variable.get("smtp_pass");
  36. f.addElement(new sugoi.form.elements.StringSelect("mailer", "Mailer", data, mailer));
  37. f.addElement(new sugoi.form.elements.StringInput("smtp_host", "host", host));
  38. f.addElement(new sugoi.form.elements.StringInput("smtp_port", "port", port));
  39. f.addElement(new sugoi.form.elements.StringInput("smtp_user", "user", user));
  40. f.addElement(new sugoi.form.elements.StringInput("smtp_pass", "pass", pass));
  41. if (f.isValid()) {
  42. for (k in ["mailer", "smtp_host", "smtp_port", "smtp_user", "smtp_pass"]) {
  43. sugoi.db.Variable.set(k, f.getValueOf(k));
  44. }
  45. throw Ok("/admin/emails", t._("Configuration updated"));
  46. }
  47. view.title = t._("Email service configuration");
  48. view.form = f;
  49. }
  50. function doPlugins(d:Dispatch) {
  51. d.dispatch(new controller.admin.Plugins());
  52. }
  53. @tpl("admin/taxo.mtt")
  54. function doTaxo() {
  55. view.categ = db.TxpCategory.manager.all();
  56. }
  57. /**
  58. * Display errors logged in DB
  59. */
  60. @tpl("admin/errors.mtt")
  61. function doErrors(args:{?user:Int, ?like:String, ?empty:Bool}) {
  62. view.now = Date.now();
  63. view.u = args.user != null ? db.User.manager.get(args.user, false) : null;
  64. view.like = args.like != null ? args.like : "";
  65. var sql = "";
  66. if (args.user != null)
  67. sql += " AND uid=" + args.user;
  68. // if( args.like!=null && args.like != "" ) sql += " AND error like "+sys.db.Manager.cnx.quote("%"+args.like+"%");
  69. if (args.empty) {
  70. sys.db.Manager.cnx.request("truncate table Error");
  71. }
  72. var errorsStats = sys.db.Manager.cnx.request("select count(id) as c, DATE_FORMAT(date,'%y-%m-%d') as day from Error where date > NOW()- INTERVAL 1 MONTH "
  73. + sql
  74. + " group by day order by day")
  75. .results();
  76. view.errorsStats = errorsStats;
  77. view.browser = new sugoi.tools.ResultsBrowser(sugoi.db.Error.manager.unsafeCount("SELECT count(*) FROM Error WHERE 1 " + sql), 20,
  78. function(start, limit) {
  79. return sugoi.db.Error.manager.unsafeObjects("SELECT * FROM Error WHERE 1 " + sql + " ORDER BY date DESC LIMIT " + start + "," + limit, false);
  80. });
  81. }
  82. @tpl("admin/graph.mtt")
  83. function doGraph(?key:String, ?year:Int, ?month:Int) {
  84. var from = new Date(year, month, 1, 0, 0, 0);
  85. var to = new Date(year, month + 1, 0, 23, 59, 59);
  86. if (app.params.exists("recompute")) {
  87. switch (key) {
  88. case "basket":
  89. for (d in 1...to.getDate()) {
  90. var _from = new Date(year, month, d, 0, 0, 0);
  91. var _to = new Date(year, month, d, 23, 59, 59);
  92. var value = db.Basket.manager.count($cdate >= _from && $cdate <= _to);
  93. var g = db.Graph.record(key, value, _from);
  94. // trace(value,_from,g);
  95. }
  96. }
  97. }
  98. var data = db.Graph.getRange(key, from, to);
  99. view.data = data;
  100. view.from = from;
  101. view.to = to;
  102. view.key = key;
  103. var averageValue = 0.0;
  104. var total = 0.0;
  105. for (d in data)
  106. total += d.value;
  107. averageValue = total / data.length;
  108. view.total = total;
  109. view.averageValue = averageValue;
  110. }
  111. function doFixDistribValidation() {
  112. Sys.println("===== Liste des distributions ayant été re-validées ====<br>");
  113. // Get the current group
  114. var group = app.user.amap;
  115. // Get all the contracts for this given group
  116. var contractIds = Lambda.map(group.getContracts(), function(x) return x.id);
  117. // Get all the validated distributions for this given group
  118. var validatedDistribs = db.Distribution.manager.search(($contractId in contractIds) && $validated == true, {orderBy: date}, false);
  119. for (distrib in validatedDistribs) {
  120. service.PaymentService.validateDistribution(distrib);
  121. Sys.println(distrib.toString() + "<br>");
  122. }
  123. Sys.println("===== Fin de la liste ====");
  124. }
  125. function doCheckDistribValidation() {
  126. Sys.println("===== Liste des distributions validées ayant des opérations/paiements non validés ====<br>");
  127. // Get the current group
  128. var group = app.user.amap;
  129. // Get all the contracts for this given group
  130. var contractIds = Lambda.map(group.getContracts(), function(x) return x.id);
  131. // Get all the validated distributions for this given group
  132. var validatedDistribs = db.Distribution.manager.search(($contractId in contractIds) && $validated == true, {orderBy: date}, false);
  133. for (distrib in validatedDistribs) {
  134. for (user in distrib.getUsers()) {
  135. var basket = db.Basket.get(user, distrib.place, distrib.date);
  136. if (basket == null || basket.isValidated())
  137. continue;
  138. for (order in basket.getOrders()) {
  139. if (!order.paid) {
  140. Sys.println(order.distribution.toString() + "<br>");
  141. Sys.println(order.toString() + "<br>");
  142. }
  143. }
  144. var operation = basket.getOrderOperation(false);
  145. if (operation != null) {
  146. if (operation.pending) {
  147. Sys.println(distrib.toString() + "<br>");
  148. Sys.println(operation.toString() + "<br>");
  149. }
  150. for (payment in basket.getPayments()) {
  151. if (payment.pending) {
  152. Sys.println(distrib.toString() + "<br>");
  153. Sys.println(payment.toString() + "<br>");
  154. }
  155. }
  156. }
  157. }
  158. }
  159. Sys.println("===== Fin de la liste ====");
  160. }
  161. }