b43653944ddc3f67af813131832e60aacb4b9004
Bernd Wurst Domain-Transfer und -Regist...

Bernd Wurst authored 6 years ago

1) <?php
2) /*
3) This file belongs to the Webinterface of schokokeks.org Hosting
4) 
5) Written 2008-2018 by schokokeks.org Hosting, namely
6)   Bernd Wurst <bernd@schokokeks.org>
7)   Hanno Böck <hanno@schokokeks.org>
8) 
9) To the extent possible under law, the author(s) have dedicated all copyright and related and neighboring rights to this software to the public domain worldwide. This software is distributed without any warranty.
10) 
Hanno Fix coding style with php-c...

Hanno authored 6 years ago

11) You should have received a copy of the CC0 Public Domain Dedication along with this software. If not, see
Bernd Wurst Domain-Transfer und -Regist...

Bernd Wurst authored 6 years ago

12) http://creativecommons.org/publicdomain/zero/1.0/
13) 
14) Nevertheless, in case you use a significant part of this code, we ask (but not require, see the license) that you keep the authors' names in place and return your changes to the public. We would be especially happy if you tell us what you're going to do with this code.
15) */
16) 
17) require_once("class/domain.php");
18) require_once("domains.php");
19) require_once("domainapi.php");
20) require_role(ROLE_CUSTOMER);
21) check_form_token('domains_domainreg');
22) 
Hanno Fix coding style with php-c...

Hanno authored 6 years ago

23) if (! (isset($_SESSION['domains_domainreg_owner']) && $_SESSION['domains_domainreg_owner']) ||
24)     ! (isset($_SESSION['domains_domainreg_admin_c']) && $_SESSION['domains_domainreg_admin_c']) ||
Bernd Wurst Domain-Transfer und -Regist...

Bernd Wurst authored 6 years ago

25)     ! (isset($_SESSION['domains_domainreg_domainname']) && $_SESSION['domains_domainreg_domainname'])) {
26)     system_failure("Fehler im Programmablauf!");
27) }
28) 
29) if (! (isset($_REQUEST['domain']) && $_REQUEST['domain']) ||
30)     $_REQUEST['domain'] != $_SESSION['domains_domainreg_domainname']) {
31)     system_failure("Fehler im Programmablauf!");
32) }
Bernd Wurst hardening domain input (II)

Bernd Wurst authored 6 years ago

33) // Validierung der Domain entfällt hier, weil wir nur bestehende Domain aus der Datenbank laden. Bei ungültiger Eingabe wird kein Treffer gefunden.
Bernd Wurst Domain-Transfer und -Regist...

Bernd Wurst authored 6 years ago

34) $dom = new Domain((string) $_REQUEST['domain']);
35) $dom->ensure_userdomain();
36) 
37) // Speichere Kontakte
38) domain_ownerchange($dom->fqdn, $_SESSION['domains_domainreg_owner'], $_SESSION['domains_domainreg_admin_c']);
39) 
Hanno Fix coding style with php-c...

Hanno authored 6 years ago

40) $authinfo = null;
Bernd Wurst Domain-Transfer und -Regist...

Bernd Wurst authored 6 years ago

41) if ($dom->status == 'pretransfer') {
42)     if (! (isset($_REQUEST['authinfo']) && $_REQUEST['authinfo'])) {
43)         system_failure("Kein Auth-Info-Code angegeben!");
44)     }
45)     $authinfo = chop($_REQUEST['authinfo']);
46) }
47) 
Bernd Wurst send confirmation message u...

Bernd Wurst authored 5 years ago

48) $customerno = (int) $customerno;
49) $customer = get_customer_info($customerno);
50) $msg = 'Sie haben in Ihrem Kundenkonto bei '.config('company_name').' eine Domainregistrierung 
51) in Auftrag gegeben.
52) 
53) Domainname: '.$dom->fqdn.'
54) 
55) Die Registrierung wird umgehend ausgeführt. Bis die Domain vollständig nutzbar ist, 
56) können abhängig von der Domainendung und damit der zuständigen Registrierungsstelle 
57) ein paar Stunden vergehen. Sollten bei der Registrierung Fehler auftreten, werden 
58) die Administratoren direkt darüber informiert und werden sich umgehend darum kümmern.
59) 
60) Mit freundlichen Grüßen,
61) Ihre Admins von '.config('company_name');
62) if ($dom->status == 'pretransfer') {
63)     $msg = 'Sie haben in Ihrem Kundenkonto bei '.config('company_name').' einen Domaintransfer
64) in Auftrag gegeben.
65) 
66) Domainname: '.$dom->fqdn.'
67) 
68) Der Transfer wird umgehend ausgeführt. Bis die Domain vollständig umgezogen ist, 
69) können abhängig von der Domainendung und damit der zuständigen Registrierungsstelle 
70) ein paar Stunden vergehen. Sollten beim Domainumzug Fehler auftreten, werden die 
71) Administratoren direkt darüber informiert und werden sich umgehend darum kümmern.
72) 
73) Mit freundlichen Grüßen,
74) Ihre Admins von '.config('company_name');
75) }
76) 
77) $msg .= "\n\nDiese Bestellung haben wir am ".date("r")." von der IP-Adresse\n{$_SERVER['REMOTE_ADDR']} erhalten.\nSofern Sie dies nicht ausgelöst haben, benachrichtigen Sie bitte den Support\ndurch eine Antwort auf diese E-Mail.";
78) 
79) send_mail($customer['email'], 'Domainregistrierung '.$dom->fqdn, $msg);
80) 
Bernd Wurst Domain-Transfer und -Regist...

Bernd Wurst authored 6 years ago

81) api_register_domain($dom->fqdn, $authinfo);
82) 
83) success_msg('Die Registrierung wurde in Auftrag gegeben. Der Domain-Status sollte sich in den nächsten Minuten entsprechend ändern.');
Bernd Wurst Session aufräumen, Weiterle...

Bernd Wurst authored 6 years ago

84) 
85) unset($_SESSION['domains_domainreg_owner']);
86) unset($_SESSION['domains_domainreg_admin_c']);
87) unset($_SESSION['domains_domainreg_detach']);
88) unset($_SESSION['domains_domainreg_domainname']);
89)