ns.inc.php 2.0 KB

12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455565758596061626364656667686970717273747576777879808182
  1. <?php
  2. if (strpos($_SERVER['PHP_SELF'], "inc.php") !== false)
  3. exit("This file is meant to be included.");
  4. function nsCommonRequirements() {
  5. if (isset($_POST['action'])
  6. AND isset($_POST['zone'])
  7. AND isset($_POST['ttl-value'])
  8. AND isset($_POST['ttl-multiplier'])
  9. AND isset($_SESSION['username'])
  10. ) {
  11. return true;
  12. }
  13. }
  14. function nsParseCommonRequirements() {
  15. $values['action'] = checkAction($_POST['action']);
  16. nsCheckZonePossession($_POST['zone']);
  17. if (($_POST['subdomain'] === "") OR ($_POST['subdomain'] === "@"))
  18. $values['domain'] = $_POST['zone'];
  19. else
  20. $values['domain'] = $_POST['subdomain'] . "." . $_POST['zone'];
  21. checkAbsoluteDomainFormat($values['domain']);
  22. $values['ttl'] = $_POST['ttl-value'] * $_POST['ttl-multiplier'];
  23. if (!($values['ttl'] >= 300 AND $values['ttl'] <= 432000))
  24. exit("Erreur : le TTL doit être compris entre 5 minutes et 5 jours (entre 300 et 432000 secondes)");
  25. return $values;
  26. }
  27. function nsListUserZones($username) {
  28. $db = new PDO('sqlite:' . DB_PATH);
  29. $usernameArray[0] = $username;
  30. $op = $db->prepare('SELECT zone FROM zones WHERE username = ?');
  31. $op->execute($usernameArray);
  32. $data = $op->fetch();
  33. if (isset($data['zone']))
  34. $zone = $data['zone'];
  35. else
  36. $zone = NULL;
  37. $i = 0;
  38. $zones = NULL;
  39. while ($zone != NULL) {
  40. $zones[$i] = $zone;
  41. $i++;
  42. $data = $op->fetch();
  43. if (isset($data['zone']))
  44. $zone = $data['zone'];
  45. else
  46. $zone = NULL;
  47. }
  48. return $zones;
  49. }
  50. function nsCheckZonePossession($submittedZone) {
  51. checkAbsoluteDomainFormat($submittedZone);
  52. $db = new PDO('sqlite:' . DB_PATH);
  53. $username[0] = $_SESSION['username'];
  54. $op = $db->prepare('SELECT zone FROM zones WHERE username = ?');
  55. $op->execute($username);
  56. $dbZone = $op->fetch()['zone'];
  57. while ($dbZone != NULL) {
  58. if ($dbZone === $submittedZone) return;
  59. $dbZone = $op->fetch()['zone'];
  60. }
  61. // If there is no entry in the database for the user matching the submitted zone
  62. exit("ERROR: You don't own this zone on the nameserver");
  63. }