ns.php 2.0 KB

1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859606162636465666768697071727374
  1. <?php
  2. define('SOA_VALUES', [
  3. 'ttl' => 10800,
  4. 'email' => CONF['ns']['public_soa_email'],
  5. 'refresh' => 10800,
  6. 'retry' => 3600,
  7. 'expire' => 3628800,
  8. 'negative' => 10800,
  9. ]);
  10. define('MIN_TTL', 300);
  11. define('DEFAULT_TTL', 10800);
  12. define('MAX_TTL', 1728000);
  13. define('ALLOWED_TYPES', ['AAAA', 'A', 'TXT', 'SRV', 'MX', 'SVCB', 'HTTPS', 'NS', 'DS', 'CAA', 'CNAME', 'DNAME', 'LOC', 'SSHFP', 'TLSA']);
  14. define('ZONE_MAX_CHARACTERS', 10000);
  15. function nsCommonRequirements() {
  16. return (isset($_POST['action'])
  17. AND isset($_POST['zone'])
  18. AND isset($_POST['ttl-value'])
  19. AND isset($_POST['ttl-multiplier'])
  20. AND isset($_SESSION['username'])
  21. );
  22. }
  23. function nsParseCommonRequirements() {
  24. nsCheckZonePossession($_POST['zone']);
  25. if (($_POST['subdomain'] === '') OR ($_POST['subdomain'] === '@'))
  26. $values['domain'] = $_POST['zone'];
  27. else
  28. $values['domain'] = formatAbsoluteDomain(formatEndWithDot($_POST['subdomain']) . $_POST['zone']);
  29. $values['ttl'] = $_POST['ttl-value'] * $_POST['ttl-multiplier'];
  30. if ($values['ttl'] < MIN_TTL)
  31. output(403, 'Les TTLs inférieurs à ' . MIN_TTL . ' secondes ne sont pas autorisés.');
  32. if ($values['ttl'] > MAX_TTL)
  33. output(403, 'Les TTLs supérieurs à ' . MAX_TTL . ' secondes ne sont pas autorisés.');
  34. return $values;
  35. }
  36. function nsListUserZones($username) {
  37. return query('select', 'zones', ['username' => $username], 'zone');
  38. }
  39. function nsCheckZonePossession($zone) {
  40. checkAbsoluteDomainFormat($zone);
  41. if (!in_array($zone, query('select', 'zones', ['username' => $_SESSION['username']], 'zone'), true))
  42. output(403, 'You don\'t own this zone on the nameserver.');
  43. }
  44. function nsDeleteZone($zone) {
  45. // Remove from Knot configuration
  46. knotcConfExec(["unset 'zone[$zone]'"]);
  47. // Remove Knot zone file
  48. if(unlink(CONF['ns']['knot_zones_path'] . '/' . $zone . 'zone') !== true)
  49. output(500, 'Failed to remove Knot zone file.');
  50. // Remove Knot related data
  51. exec(CONF['dns']['knotc_path'] . ' zone-purge ' . $zone);
  52. // Remove from database
  53. query('delete', 'zones', [
  54. 'zone' => $zone,
  55. 'username' => $_SESSION['username'],
  56. ]);
  57. }