animalTestSubmit.php 2.9 KB

1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859606162636465666768697071727374757677787980818283848586878889909192939495
  1. <?php
  2. /**
  3. * controllers/animalTestSubmit.php
  4. *
  5. * Handles POST submission of animal dietary balance test data.
  6. * Replaces dashboard/crop-analysis/animal-dietary-balance/animal-submit.php
  7. */
  8. if (session_status() === PHP_SESSION_NONE) {
  9. session_start();
  10. }
  11. require_once __DIR__ . '/../config/database.php';
  12. require_once __DIR__ . '/../lib/auth.php';
  13. require_once __DIR__ . '/../lib/csrf.php';
  14. requireLogin();
  15. if ($_SERVER['REQUEST_METHOD'] !== 'POST') {
  16. header('Location: /dashboard/crop-analysis/animal-dietary-balance/');
  17. exit;
  18. }
  19. if (!verifyCsrfToken($_POST['csrf_token'] ?? '')) {
  20. http_response_code(403);
  21. exit('Invalid security token.');
  22. }
  23. $pdo = getDBConnection();
  24. $userId = getCurrentUserId();
  25. $date = date('Y-m-d');
  26. $rand = mt_rand(10000, 99999);
  27. $str = fn($key) => trim($_POST[$key] ?? '');
  28. $num = fn($key) => is_numeric($_POST[$key] ?? '') ? (float) $_POST[$key] : null;
  29. // Collect POST fields
  30. $email = $str('email');
  31. $clientName = $str('name');
  32. $siteAddress = $str('site_address');
  33. $statePostcode = $str('state_postcode');
  34. $analysisType = $str('analysis_type');
  35. $labNo = $str('lab_no');
  36. $dateSampled = $str('date_sampled') ?: null;
  37. $sampleId = $str('sample_id');
  38. $cropType = $str('crop_type');
  39. $n = $str('n'); $p = $str('p'); $k = $str('k');
  40. $s = $str('s'); $mg = $str('mg'); $ca = $str('ca');
  41. $na = $str('na'); $fe = $str('fe'); $mn = $str('mn');
  42. $zn = $str('zn'); $cu = $str('cu'); $b = $str('b');
  43. $mo = $str('mo'); $co = $str('co'); $se = $str('se');
  44. $cl = $str('cl');
  45. // meq/100g calculations
  46. $kNum = (float) $k;
  47. $sNum = (float) $s;
  48. $caNum = (float) $ca;
  49. $mgNum = (float) $mg;
  50. $naNum = (float) $na;
  51. $clNum = (float) $cl;
  52. $kMeq = $kNum / 390;
  53. $sMeq = $sNum / 100000 * 33333 * 1.11;
  54. $caMeq = $caNum / 200;
  55. $mgMeq = $mgNum / 120;
  56. $naMeq = $naNum / 230;
  57. $clMeq = $clNum / 100000 * 448.34 * 1.11;
  58. $stmt = $pdo->prepare('
  59. INSERT INTO animal_records
  60. (client_records_id, modx_user_id, date, email, client_name, site_address,
  61. state_postcode, analysis_type, lab_no, date_sampled, sample_id, crop_type,
  62. n, p, k, s, mg, ca, na, fe, mn, zn, cu, b, mo, co, se, cl,
  63. k_meq, s_meq, ca_meq, mg_meq, na_meq, cl_meq, rand)
  64. VALUES
  65. (0, ?, ?, ?, ?, ?, ?, ?, ?, ?, ?, ?,
  66. ?, ?, ?, ?, ?, ?, ?, ?, ?, ?, ?, ?, ?, ?, ?, ?,
  67. ?, ?, ?, ?, ?, ?, ?)
  68. ');
  69. $stmt->execute([
  70. $userId, $date, $email, $clientName, $siteAddress,
  71. $statePostcode, $analysisType, $labNo, $dateSampled, $sampleId, $cropType,
  72. $n, $p, $k, $s, $mg, $ca, $na, $fe, $mn, $zn, $cu, $b, $mo, $co, $se, $cl,
  73. $kMeq, $sMeq, $caMeq, $mgMeq, $naMeq, $clMeq, $rand,
  74. ]);
  75. $insertId = (int) $pdo->lastInsertId();
  76. header('Location: /dashboard/crop-analysis/animal-dietary-balance/?rand=' . $rand
  77. . '&cid=' . urlencode($sampleId)
  78. . '&rid=' . $insertId
  79. . '&stid=' . urlencode($cropType));
  80. exit;