index.php 5.6 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148
  1. <?php
  2. $clickuzConf = parse_ini_file('config/myclickuz.ini');
  3. // подключаем API MySQL
  4. include ("../../libs/api.mysql.php");
  5. //вытаскиваем из конфига все что нам нужно в будущем
  6. $ispUrl = $clickuzConf['TEMPLATE_ISP_URL'];
  7. $ispName = $clickuzConf['TEMPLATE_ISP'];
  8. $ispLogo = $clickuzConf['TEMPLATE_ISP_LOGO'];
  9. $merchant_service = $clickuzConf['MERCHANT_SERVICE'];
  10. /*
  11. * shows payment summ selection form
  12. *
  13. * @return string
  14. */
  15. function clickuz_PricesForm() {
  16. global $clickuzConf;
  17. $result = '<form action="" method="POST">';
  18. $addCommission = (isset($clickuzConf['ADD_COMMISSION'])) ? $clickuzConf['ADD_COMMISSION'] : 1;
  19. if (!empty($clickuzConf['AVAIL_PRICES'])) {
  20. $pricesArr = array();
  21. $pricesRaw = explode(',', $clickuzConf['AVAIL_PRICES']);
  22. if (!empty($pricesRaw)) {
  23. $i=0;
  24. foreach ($pricesRaw as $eachPrice) {
  25. $selected = ($i==0) ? 'CHECKED' : '';
  26. $result.= '<input type="radio" name="amount" value="' . (trim($eachPrice)*($addCommission)) . '" ' . $selected . '> ' . trim($eachPrice) . ' ' . $clickuzConf['TEMPLATE_CURRENCY'] . '<br>';
  27. $i++;
  28. }
  29. }
  30. }
  31. if (isset($clickuzConf['CUSTOM_PRICE']) AND ! empty($clickuzConf['CUSTOM_PRICE'])) {
  32. // Script for change custom amount value
  33. $result.= '<script>
  34. function change_custom_amount(){
  35. var custom_amount = document.getElementById("radio_custom_amount");
  36. custom_amount.value = document.getElementById("input_custom_amount").value;
  37. custom_amount.value = (custom_amount.value * ' . $addCommission . ').toFixed(2);
  38. }
  39. document.addEventListener(\'DOMContentLoaded\', function() {
  40. // just to apply $addCommission after the page loads
  41. change_custom_amount();
  42. }, false);
  43. </script>
  44. ';
  45. if (!empty($clickuzConf['AVAIL_PRICES'])) {
  46. $result.= '<input type="radio" name="amount" value="' . $clickuzConf['CUSTOM_PRICE'] . '" id="radio_custom_amount" onClick="change_custom_amount()">';
  47. } else {
  48. $result.= '<input type="hidden" name="amount" value="' . $clickuzConf['CUSTOM_PRICE'] . '" id="radio_custom_amount">';
  49. }
  50. $result.= '<input onchange="change_custom_amount()" id="input_custom_amount" type="number" style="width: 4em;" value="' . $clickuzConf['CUSTOM_PRICE'] . '" min="' . $clickuzConf['CUSTOM_PRICE'] . '" step="any" /> ' . $clickuzConf['TEMPLATE_CURRENCY'] . '<br>';
  51. }
  52. $result.= '<input type="submit" value="' . $clickuzConf['TEMPLATE_NEXT'] . '">';
  53. $result.= '</form>';
  54. return ($result);
  55. }
  56. /*
  57. * returns form with ClickUZ payment button
  58. *
  59. * @param $customer_id string valid Payment ID
  60. *
  61. * @return string
  62. */
  63. function clickuz_PaymentForm($customer_id) {
  64. global $clickuzConf;
  65. $cardType = $clickuzConf['CARD_TYPE'];
  66. $summ = trim($_POST['amount']);
  67. $returnURL = $clickuzConf['RETURN_URL'];
  68. if (isset($clickuzConf['MERCHANT_ID']['default']) AND isset($clickuzConf['MERCHANT_SERVICE_ID']['default']) ) {
  69. $avaibleTagsRaw = explode(',', $clickuzConf['AVAIBLE_TAGS_ID']);
  70. if (!empty($avaibleTagsRaw)) {
  71. $where = '';
  72. foreach ($avaibleTagsRaw as $tag) {
  73. if($tag != end($avaibleTagsRaw)) {
  74. $where.= "`tagid` = '" . trim($tag) . "' OR ";
  75. } else {
  76. $where.= "`tagid` = '" . trim($tag) . "'";
  77. }
  78. }
  79. $customer_id_m = mysql_real_escape_string($customer_id);
  80. $query = "SELECT `tagid` FROM `tags` INNER JOIN `op_customers` ON (`tags`.`login`= `op_customers`.`realid`) WHERE `op_customers`.`virtualid` = '" . $customer_id_m . "' AND (" . $where . ")";
  81. $data = simple_query($query);
  82. if (!empty($data)) {
  83. $tag_id = $data['tagid'];
  84. $merchant_id = $clickuzConf['MERCHANT_ID'][$tag_id];
  85. $merchant_service_id = $clickuzConf['MERCHANT_SERVICE_ID'][$tag_id];
  86. } else {
  87. $merchant_id = $clickuzConf['MERCHANT_ID']['default'];
  88. $merchant_service_id = $clickuzConf['MERCHANT_SERVICE_ID']['default'];
  89. }
  90. } else {
  91. $merchant_id = $clickuzConf['MERCHANT_ID']['default'];
  92. $merchant_service_id = $clickuzConf['MERCHANT_SERVICE_ID']['default'];
  93. }
  94. } else {
  95. $merchant_id = $clickuzConf['MERCHANT_ID'];
  96. $merchant_service_id = $clickuzConf['MERCHANT_SERVICE_ID'];
  97. }
  98. $result = "<h2>" . $clickuzConf['TEMPLATE_ISP_SERVICE'] . " " . $customer_id . "</h2>";
  99. $result.= '
  100. <form method="post" action="'. $returnURL . '">
  101. <script src="https://my.click.uz/pay/checkout.js"
  102. class="uzcard_payment_button"
  103. data-service-id="' . $merchant_service_id . '"
  104. data-merchant-id="' . $merchant_id . '"
  105. data-transaction-param="' . $customer_id . '"
  106. data-amount="' . $summ . '"
  107. data-card-type="' . $cardType . '"
  108. data-label="Оплатить" <!-- Текст кнопки оплаты -->>
  109. </script>
  110. </form> ';
  111. return ($result);
  112. }
  113. /*
  114. * main codepart
  115. */
  116. if (isset($_GET['customer_id'])) {
  117. $customer_id = $_GET['customer_id'];
  118. if (!isset($_POST['amount'])) {
  119. $paymentForm = clickuz_PricesForm();
  120. } else {
  121. $paymentForm = clickuz_PaymentForm($customer_id);
  122. }
  123. //рендерим все в темплейт
  124. include('template.html');
  125. } else {
  126. die('WRONG_CUSTOMERID');
  127. }
  128. ?>