zimbraAddressAvailable.php 1.6 KB

12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152
  1. <?php
  2. $allowed_host = 'admin.seecure.ch';
  3. $host = parse_url($_SERVER['HTTP_REFERER'], PHP_URL_HOST);
  4. if(substr($host, 0 - strlen($allowed_host)) != $allowed_host) {
  5. die("This file cannot be accessed directly");
  6. }
  7. use WHMCS\Database\Capsule;
  8. define("CLIENTAREA", true);
  9. require_once(__DIR__ . '/../../../init.php');
  10. require_once(ROOTDIR . '/includes/dbfunctions.php');
  11. require_once dirname(__FILE__) . '/zimbraSingle.inc';
  12. $whmcs = App::self();
  13. $productID = $_GET['pid'];
  14. $accessData = array('zimbraServer' => '', 'adminUser' => '', 'adminPass' => '');
  15. $serverIDObj = Capsule::table('tblhosting')
  16. ->select('server')
  17. ->where('id', '=', $productID)
  18. ->get();
  19. $serverID = $serverIDObj[0]->server;
  20. $server = Capsule::table('tblservers')
  21. ->select('ipaddress', 'username', 'password')
  22. ->where('id', '=', $serverID)
  23. ->where('active', '=', 1)
  24. ->get();
  25. $accessData['zimbraServer'] = $server[0]->ipaddress;
  26. $accessData['adminUser'] = $server[0]->username;
  27. $adminPassCrypt = $server[0]->password;
  28. $adminPassDecrypt = localAPI('DecryptPassword', array('password2' => $adminPassCrypt));
  29. if ($adminPassDecrypt['result'] == 'success') {
  30. $accessData['adminPass'] = $adminPassDecrypt['password'];
  31. }
  32. $api = new Zm_Auth($accessData['zimbraServer'], $accessData['adminUser'], $accessData['adminPass'], "admin");
  33. $login = $api->login();
  34. if(is_a($login, "Exception")) {
  35. logModuleCall(
  36. 'zimbrasingle',
  37. __FUNCTION__,
  38. $accessData,
  39. "Error : cannot login to " . $accessData['zimbraServer'],
  40. $serverID
  41. );
  42. exit();
  43. } else {
  44. $apiAccountManager = new Zm_Account($api);
  45. if( $apiAccountManager->accountExists($account_name)) {
  46. echo 'no';
  47. } else {
  48. echo 'yes';
  49. }
  50. }