b2ad7569cf15b7ca49876dc8121fd612e78695c4
Bernd Wurst In neues Modul ausgelagert

Bernd Wurst authored 6 years ago

modules/handles/include/handles.php     1) <?php
modules/handles/include/handles.php     2) /*
modules/handles/include/handles.php     3) This file belongs to the Webinterface of schokokeks.org Hosting
modules/handles/include/handles.php     4) 
Bernd Wurst Copyright year update

Bernd Wurst authored 6 years ago

modules/handles/include/handles.php     5) Written 2008-2018 by schokokeks.org Hosting, namely
Bernd Wurst In neues Modul ausgelagert

Bernd Wurst authored 6 years ago

modules/handles/include/handles.php     6)   Bernd Wurst <bernd@schokokeks.org>
modules/handles/include/handles.php     7)   Hanno Böck <hanno@schokokeks.org>
modules/handles/include/handles.php     8) 
modules/handles/include/handles.php     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.
modules/handles/include/handles.php    10) 
modules/handles/include/handles.php    11) You should have received a copy of the CC0 Public Domain Dedication along with this software. If not, see 
modules/handles/include/handles.php    12) http://creativecommons.org/publicdomain/zero/1.0/
modules/handles/include/handles.php    13) 
modules/handles/include/handles.php    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.
modules/handles/include/handles.php    15) */
modules/handles/include/handles.php    16) 
modules/handles/include/handles.php    17) require_once('inc/debug.php');
modules/handles/include/handles.php    18) require_role(array(ROLE_CUSTOMER));
Bernd Wurst Security

Bernd Wurst authored 6 years ago

modules/contacts/include/contacts.php  19) require_once('class/domain.php');
Bernd Wurst In neues Modul ausgelagert

Bernd Wurst authored 6 years ago

modules/handles/include/handles.php    20) 
Bernd Wurst Setzen als Kundenkontakte e...

Bernd Wurst authored 6 years ago

modules/contacts/include/contacts.php  21) require_once('contactapi.php');
Bernd Wurst API-Funktionen um Kontakte...

Bernd Wurst authored 6 years ago

modules/contacts/include/contacts.php  22) 
Bernd Wurst $usage ist ein array

Bernd Wurst authored 6 years ago

modules/handles/include/handles.php    23) /*
Bernd Wurst Kontakt kopieren

Bernd Wurst authored 6 years ago

modules/contacts/include/contacts.php  24) Todo:
modules/contacts/include/contacts.php  25)     - "separate Rechnungsadresse einrichten" / "Zusätzliche Adresse für den Notfall"
modules/contacts/include/contacts.php  26)     - Domaininhaber festlegen    
Bernd Wurst $usage ist ein array

Bernd Wurst authored 6 years ago

modules/handles/include/handles.php    27) */
modules/handles/include/handles.php    28) 
modules/handles/include/handles.php    29) 
Bernd Wurst Vorbereitung für edit/new

Bernd Wurst authored 6 years ago

modules/contacts/include/contacts.php  30) function new_contact() {
modules/contacts/include/contacts.php  31)     return array("id" => NULL,
modules/contacts/include/contacts.php  32)         "state" => NULL,
modules/contacts/include/contacts.php  33)         "lastchange" => time(),
modules/contacts/include/contacts.php  34)         "nic_handle" => NULL,
modules/contacts/include/contacts.php  35)         "nic_id" => NULL,
modules/contacts/include/contacts.php  36)         "company" => NULL,
modules/contacts/include/contacts.php  37)         "name" => NULL,
modules/contacts/include/contacts.php  38)         "address" => NULL,
modules/contacts/include/contacts.php  39)         "zip" => NULL,
modules/contacts/include/contacts.php  40)         "city" => NULL,
modules/contacts/include/contacts.php  41)         "country" => "DE",
modules/contacts/include/contacts.php  42)         "phone" => NULL,
modules/contacts/include/contacts.php  43)         "mobile" => NULL,
modules/contacts/include/contacts.php  44)         "fax" => NULL,
modules/contacts/include/contacts.php  45)         "email" => NULL,
modules/contacts/include/contacts.php  46)         "pgp_id" => NULL,
modules/contacts/include/contacts.php  47)         "pgp_key" => NULL,
modules/contacts/include/contacts.php  48)         "customer" => $_SESSION['customerinfo']['customerno']);
modules/contacts/include/contacts.php  49) }
modules/contacts/include/contacts.php  50) 
modules/contacts/include/contacts.php  51) 
modules/contacts/include/contacts.php  52) function get_contact($id)
modules/contacts/include/contacts.php  53) {
modules/contacts/include/contacts.php  54)     $args = array(
modules/contacts/include/contacts.php  55)         "cid" => (int) $_SESSION['customerinfo']['customerno'],
modules/contacts/include/contacts.php  56)         "id" => (int) $id);
modules/contacts/include/contacts.php  57)     $result = db_query("SELECT id, state, lastchange, nic_id, nic_handle, company, name, address, zip, city, country, phone, mobile, fax, email, pgp_id, pgp_key FROM kundendaten.contacts WHERE id=:id AND customer=:cid", $args);
modules/contacts/include/contacts.php  58)     if ($result->rowCount() == 0) {
modules/contacts/include/contacts.php  59)         system_failure("Kontakt nicht gefunden oder gehört nicht diesem Kunden");
modules/contacts/include/contacts.php  60)     }
Bernd Wurst Zeige bestehende Daten in d...

Bernd Wurst authored 6 years ago

modules/contacts/include/contacts.php  61)     $contact = $result->fetch();
Bernd Wurst Vorbereitung für edit/new

Bernd Wurst authored 6 years ago

modules/contacts/include/contacts.php  62)     return $contact;
modules/contacts/include/contacts.php  63) }
modules/contacts/include/contacts.php  64) 
Bernd Wurst Umbenennung Datenbank handl...

Bernd Wurst authored 6 years ago

modules/contacts/include/contacts.php  65) function get_contacts() {
Bernd Wurst In neues Modul ausgelagert

Bernd Wurst authored 6 years ago

modules/handles/include/handles.php    66)     $cid = (int) $_SESSION['customerinfo']['customerno'];
Bernd Wurst Neue Darstellung der Kontak...

Bernd Wurst authored 6 years ago

modules/contacts/include/contacts.php  67)     $result = db_query("SELECT id, state, lastchange, nic_id, nic_handle, company, name, address, zip, city, country, phone, mobile, fax, email, pgp_id, pgp_key FROM kundendaten.contacts WHERE (state<>'deleted' OR state IS NULL) AND customer=? ORDER BY id", array($cid));
Bernd Wurst In neues Modul ausgelagert

Bernd Wurst authored 6 years ago

modules/handles/include/handles.php    68)     $ret = array();
Bernd Wurst Umbenennung Datenbank handl...

Bernd Wurst authored 6 years ago

modules/contacts/include/contacts.php  69)     while ($contact = $result->fetch()) {
modules/contacts/include/contacts.php  70)         $ret[$contact['id']] = $contact;
Bernd Wurst In neues Modul ausgelagert

Bernd Wurst authored 6 years ago

modules/handles/include/handles.php    71)     }
modules/handles/include/handles.php    72)     DEBUG($ret);
modules/handles/include/handles.php    73)     return $ret;
modules/handles/include/handles.php    74) }
modules/handles/include/handles.php    75) 
Bernd Wurst Prüfe Telefonnummer

Bernd Wurst authored 6 years ago

modules/contacts/include/contacts.php  76) 
Bernd Wurst Neue Darstellung der Kontak...

Bernd Wurst authored 6 years ago

modules/contacts/include/contacts.php  77) function is_domainholder($contactid) {
modules/contacts/include/contacts.php  78)     $contactid = (int) $contactid;
modules/contacts/include/contacts.php  79)     $result = db_query("SELECT id FROM kundendaten.domains WHERE owner=? OR admin_c=?", array($contactid, $contactid));
modules/contacts/include/contacts.php  80)     if ($result->rowCount() > 0) {
modules/contacts/include/contacts.php  81)         return true;
modules/contacts/include/contacts.php  82)     }
modules/contacts/include/contacts.php  83)     return false;
modules/contacts/include/contacts.php  84) }
modules/contacts/include/contacts.php  85) 
Bernd Wurst Prüfe Telefonnummer

Bernd Wurst authored 6 years ago

modules/contacts/include/contacts.php  86) function possible_domainholders() {
modules/contacts/include/contacts.php  87)     $allcontacts = get_contacts();
modules/contacts/include/contacts.php  88)     $ret = array();
modules/contacts/include/contacts.php  89)     foreach ($allcontacts as $id => $c) {
Bernd Wurst API-Funktionen um Kontakte...

Bernd Wurst authored 6 years ago

modules/contacts/include/contacts.php  90)         if (possible_domainholder($c)) {
Bernd Wurst Prüfe Telefonnummer

Bernd Wurst authored 6 years ago

modules/contacts/include/contacts.php  91)             $ret[$id] = $c;
modules/contacts/include/contacts.php  92)         }
modules/contacts/include/contacts.php  93)     }
modules/contacts/include/contacts.php  94)     return $ret;
modules/contacts/include/contacts.php  95) }
modules/contacts/include/contacts.php  96) 
Bernd Wurst API-Funktionen um Kontakte...

Bernd Wurst authored 6 years ago

modules/contacts/include/contacts.php  97) function possible_domainholder($c)
modules/contacts/include/contacts.php  98) {
modules/contacts/include/contacts.php  99)     if ($c['name'] && $c['address'] && $c['zip'] && $c['city'] && $c['country'] && $c['phone'] && $c['email']) {
modules/contacts/include/contacts.php 100)         return true;
modules/contacts/include/contacts.php 101)     }
modules/contacts/include/contacts.php 102)     return false;
modules/contacts/include/contacts.php 103) }
Bernd Wurst Prüfe Telefonnummer

Bernd Wurst authored 6 years ago

modules/contacts/include/contacts.php 104) 
Bernd Wurst Speichern der Änderungen mö...

Bernd Wurst authored 6 years ago

modules/contacts/include/contacts.php 105) function have_mailaddress($email) 
modules/contacts/include/contacts.php 106) {
modules/contacts/include/contacts.php 107)     $cid = (int) $_SESSION['customerinfo']['customerno'];
modules/contacts/include/contacts.php 108)     $result = db_query("SELECT id FROM kundendaten.contacts WHERE customer=? AND email=?", array($cid, $email));
modules/contacts/include/contacts.php 109)     if ($result->rowCount() > 0) {
modules/contacts/include/contacts.php 110)         return true;
modules/contacts/include/contacts.php 111)     }
modules/contacts/include/contacts.php 112)     return false;
modules/contacts/include/contacts.php 113) }
modules/contacts/include/contacts.php 114) 
Bernd Wurst In neues Modul ausgelagert

Bernd Wurst authored 6 years ago

modules/handles/include/handles.php   115) 
Bernd Wurst Setzen als Kundenkontakte e...

Bernd Wurst authored 6 years ago

modules/contacts/include/contacts.php 116) function possible_kundenkontakt($c) {
modules/contacts/include/contacts.php 117)     if ($c['name'] && $c['email']) {
modules/contacts/include/contacts.php 118)         return true;
modules/contacts/include/contacts.php 119)     }
modules/contacts/include/contacts.php 120) }
modules/contacts/include/contacts.php 121) 
modules/contacts/include/contacts.php 122) 
modules/contacts/include/contacts.php 123) function set_kundenkontakt($typ, $id) {
modules/contacts/include/contacts.php 124)     if (! $id) {
modules/contacts/include/contacts.php 125)         $id = NULL;
modules/contacts/include/contacts.php 126)     } else {
modules/contacts/include/contacts.php 127)         $id = (int) $id;
modules/contacts/include/contacts.php 128)     }
modules/contacts/include/contacts.php 129)     $args = array(
modules/contacts/include/contacts.php 130)         "kunde" => (int) $_SESSION['customerinfo']['customerno'],
modules/contacts/include/contacts.php 131)         "contact" => $id
modules/contacts/include/contacts.php 132)         );
modules/contacts/include/contacts.php 133)     $field = NULL;
modules/contacts/include/contacts.php 134)     if ($typ == 'kunde') {
modules/contacts/include/contacts.php 135)         $field = 'contact_kunde';
modules/contacts/include/contacts.php 136)     } elseif ($typ == 'extern') {
modules/contacts/include/contacts.php 137)         $field = 'contact_extern';
modules/contacts/include/contacts.php 138)     } elseif ($typ == 'rechnung') {
modules/contacts/include/contacts.php 139)         $field = 'contact_rechnung';
modules/contacts/include/contacts.php 140)     } else {
modules/contacts/include/contacts.php 141)         system_failure("Falscher Typ!");
modules/contacts/include/contacts.php 142)     }
modules/contacts/include/contacts.php 143)     db_query("UPDATE kundendaten.kunden SET ".$field."=:contact WHERE id=:kunde", $args);
modules/contacts/include/contacts.php 144) }
modules/contacts/include/contacts.php 145) 
Bernd Wurst Umbenennung Datenbank handl...

Bernd Wurst authored 6 years ago

modules/contacts/include/contacts.php 146) function get_kundenkontakte() {
Bernd Wurst In neues Modul ausgelagert

Bernd Wurst authored 6 years ago

modules/handles/include/handles.php   147)     $cid = (int) $_SESSION['customerinfo']['customerno'];
Bernd Wurst Umbenennung Datenbank handl...

Bernd Wurst authored 6 years ago

modules/contacts/include/contacts.php 148)     $result = db_query("SELECT contact_kunde, contact_extern, contact_rechnung FROM kundendaten.kunden WHERE id=?", array($cid));
Bernd Wurst In neues Modul ausgelagert

Bernd Wurst authored 6 years ago

modules/handles/include/handles.php   149)     $res = $result->fetch();
Bernd Wurst Umbenennung Datenbank handl...

Bernd Wurst authored 6 years ago

modules/contacts/include/contacts.php 150)     $ret = array("kunde" => $res['contact_kunde'],
modules/contacts/include/contacts.php 151)                  "extern" => $res['contact_extern'],
modules/contacts/include/contacts.php 152)                  "rechnung" => $res['contact_rechnung']);
Bernd Wurst In neues Modul ausgelagert

Bernd Wurst authored 6 years ago

modules/handles/include/handles.php   153)     return $ret;
modules/handles/include/handles.php   154) }
modules/handles/include/handles.php   155) 
Bernd Wurst Speichern der Änderungen mö...

Bernd Wurst authored 6 years ago

modules/contacts/include/contacts.php 156) function save_emailaddress($id, $email) 
modules/contacts/include/contacts.php 157) {
Bernd Wurst Speichere E-Mail-Adresse oh...

Bernd Wurst authored 6 years ago

modules/contacts/include/contacts.php 158)     // Speichert eine E-Mail-Adresse direkt, z.B. wenn diese schonmal geprüt wurde
modules/contacts/include/contacts.php 159)     $args = array("cid" => (int) $_SESSION['customerinfo']['customerno'],
modules/contacts/include/contacts.php 160)         "id" => (int) $id,
modules/contacts/include/contacts.php 161)         "email" => $email);
modules/contacts/include/contacts.php 162)     db_query("UPDATE kundendaten.contacts SET email=:email WHERE id=:id AND customer=:cid", $args);    
Bernd Wurst Speichern der Änderungen mö...

Bernd Wurst authored 6 years ago

modules/contacts/include/contacts.php 163) }
modules/contacts/include/contacts.php 164) 
modules/contacts/include/contacts.php 165) function save_contact($c)
modules/contacts/include/contacts.php 166) {
Bernd Wurst API-Funktionen um Kontakte...

Bernd Wurst authored 6 years ago

modules/contacts/include/contacts.php 167)     if ($c['nic_id']) {
modules/contacts/include/contacts.php 168)         if (! possible_domainholder($c)) {
modules/contacts/include/contacts.php 169)             system_failure("Sie haben ein Feld geleert, das für die Eigenschaft als Domaininhaber erhalten bleiben muss. Ihre Änderungen wurden nicht gespeichert.");
modules/contacts/include/contacts.php 170)         }
modules/contacts/include/contacts.php 171)     }
Bernd Wurst Speichern der Änderungen mö...

Bernd Wurst authored 6 years ago

modules/contacts/include/contacts.php 172)     for ($i=0;array_key_exists($i, $c);$i++) {
modules/contacts/include/contacts.php 173)         unset($c[$i]);
modules/contacts/include/contacts.php 174)     }
modules/contacts/include/contacts.php 175)     unset($c['state']);
modules/contacts/include/contacts.php 176)     unset($c['lastchange']);
modules/contacts/include/contacts.php 177)     unset($c['email']);
modules/contacts/include/contacts.php 178)     $c['customer'] = (int) $_SESSION['customerinfo']['customerno'];
modules/contacts/include/contacts.php 179)     if ($c['id']) {
modules/contacts/include/contacts.php 180)         // Kontakt bestaht schon, Update
Bernd Wurst API-Funktionen um Kontakte...

Bernd Wurst authored 6 years ago

modules/contacts/include/contacts.php 181)         db_query("UPDATE kundendaten.contacts SET nic_id=:nic_id, nic_handle=:nic_handle, company=:company, name=:name, address=:address, zip=:zip, city=:city, country=:country, phone=:phone, mobile=:mobile, fax=:fax, pgp_id=:pgp_id, pgp_key=:pgp_key WHERE id=:id AND customer=:customer", $c);
Bernd Wurst Speichern der Änderungen mö...

Bernd Wurst authored 6 years ago

modules/contacts/include/contacts.php 182)     } else {
modules/contacts/include/contacts.php 183)         unset($c['id']);
modules/contacts/include/contacts.php 184)         // Neu anlegen
Bernd Wurst API-Funktionen um Kontakte...

Bernd Wurst authored 6 years ago

modules/contacts/include/contacts.php 185)         db_query("INSERT INTO kundendaten.contacts (nic_id, nic_handle, customer, company, name, address, zip, city, country, phone, mobile, fax, pgp_id, pgp_key) VALUES (:nic_id, :nic_handle, :customer, :company, :name, :address, :zip, :city, :country, :phone, :mobile, :fax, :pgp_id, :pgp_key)", $c);
Bernd Wurst Speichern der Änderungen mö...

Bernd Wurst authored 6 years ago

modules/contacts/include/contacts.php 186)         $c['id'] = db_insert_id();
modules/contacts/include/contacts.php 187)     }
modules/contacts/include/contacts.php 188)     return $c['id'];
modules/contacts/include/contacts.php 189) }
modules/contacts/include/contacts.php 190) 
modules/contacts/include/contacts.php 191) 
modules/contacts/include/contacts.php 192) function send_emailchange_token($id, $email)
modules/contacts/include/contacts.php 193) {
modules/contacts/include/contacts.php 194)     if (! check_emailaddr($email)) {
modules/contacts/include/contacts.php 195)         system_falure("Die E-Mail-Adresse scheint nicht gültig zu sein.");
modules/contacts/include/contacts.php 196)     }
modules/contacts/include/contacts.php 197)     $args = array("id" => (int) $id,
modules/contacts/include/contacts.php 198)         "email" => $email,
modules/contacts/include/contacts.php 199)         "token" => random_string(20));
modules/contacts/include/contacts.php 200) 
modules/contacts/include/contacts.php 201)     db_query("INSERT INTO kundendaten.mailaddress_token (token, expire, contact, email) VALUES (:token, NOW() + INTERVAL 1 DAY, :id, :email)" , $args);
modules/contacts/include/contacts.php 202)     DEBUG('Token erzeugt: '.print_r($args, true));
modules/contacts/include/contacts.php 203)     $message = 'Diese E-Mail-Adresse wurde angegeben als möglicher Domaininhaber oder Kundenkontakt bei schokokeks.org Hosting.
modules/contacts/include/contacts.php 204) 
modules/contacts/include/contacts.php 205) Bitte bestätigen Sie mit einem Klick auf den nachfolgenden Link, dass diese E-Mail-Adresse funktioniert und verwendet werden soll:
modules/contacts/include/contacts.php 206) 
modules/contacts/include/contacts.php 207)     '.config('webinterface_url').'/verify'.$args['token'].'
modules/contacts/include/contacts.php 208) 
modules/contacts/include/contacts.php 209) Wenn Sie diesen Link nicht innerhalb von 24 Stunden abrufen, wird Ihre Adresse gelöscht und nicht verwendet.
modules/contacts/include/contacts.php 210) Sollten Sie mit der Verwendung Ihrer E-Mail-Adresse nicht einverstanden sein, so ignorieren Sie daher bitte diese Nachricht oder teilen Sie uns dies mit.
modules/contacts/include/contacts.php 211) 
modules/contacts/include/contacts.php 212) -- 
modules/contacts/include/contacts.php 213) schokokeks.org GbR, Bernd Wurst, Johannes Böck
modules/contacts/include/contacts.php 214) Köchersberg 32, 71540 Murrhardt
modules/contacts/include/contacts.php 215) 
modules/contacts/include/contacts.php 216) https://schokokeks.org
modules/contacts/include/contacts.php 217) ';
modules/contacts/include/contacts.php 218)     # send welcome message
modules/contacts/include/contacts.php 219)     mail($email, '=?UTF-8?Q?Best=C3=A4tigung_Ihrer_E-Mail-Adresse?=', $message, "X-schokokeks-org-message: verify\nFrom: ".config('company_name').' <'.config('adminmail').">\nMIME-Version: 1.0\nContent-Type: text/plain; charset=UTF-8\n");
modules/contacts/include/contacts.php 220)  
modules/contacts/include/contacts.php 221) }
Bernd Wurst E-Mail-Adresse verifizieren...

Bernd Wurst authored 6 years ago

modules/handles/include/handles.php   222) 
Bernd Wurst Umbenennung Datenbank handl...

Bernd Wurst authored 6 years ago

modules/contacts/include/contacts.php 223) function update_pending($contactid) {
modules/contacts/include/contacts.php 224)     $contactid = (int) $contactid;
modules/contacts/include/contacts.php 225)     $result = db_query("SELECT email FROM kundendaten.mailaddress_token WHERE contact=?", array($contactid));
Bernd Wurst E-Mail-Adresse verifizieren...

Bernd Wurst authored 6 years ago

modules/handles/include/handles.php   226)     if ($result->rowCount() == 0) {
modules/handles/include/handles.php   227)         return NULL;
modules/handles/include/handles.php   228)     }
modules/handles/include/handles.php   229)     $res = $result->fetch();
modules/handles/include/handles.php   230)     return $res['email'];
modules/handles/include/handles.php   231) }
modules/handles/include/handles.php   232) 
modules/handles/include/handles.php   233) 
modules/handles/include/handles.php   234) 
Bernd Wurst Neue Darstellung der Kontak...

Bernd Wurst authored 6 years ago

modules/contacts/include/contacts.php 235) function delete_contact($id) {
modules/contacts/include/contacts.php 236)     $c = get_contact($id);
modules/contacts/include/contacts.php 237)     if ($c['nic_id']) {
modules/contacts/include/contacts.php 238)         // Lösche bei der Registry
modules/contacts/include/contacts.php 239)         $c['state'] = 'deleted';
modules/contacts/include/contacts.php 240)         upload_contact($c);
modules/contacts/include/contacts.php 241)     }
modules/contacts/include/contacts.php 242)     db_query("UPDATE kundendaten.contacts SET state='deleted' WHERE id=?", array($c['id']));
modules/contacts/include/contacts.php 243) }
modules/contacts/include/contacts.php 244)