7569c300cd09a33bf44aa8714faeda46179ebd12
Bernd Wurst Ermögliche das Ändern eines...

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) 
11) You should have received a copy of the CC0 Public Domain Dedication along with this software. If not, see 
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('inc/debug.php');
18) require_once('inc/icons.php');
19) 
20) require_once('class/domain.php');
21) require_once('domains.php');
Bernd Wurst Alle Domain-Details auf ein...

Bernd Wurst authored 6 years ago

22) require_once('domainapi.php');
Bernd Wurst Ermögliche das Ändern eines...

Bernd Wurst authored 6 years ago

23) 
24) require_role(ROLE_CUSTOMER);
25) 
Bernd Wurst Alle Domain-Details auf ein...

Bernd Wurst authored 6 years ago

26) $dom = NULL;
27) if (isset($_REQUEST['id'])) {
28)     $dom = new Domain( (int) $_REQUEST['id']);
Bernd Wurst Erste Vorbereitungen für Do...

Bernd Wurst authored 6 years ago

29)     $_SESSION['domains_detail_domainname'] = $dom->fqdn;
30) } elseif (isset($_SESSION['domains_detail_domainname'])) {
31)     $dom = new Domain($_SESSION['domains_detail_domainname']);
Bernd Wurst Alle Domain-Details auf ein...

Bernd Wurst authored 6 years ago

32) } else {
33)     system_failure("Keine Domain angegeben");
Bernd Wurst Ermögliche das Ändern eines...

Bernd Wurst authored 6 years ago

34) }
Bernd Wurst Alle Domain-Details auf ein...

Bernd Wurst authored 6 years ago

35) if (!$dom) {
36)     system_failure("Keine Domain gewählt!");
37) }
38) $dom->ensure_customerdomain();
Bernd Wurst Ermögliche das Ändern eines...

Bernd Wurst authored 6 years ago

39) 
40) title("Domain {$dom->fqdn}");
41) $section = 'domains_domains';
42) 
Bernd Wurst Alle Domain-Details auf ein...

Bernd Wurst authored 6 years ago

43) // Block zuständiger Useraccount
44) 
45) $useraccounts = list_useraccounts();
46) if ($_SESSION['role'] & ROLE_CUSTOMER && count($useraccounts) > 1) {
47)     // Mehrere User vorhanden
48)     $options = array();
49)     foreach ($useraccounts as $u) {
50)         $options[$u['uid']] = $u['username'];
51)     }
52)     if (!array_key_exists($dom->useraccount, $options)) {
53)         $options[$dom->useraccount] = $dom->useraccount;
54)     }
55)     output('<h4>Zuständiges Benutzerkonto</h4>');
56)     $form = '<p>Diese Domain nutzen im Benutzerkonto '.html_select('domainuser', $options, $dom->useraccount).' <input type="submit" name="submit" value="Änderung speichern"></p>';
57)     output(html_form('update-user', 'update', 'action=chguser&id='.$dom->id, $form));
Bernd Wurst Ermögliche das Ändern eines...

Bernd Wurst authored 6 years ago

58) }
Bernd Wurst Alle Domain-Details auf ein...

Bernd Wurst authored 6 years ago

59) 
60) 
61) // Block Domain-Inhaber 
62) 
63) if ($dom->provider == 'terions' && ($dom->cancel_date === NULL || $dom->cancel_date > date('Y-m-d'))) {
64)     use_module('contacts');
65)     require_once('contacts.php');
66) 
67)     output('<h4>Inhaberwechsel der Domain</h4>');
68)     output('<p>Legen Sie hier einen neuen Inhaber für diese Domain fest.</p>');
69) 
70)     if (isset($_REQUEST['id'])) {
71)         api_download_domain($_REQUEST['id']);
Bernd Wurst Erste Vorbereitungen für Do...

Bernd Wurst authored 6 years ago

72)         $_SESSION['domains_detail_domainname'] = $dom->fqdn;
73)         $_SESSION['domains_detail_owner'] = $dom->owner;
74)         $_SESSION['domains_detail_admin_c'] = $dom->admin_c;
Bernd Wurst Alle Domain-Details auf ein...

Bernd Wurst authored 6 years ago

75)     }
76)     if (!update_possible($dom->id)) {
77)         warning("Diese Domain verwendet eine unübliche Endung. Daher kann der Inhaber nicht auf diesem Weg verändert werden. Bitte kontaktieren Sie den Support.");
78)     } else {
79) 
Bernd Wurst Erste Vorbereitungen für Do...

Bernd Wurst authored 6 years ago

80)         if ($_SESSION['domains_detail_admin_c'] == $dom->admin_c && 
81)                 $_SESSION['domains_detail_owner'] != $dom->owner && 
82)                 (!isset($_SESSION['domains_detail_detach']) || $_SESSION['domains_detail_detach'] == 0)) {
Bernd Wurst Alle Domain-Details auf ein...

Bernd Wurst authored 6 years ago

83)             // Wenn der Owner geändert wurde, der Admin aber nicht und das detach-Flag 
84)             // nicht gesetzt ist, dann wird der Admin gleich dem Owner gesetzt
Bernd Wurst Erste Vorbereitungen für Do...

Bernd Wurst authored 6 years ago

85)             $_SESSION['domains_detail_admin_c'] = $_SESSION['domains_detail_owner'];
Bernd Wurst Ermögliche das Ändern eines...

Bernd Wurst authored 6 years ago

86)         }
Bernd Wurst Alle Domain-Details auf ein...

Bernd Wurst authored 6 years ago

87) 
88)         if (isset($_GET['admin_c']) && $_GET['admin_c'] == 'none') {
Bernd Wurst Erste Vorbereitungen für Do...

Bernd Wurst authored 6 years ago

89)             $_SESSION['domains_detail_admin_c'] = $_SESSION['domains_detail_owner'];
90)             unset($_SESSION['domains_detail_detach']);
Bernd Wurst Ermögliche das Ändern eines...

Bernd Wurst authored 6 years ago

91)         }
92) 
Bernd Wurst Erste Vorbereitungen für Do...

Bernd Wurst authored 6 years ago

93)         $owner = get_contact($_SESSION['domains_detail_owner']);
94)         $admin_c = get_contact($_SESSION['domains_detail_admin_c']);
Bernd Wurst Alle Domain-Details auf ein...

Bernd Wurst authored 6 years ago

95)         $function = 'Inhaber';
96)         if ($owner['id'] == $admin_c['id']) {
97)             $function .= ' und Verwalter';
98)         }
99)         $cssclass = '';
100)         if ($owner['id'] != $dom->owner) {
101)             $cssclass = 'modified';
102)         }
103)         output('<p><strong>'.$function.':</strong></p>'.display_contact($owner, '', $cssclass));
104)         addnew('choose', 'Neuen Inhaber wählen', "type=owner");
105)         if ($owner['id'] != $admin_c['id']) {
106)             $cssclass = '';
107)             if ($admin_c['id'] != $dom->admin_c) {
108)                 $cssclass = 'modified';
Bernd Wurst Ermögliche das Ändern eines...

Bernd Wurst authored 6 years ago

109)             }
Bernd Wurst Alle Domain-Details auf ein...

Bernd Wurst authored 6 years ago

110)             output('<p><strong>Verwalter:</strong></p>'.display_contact($admin_c, '', $cssclass));
111)             addnew('choose', 'Neuen Verwalter wählen', "type=admin_c");
Bernd Wurst Erste Vorbereitungen für Do...

Bernd Wurst authored 6 years ago

112)             output('<p class="delete">'.internal_link('', 'Keinen separaten Verwalter festlegen', 'admin_c=none').'</p>');
Bernd Wurst Alle Domain-Details auf ein...

Bernd Wurst authored 6 years ago

113)         } else {
114)             addnew('choose', 'Einen separaten Verwalter wählen', "type=admin_c&detach=1");
Bernd Wurst Ermögliche das Ändern eines...

Bernd Wurst authored 6 years ago

115)         }
116) 
117) 
Bernd Wurst Alle Domain-Details auf ein...

Bernd Wurst authored 6 years ago

118)         if ($owner['id'] != $dom->owner || $admin_c['id'] != $dom->admin_c) {
119)             if (isset($_GET['error']) && $_GET['error'] == '1') {
120)                 input_error('Sie müssen der Übertragung explizit zustimmen!');
121)             }
122)             $form = '<p>Es sind Änderungen vorgenommen worden, die noch nicht gespeichert wurden</p>';
123)             $form .= '<p><input type="checkbox" name="accept" value="1" id="accept"><label for="accept"> Ich bestätige, dass ich die nachfolgenden Hinweise zur Kenntnis genommen habe.</p>
124)                 <p>Mit Speichern dieser Änderungen führen Sie möglicherweise einen Inhaberwechsel bei der Domain '.$dom->fqdn.' aus. Inhaberwechsel sind bei einigen Domainendungen (z.B. com/net/org) zustimmungspflichtig vom alten und vom neuen Inhaber. Die Registrierungsstelle kann nach eigenem Ermessen diese Zustimmung per separater E-Mail einfordern. Wird diese Zustimmung nicht oder verspätet erteilt, kann eine Domain gesperrt werden. Dieser Vorgang wird nicht von '.config('company_name').' kontrolliert.</p>
125)                 <p>Sie sind ferner darüber informiert, dass die Adresse des Domaininhabers öffentlich abrufbar ist.</p>';
126)             $form .= '<p><input type="submit" name="sumbit" value="Änderungen speichern und Domaininhaber ändern"></p>';
127)             output(html_form('domains_update', 'update', "action=ownerchange&id=".$dom->id, $form));
128)         } 
Bernd Wurst Ermögliche das Ändern eines...

Bernd Wurst authored 6 years ago

129)     }
130) }
Bernd Wurst Alle Domain-Details auf ein...

Bernd Wurst authored 6 years ago

131) 
132) // Block Externe Domain umziehen
133) 
Bernd Wurst Erste Vorbereitungen für Do...

Bernd Wurst authored 6 years ago

134) if ($dom->status == 'prereg') {
135)     output('<h4>Domain-Registrierung abschließen</h4>
136)             <p>'.internal_link('domainreg', 'Domain registrieren', "domain={$dom->fqdn}").'</p>');
137) } elseif ($dom->status == 'pretransfer') {
Bernd Wurst Transfer-Freigabe und Kündi...

Bernd Wurst authored 6 years ago

138)     output('<h4>Domain zu '.config('company_name').' umziehen</h4>
Bernd Wurst Erste Vorbereitungen für Do...

Bernd Wurst authored 6 years ago

139)             <p>'.internal_link('domainreg', 'Umzugsautrag (ggf. nochmals) erteilen', "domain={$dom->fqdn}").'</p>');
140) } elseif ($dom->provider != 'terions') {
Bernd Wurst Transfer-Freigabe und Kündi...

Bernd Wurst authored 6 years ago

141)     output('<h4>Domain zu '.config('company_name').' umziehen</h4>
142)             <p>'.internal_link('domainreg', 'Domain-Transfer starten', "domain={$dom->fqdn}").'</p>');
Bernd Wurst Alle Domain-Details auf ein...

Bernd Wurst authored 6 years ago

143) }
144) 
Bernd Wurst Transfer-Freigabe und Kündi...

Bernd Wurst authored 6 years ago

145) 
146) // Block Domain löschen/kündigen
147) 
148) $domain_in_use = mailman_subdomains($dom->id) || mail_in_use($dom->id) || web_in_use($dom->id) || $dom->jabber == 1;
149) if (!$domain_in_use && ($dom->status == 'prereg' || $dom->status == 'pretransfer' || $dom->status == 'transferfailed' || $dom->status == 'external')) {
150)     output('<h4>Domain wieder entfernen</h4>');
151)     output('<p class="delete">'.internal_link('save', 'Die Domain '.$dom->fqdn.' entfernen', 'action=delete&domain='.$dom->id).'</p>');
152) } elseif ($dom->provider == 'terions') {
153)     output('<h4>Domain kündigen</h4>');
154)     $info = api_download_domain($dom->id);
155)     if ($info['authInfo']) {
156)         output('<p>Das Auth-Info für diese Domain lautet: <strong>'.$info['authInfo'].'</strong></p>');
157)         output('<p>Wenden Sie sich an den Support, wenn Sie den Domainumzug wieder sperren möchten.</p>');
158)     } else {
159)         output('<p>Hier können Sie die Domain zum Umzug freigeben.</p>');
160)         $form = '<p><input type="hidden" name="domain" value="'.$dom->id.'"><input type="submit" name="submit" value="Die Domain '.$dom->fqdn.' zum Umzug freigeben"></p>';
161)         output(html_form('domains_transfer', 'save', 'action=transfer', $form));
162)     }
163)     output('<p>Die aktuelle Laufzeit der Domain dauert noch bis '.$info['currentContractPeriodEnd'].'</p>');
164)     if ($info['deletionDate']) {
165)         output('<p>Es liegt aktuell eine Kündigung vor auf <strong>'.$info['deletionDate'].'</strong></p><p>Um die Kündigung aufzuheben, wenden Sie sich bitte an den Support.</p>');
166)     } else {
167)         output('<p class="delete">'.internal_link('save', 'Die Domain '.$dom->fqdn.' kündigen', 'action=cancel&domain='.$dom->id).'</p>');
168)     }
169) }
170) 
171) 
Bernd Wurst Alle Domain-Details auf ein...

Bernd Wurst authored 6 years ago

172) // Block Domain bestätigen
173) 
Bernd Wurst Erste Vorbereitungen für Do...

Bernd Wurst authored 6 years ago

174) if ($dom->mailserver_lock == 1 && $dom->status != 'prereg') {
Bernd Wurst Alle Domain-Details auf ein...

Bernd Wurst authored 6 years ago

175)     if (has_own_ns($dom->domainname, $dom->tld)) {
176)         unset_mailserver_lock($dom);
177)         success_msg("Die Domain {$dom->fqdn} wurde erfolgreich bestätigt und kann nun in vollem Umfang verwendet werden.");
178)         redirect("");
179)     }
180)     output('<h3>Mailserver-Sperre aktiv</h3>
181)             <p>Bisher ist für diese Domain die Nutzung als Mail-Domain eingeschränkt, da wir noch keine Gewissheit haben, ob Sie der rechtmäßige Nutzer der Domain sind. Eine Domain, die für E-Mail-Aktivität genutzt werden soll, muss entweder die DNS-Server von '.config('company_name').' verwenden oder die Inhaberschaft muss durch einen passend gesetzten DNS-Record nachgewiesen werden. Nachfolgend werden die Möglichkeiten im Detail vorgestellt.</p>');
182)     if (!$dom->secret) {
183)         create_domain_secret($dom);
184)     }
185) 
186)     $TXT = get_txt_record('_schokokeks', $dom->domainname, $dom->tld);
187)     if ($TXT == $dom->secret) {
188)         unset_mailserver_lock($dom);
189)         success_msg("Die Domain {$dom->fqdn} wurde erfolgreich bestätigt und kann nun in vollem Umfang verwendet werden.");
Bernd Wurst Lasse die API bestimmen was...

Bernd Wurst authored 6 years ago

190)         redirect("");