Passed
Push — main ( 4aef09...4747c4 )
by Miaad
01:45
created
src/tools.php 2 patches
Spacing   +51 added lines, -51 removed lines patch added patch discarded remove patch
@@ -29,7 +29,7 @@  discard block
 block discarded – undo
29 29
 /**
30 30
  * tools class , gather what ever you need
31 31
  */
32
-class tools{
32
+class tools {
33 33
     /**
34 34
      * Check the given username format
35 35
      *
@@ -41,7 +41,7 @@  discard block
 block discarded – undo
41 41
      *
42 42
      * @return bool
43 43
      */
44
-    public static function isUsername (string $username): bool {
44
+    public static function isUsername(string $username): bool {
45 45
         $length = strlen($username);
46 46
         return !str_contains($username, '__') && $length >= 5 && $length <= 33 && preg_match('/^@?([a-zA-Z])(\w{4,31})$/', $username);
47 47
     }
@@ -58,7 +58,7 @@  discard block
 block discarded – undo
58 58
      *
59 59
      * @return bool
60 60
      */
61
-    public static function ipInRange (string $ip, string $range): bool {
61
+    public static function ipInRange(string $ip, string $range): bool {
62 62
         if (!str_contains($range, '/')) {
63 63
             $range .= '/32';
64 64
         }
@@ -78,7 +78,7 @@  discard block
 block discarded – undo
78 78
      *
79 79
      * @return bool
80 80
      */
81
-    public static function isTelegram (string $ip): bool {
81
+    public static function isTelegram(string $ip): bool {
82 82
         return tools::ipInRange($ip, '149.154.160.0/20') || tools::ipInRange($ip, '91.108.4.0/22');
83 83
     }
84 84
 
@@ -93,10 +93,10 @@  discard block
 block discarded – undo
93 93
      *
94 94
      * @return bool
95 95
      */
96
-    public static function isCloudFlare (string $ip): bool {
96
+    public static function isCloudFlare(string $ip): bool {
97 97
         $cf_ips = ['173.245.48.0/20', '103.21.244.0/22', '103.22.200.0/22', '103.31.4.0/22', '141.101.64.0/18', '108.162.192.0/18', '190.93.240.0/20', '188.114.96.0/20', '197.234.240.0/22', '198.41.128.0/17', '162.158.0.0/15', '104.16.0.0/12', '104.24.0.0/14', '172.64.0.0/13', '131.0.72.0/22'];
98 98
         foreach ($cf_ips as $cf_ip) {
99
-            if (self::ipInRange($ip,$cf_ip)) {
99
+            if (self::ipInRange($ip, $cf_ip)) {
100 100
                 return true;
101 101
             }
102 102
         }
@@ -114,10 +114,10 @@  discard block
 block discarded – undo
114 114
      *
115 115
      * @return bool
116 116
      */
117
-    public static function isArvanCloud (string $ip): bool {
117
+    public static function isArvanCloud(string $ip): bool {
118 118
         $ar_ips = ['185.143.232.0/22', '92.114.16.80/28', '2.146.0.0/28', '46.224.2.32/29', '89.187.178.96/29', '195.181.173.128/29', '89.187.169.88/29', '188.229.116.16/29', '83.123.255.56/31', '164.138.128.28/31', '94.182.182.28/30', '185.17.115.176/30', '5.213.255.36/31', '138.128.139.144/29', '5.200.14.8/29', '188.122.68.224/29', '188.122.83.176/29', '213.179.217.16/29', '185.179.201.192/29', '43.239.139.192/29', '213.179.197.16/29', '213.179.201.192/29', '109.200.214.248/29', '138.128.141.16/29', '188.122.78.136/29', '213.179.211.32/29', '103.194.164.24/29', '185.50.105.136/29', '213.179.213.16/29', '162.244.52.120/29', '188.122.80.240/29', '109.200.195.64/29', '109.200.199.224/29', '185.228.238.0/28', '94.182.153.24/29', '94.101.182.0/27', '37.152.184.208/28', '78.39.156.192/28', '158.255.77.238/31', '81.12.28.16/29', '176.65.192.202/31', '2.144.3.128/28', '89.45.48.64/28', '37.32.16.0/27', '37.32.17.0/27', '37.32.18.0/27'];
119 119
         foreach ($ar_ips as $ar_ip) {
120
-            if (self::ipInRange($ip,$ar_ip)) {
120
+            if (self::ipInRange($ip, $ar_ip)) {
121 121
                 return true;
122 122
             }
123 123
         }
@@ -137,11 +137,11 @@  discard block
 block discarded – undo
137 137
      *
138 138
      * @return bool|user return array when verify is active and token is true array of telegram getMe result
139 139
      */
140
-    public static function isToken (string $token, bool $verify = false): bool|user {
140
+    public static function isToken(string $token, bool $verify = false): bool | user {
141 141
         if (!preg_match('/^(\d{8,10}):[\w\-]{35}$/', $token)) {
142 142
             return false;
143 143
         }
144
-        if (!$verify){
144
+        if (!$verify) {
145 145
             return true;
146 146
         }
147 147
         $res = telegram::me($token);
@@ -171,14 +171,14 @@  discard block
 block discarded – undo
171 171
      *
172 172
      * @return bool
173 173
      */
174
-    public static function isJoined (array|string|int $ids , int|null $user_id = null): bool {
174
+    public static function isJoined(array | string | int $ids, int | null $user_id = null): bool {
175 175
         if (!is_array($ids)) {
176 176
             $ids = [$ids];
177 177
         }
178 178
         $user_id = $user_id ?? request::catchFields('user_id');
179 179
 
180 180
         foreach ($ids as $id) {
181
-            $check = telegram::getChatMember($id,$user_id);
181
+            $check = telegram::getChatMember($id, $user_id);
182 182
             if (telegram::$status) {
183 183
                 $check = $check->status;
184 184
                 if ($check === chatMemberStatus::LEFT || $check === chatMemberStatus::KICKED) {
@@ -205,7 +205,7 @@  discard block
 block discarded – undo
205 205
      *
206 206
      * @return array keys will be id and values will be bool(null for not founded ids)
207 207
      */
208
-    public static function joinChecker (array|string|int $ids , int|null $user_id = null): array {
208
+    public static function joinChecker(array | string | int $ids, int | null $user_id = null): array {
209 209
         if (!is_array($ids)) {
210 210
             $ids = [$ids];
211 211
         }
@@ -213,7 +213,7 @@  discard block
 block discarded – undo
213 213
 
214 214
         $result = [];
215 215
         foreach ($ids as $id) {
216
-            $check = telegram::getChatMember($id,$user_id);
216
+            $check = telegram::getChatMember($id, $user_id);
217 217
             if (telegram::$status) {
218 218
                 $check = $check->status;
219 219
                 $result[$id] = $check !== chatMemberStatus::LEFT && $check !== chatMemberStatus::KICKED;
@@ -233,7 +233,7 @@  discard block
 block discarded – undo
233 233
      * @return bool
234 234
      */
235 235
     public static function isShorted(string $text): bool{
236
-        return preg_match('/^[a-zA-Z0-9]+$/',$text);
236
+        return preg_match('/^[a-zA-Z0-9]+$/', $text);
237 237
     }
238 238
 
239 239
     /**
@@ -250,7 +250,7 @@  discard block
 block discarded – undo
250 250
      *
251 251
      * @return string|int|false string for formatted data , int for normal data , false when size can not be found(file not found or ...)
252 252
      */
253
-    public static function size (string $path, bool $format = true): string|int|false {
253
+    public static function size(string $path, bool $format = true): string | int | false {
254 254
         if (filter_var($path, FILTER_VALIDATE_URL)) {
255 255
             $ch = curl_init($path);
256 256
             curl_setopt($ch, CURLOPT_RETURNTRANSFER, true);
@@ -283,7 +283,7 @@  discard block
 block discarded – undo
283 283
      * @return bool
284 284
      * @throws bptException
285 285
      */
286
-    public static function delete (string $path, bool $sub = true): bool {
286
+    public static function delete(string $path, bool $sub = true): bool {
287 287
         $path = realpath($path);
288 288
         if (!is_dir($path)) {
289 289
             return unlink($path);
@@ -292,7 +292,7 @@  discard block
 block discarded – undo
292 292
             return rmdir($path);
293 293
         }
294 294
         if (!$sub) {
295
-            logger::write("tools::delete function used\ndelete function cannot delete folder because its have subFiles and sub parameter haven't true value",loggerTypes::ERROR);
295
+            logger::write("tools::delete function used\ndelete function cannot delete folder because its have subFiles and sub parameter haven't true value", loggerTypes::ERROR);
296 296
             throw new bptException('DELETE_FOLDER_HAS_SUB');
297 297
         }
298 298
         $it = new RecursiveDirectoryIterator($path, FilesystemIterator::SKIP_DOTS);
@@ -314,7 +314,7 @@  discard block
 block discarded – undo
314 314
      * @return bool
315 315
      * @throws bptException when zip extension not found
316 316
      */
317
-    public static function zip (string $path, string $destination): bool {
317
+    public static function zip(string $path, string $destination): bool {
318 318
         if (!extension_loaded('zip')) {
319 319
             logger::write("tools::zip function used\nzip extension is not found , It may not be installed or enabled", loggerTypes::ERROR);
320 320
             throw new bptException('ZIP_EXTENSION_MISSING');
@@ -349,14 +349,14 @@  discard block
 block discarded – undo
349 349
      *
350 350
      * @return bool true on success and false in failure
351 351
      */
352
-    public static function downloadFile (string $url, string $path,int $chunk_size = 512): bool {
352
+    public static function downloadFile(string $url, string $path, int $chunk_size = 512): bool {
353 353
         $file = fopen($url, 'rb');
354 354
         if (!$file) return false;
355 355
         $path = fopen($path, 'wb');
356 356
         if (!$path) return false;
357 357
 
358 358
         $length = $chunk_size * 1024;
359
-        while (!feof($file)){
359
+        while (!feof($file)) {
360 360
             fwrite($path, fread($file, $length), $length);
361 361
         }
362 362
         fclose($path);
@@ -379,10 +379,10 @@  discard block
 block discarded – undo
379 379
      *
380 380
      * @return string
381 381
      */
382
-    public static function byteFormat (int $byte, int $precision = 2, bool $space_between = true): string {
382
+    public static function byteFormat(int $byte, int $precision = 2, bool $space_between = true): string {
383 383
         $rate_counter = 0;
384 384
 
385
-        while ($byte > 1024){
385
+        while ($byte > 1024) {
386 386
             $byte /= 1024;
387 387
             $rate_counter++;
388 388
         }
@@ -391,7 +391,7 @@  discard block
 block discarded – undo
391 391
             $byte = round($byte, $precision);
392 392
         }
393 393
 
394
-        return $byte . ($space_between ? ' ' : '') . ['B', 'KB', 'MB', 'GB', 'TB', 'PB', 'EB'][$rate_counter];
394
+        return $byte.($space_between ? ' ' : '').['B', 'KB', 'MB', 'GB', 'TB', 'PB', 'EB'][$rate_counter];
395 395
     }
396 396
 
397 397
     /**
@@ -408,10 +408,10 @@  discard block
 block discarded – undo
408 408
      *
409 409
      * @return string|false return false when mode is incorrect
410 410
      */
411
-    public static function modeEscape (string $text, string $mode = parseMode::HTML): string|false {
411
+    public static function modeEscape(string $text, string $mode = parseMode::HTML): string | false {
412 412
         return match ($mode) {
413
-            parseMode::HTML => str_replace(['&', '<', '>',], ["&amp;", "&lt;", "&gt;",], $text),
414
-            parseMode::MARKDOWN => str_replace(['\\', '_', '*', '`', '['], ['\\\\', '\_', '\*', '\`', '\[',], $text),
413
+            parseMode::HTML => str_replace(['&', '<', '>', ], ["&amp;", "&lt;", "&gt;", ], $text),
414
+            parseMode::MARKDOWN => str_replace(['\\', '_', '*', '`', '['], ['\\\\', '\_', '\*', '\`', '\[', ], $text),
415 415
             parseMode::MARKDOWNV2 => str_replace(
416 416
                 ['_', '*', '[', ']', '(', ')', '~', '`', '>', '#', '+', '-', '=', '|', '{', '}', '.', '!', '\\'],
417 417
                 ['\_', '\*', '\[', '\]', '\(', '\)', '\~', '\`', '\>', '\#', '\+', '\-', '\=', '\|', '\{', '\}', '\.', '\!', '\\\\'],
@@ -450,12 +450,12 @@  discard block
 block discarded – undo
450 450
      * @return array{status: string,year: string,month: string,day: string,hour: string,minute: string,second: string}
451 451
      * @throws Exception
452 452
      */
453
-    public static function timeDiff (int|string $target_time, int|string|null $base_time = null): array {
453
+    public static function timeDiff(int | string $target_time, int | string | null $base_time = null): array {
454 454
         if (!isset($base_time)) {
455 455
             $base_time = '@'.time();
456 456
         }
457 457
         $base_time = new DateTime($base_time);
458
-        $target_time = new DateTime(is_numeric($target_time) ? '@' . $target_time : $target_time . ' +00:00');
458
+        $target_time = new DateTime(is_numeric($target_time) ? '@'.$target_time : $target_time.' +00:00');
459 459
 
460 460
         $diff = $base_time->diff($target_time);
461 461
 
@@ -482,12 +482,12 @@  discard block
 block discarded – undo
482 482
      *
483 483
      * @return string[]|string
484 484
      */
485
-    public static function realEscapeString(string|array $input): string|array {
486
-        if(is_array($input)) {
485
+    public static function realEscapeString(string | array $input): string | array {
486
+        if (is_array($input)) {
487 487
             return array_map(__METHOD__, $input);
488 488
         }
489 489
 
490
-        if(!empty($input) && is_string($input)) {
490
+        if (!empty($input) && is_string($input)) {
491 491
             return str_replace(['\\', "\0", "\n", "\r", "'", '"', "\x1a"], ['\\\\', '\\0', '\\n', '\\r', "\\'", '\\"', '\\Z'], $input);
492 492
         }
493 493
 
@@ -505,7 +505,7 @@  discard block
 block discarded – undo
505 505
      *
506 506
      * @return string[]|string
507 507
      */
508
-    public static function strReplaceFirst(string|array $search, string|array $replace, string|array $subject): string|array {
508
+    public static function strReplaceFirst(string | array $search, string | array $replace, string | array $subject): string | array {
509 509
         $pos = strpos($subject, $search);
510 510
         if ($pos !== false) {
511 511
             return substr_replace($subject, $replace, $pos, strlen($search));
@@ -522,7 +522,7 @@  discard block
 block discarded – undo
522 522
      *
523 523
      * @return string see possible values in fileType class
524 524
      */
525
-    public static function fileType (string $file_id): string {
525
+    public static function fileType(string $file_id): string {
526 526
         $data = base64_decode(str_pad(strtr($file_id, '-_', '+/'), strlen($file_id) % 4, '='));
527 527
         $new = '';
528 528
         $last = '';
@@ -536,7 +536,7 @@  discard block
 block discarded – undo
536 536
                 $last = $char;
537 537
             }
538 538
         }
539
-        $data = unpack('VtypeId/Vdc_id', $new . $last);
539
+        $data = unpack('VtypeId/Vdc_id', $new.$last);
540 540
         $data['typeId'] = $data['typeId'] & ~33554432 & ~16777216;
541 541
         return [
542 542
             fileTypes::THUMBNAIL,
@@ -574,10 +574,10 @@  discard block
 block discarded – undo
574 574
      *
575 575
      * @return string
576 576
      */
577
-    public static function randomString (int $length = 16, string $characters = 'aAbBcCdDeEfFgGhHiIjJkKlLmMnNoOpPqQrRsStTuUvVwWxXyYzZ'): string {
577
+    public static function randomString(int $length = 16, string $characters = 'aAbBcCdDeEfFgGhHiIjJkKlLmMnNoOpPqQrRsStTuUvVwWxXyYzZ'): string {
578 578
         $rand_string = '';
579 579
         $char_len = strlen($characters) - 1;
580
-        for ($i = 0; $i < $length; $i ++) {
580
+        for ($i = 0; $i < $length; $i++) {
581 581
             $rand_string .= $characters[rand(0, $char_len)];
582 582
         }
583 583
         return $rand_string;
@@ -606,7 +606,7 @@  discard block
 block discarded – undo
606 606
      * @return inlineKeyboardMarkup|replyKeyboardMarkup replyKeyboardMarkup for keyboard and inlineKeyboardMarkup for inline
607 607
      * @throws bptException
608 608
      */
609
-    public static function easyKey(array $keyboard = [], array $inline = []): inlineKeyboardMarkup|replyKeyboardMarkup {
609
+    public static function easyKey(array $keyboard = [], array $inline = []): inlineKeyboardMarkup | replyKeyboardMarkup {
610 610
         if (!empty($keyboard)) {
611 611
             $keyboard_object = new replyKeyboardMarkup();
612 612
             $keyboard_object->setResize_keyboard($keyboard['resize'] ?? true);
@@ -670,7 +670,7 @@  discard block
 block discarded – undo
670 670
             return $keyboard_object;
671 671
         }
672 672
         else {
673
-            logger::write("tools::eKey function used\nkeyboard or inline parameter must be set",loggerTypes::ERROR);
673
+            logger::write("tools::eKey function used\nkeyboard or inline parameter must be set", loggerTypes::ERROR);
674 674
             throw new bptException('ARGUMENT_NOT_FOUND_KEYBOARD_INLINE');
675 675
         }
676 676
     }
@@ -687,10 +687,10 @@  discard block
 block discarded – undo
687 687
      *
688 688
      * @return string
689 689
      */
690
-    public static function inviteLink (int $user_id = null, string $bot_username = null): string {
690
+    public static function inviteLink(int $user_id = null, string $bot_username = null): string {
691 691
         if (empty($user_id)) $user_id = telegram::catchFields(fields::USER_ID);
692 692
         if (empty($bot_username)) $bot_username = telegram::getMe()->username;
693
-        return 'https://t.me/' . str_replace('@', '', $bot_username) . '?start=ref_' . tools::shortEncode($user_id);
693
+        return 'https://t.me/'.str_replace('@', '', $bot_username).'?start=ref_'.tools::shortEncode($user_id);
694 694
     }
695 695
 
696 696
     /**
@@ -714,9 +714,9 @@  discard block
 block discarded – undo
714 714
      * @return string|bool|array{hash:string, key:string, iv:string}
715 715
      * @throws bptException
716 716
      */
717
-    public static function codec (string $action, string $text, string $key = null, string $iv = null): bool|array|string {
717
+    public static function codec(string $action, string $text, string $key = null, string $iv = null): bool | array | string {
718 718
         if (!extension_loaded('openssl')) {
719
-            logger::write("tools::codec function used\nopenssl extension is not found , It may not be installed or enabled",loggerTypes::ERROR);
719
+            logger::write("tools::codec function used\nopenssl extension is not found , It may not be installed or enabled", loggerTypes::ERROR);
720 720
             throw new bptException('OPENSSL_EXTENSION_MISSING');
721 721
         }
722 722
         if ($action === codecAction::ENCRYPT) {
@@ -727,17 +727,17 @@  discard block
 block discarded – undo
727 727
         }
728 728
         elseif ($action === codecAction::DECRYPT) {
729 729
             if (empty($key)) {
730
-                logger::write("tools::codec function used\nkey parameter is not set",loggerTypes::ERROR);
730
+                logger::write("tools::codec function used\nkey parameter is not set", loggerTypes::ERROR);
731 731
                 throw new bptException('ARGUMENT_NOT_FOUND_KEY');
732 732
             }
733 733
             if (empty($iv)) {
734
-                logger::write("tools::codec function used\niv parameter is not set",loggerTypes::ERROR);
734
+                logger::write("tools::codec function used\niv parameter is not set", loggerTypes::ERROR);
735 735
                 throw new bptException('ARGUMENT_NOT_FOUND_IV');
736 736
             }
737 737
             return openssl_decrypt(base64_decode($text), 'AES-256-CBC', $key, 1, $iv);
738 738
         }
739 739
         else {
740
-            logger::write("tools::codec function used\naction is not right, its must be `encode` or `decode`",loggerTypes::WARNING);
740
+            logger::write("tools::codec function used\naction is not right, its must be `encode` or `decode`", loggerTypes::WARNING);
741 741
             return false;
742 742
         }
743 743
     }
@@ -745,8 +745,8 @@  discard block
 block discarded – undo
745 745
     /**
746 746
      * @deprecated use tools::codec() instead , will remove in 1.6.0
747 747
      */
748
-    public static function crypto (string $action, string $text, string $key = null, string $iv = null): bool|array|string {
749
-        return self::codec($action,$text,$key,$iv);
748
+    public static function crypto(string $action, string $text, string $key = null, string $iv = null): bool | array | string {
749
+        return self::codec($action, $text, $key, $iv);
750 750
     }
751 751
 
752 752
     /**
@@ -761,7 +761,7 @@  discard block
 block discarded – undo
761 761
     public static function shortEncode(int $num): string {
762 762
         $codes = '0123456789abcdefghijklmnopqrstuvwxyzABCDEFGHIJKLMNOPQRSTUVWXYZ';
763 763
         $array = [];
764
-        while ($num > 0){
764
+        while ($num > 0) {
765 765
             $array[] = $num % 62;
766 766
             $num = floor($num / 62);
767 767
         }
@@ -769,7 +769,7 @@  discard block
 block discarded – undo
769 769
         foreach ($array as &$value) {
770 770
             $value = $codes[$value];
771 771
         }
772
-        return strrev(implode('',$array));
772
+        return strrev(implode('', $array));
773 773
     }
774 774
 
775 775
     /**
@@ -786,7 +786,7 @@  discard block
 block discarded – undo
786 786
         $num = 0;
787 787
         $text = str_split(strrev($text));
788 788
         foreach ($text as $key=>$value) {
789
-            $num += strpos($codes,$value) * pow(62,$key);
789
+            $num += strpos($codes, $value) * pow(62, $key);
790 790
         }
791 791
         return $num;
792 792
     }
Please login to merge, or discard this patch.
Braces   +34 added lines, -32 removed lines patch added patch discarded remove patch
@@ -217,8 +217,9 @@  discard block
 block discarded – undo
217 217
             if (telegram::$status) {
218 218
                 $check = $check->status;
219 219
                 $result[$id] = $check !== chatMemberStatus::LEFT && $check !== chatMemberStatus::KICKED;
220
+            } else {
221
+                $result[$id] = null;
220 222
             }
221
-            else $result[$id] = null;
222 223
         }
223 224
         return $result;
224 225
     }
@@ -259,8 +260,7 @@  discard block
 block discarded – undo
259 260
             curl_exec($ch);
260 261
             $size = curl_getinfo($ch, CURLINFO_CONTENT_LENGTH_DOWNLOAD);
261 262
             curl_close($ch);
262
-        }
263
-        else {
263
+        } else {
264 264
             $path = realpath($path);
265 265
             $size = file_exists($path) ? filesize($path) : false;
266 266
         }
@@ -331,8 +331,7 @@  discard block
 block discarded – undo
331 331
                     $zip->addFile($filePath, substr($filePath, $root_len));
332 332
                 }
333 333
             }
334
-        }
335
-        else {
334
+        } else {
336 335
             $zip->addFile($path, basename($path));
337 336
         }
338 337
         return $zip->close();
@@ -351,9 +350,13 @@  discard block
 block discarded – undo
351 350
      */
352 351
     public static function downloadFile (string $url, string $path,int $chunk_size = 512): bool {
353 352
         $file = fopen($url, 'rb');
354
-        if (!$file) return false;
353
+        if (!$file) {
354
+            return false;
355
+        }
355 356
         $path = fopen($path, 'wb');
356
-        if (!$path) return false;
357
+        if (!$path) {
358
+            return false;
359
+        }
357 360
 
358 361
         $length = $chunk_size * 1024;
359 362
         while (!feof($file)){
@@ -463,8 +466,9 @@  discard block
 block discarded – undo
463 466
         foreach ($string as $k => &$v) {
464 467
             if ($diff->$v) {
465 468
                 $v = $diff->$v;
469
+            } else {
470
+                unset($string[$k]);
466 471
             }
467
-            else unset($string[$k]);
468 472
         }
469 473
         $string['status'] = $base_time < $target_time ? 'later' : 'ago';
470 474
 
@@ -530,8 +534,7 @@  discard block
 block discarded – undo
530 534
             if ($last === "\0") {
531 535
                 $new .= str_repeat($last, ord($char));
532 536
                 $last = '';
533
-            }
534
-            else {
537
+            } else {
535 538
                 $new .= $last;
536 539
                 $last = $char;
537 540
             }
@@ -615,7 +618,9 @@  discard block
 block discarded – undo
615 618
             }
616 619
             $rows = [];
617 620
             foreach ($keyboard as $row) {
618
-                if (!is_array($row)) continue;
621
+                if (!is_array($row)) {
622
+                    continue;
623
+                }
619 624
                 $buttons = [];
620 625
                 foreach ($row as $base_button) {
621 626
                     $button_info = explode('||', $base_button);
@@ -624,15 +629,12 @@  discard block
 block discarded – undo
624 629
                     if (count($button_info) > 1) {
625 630
                         if ($button_info[1] === 'con') {
626 631
                             $button->setRequest_contact(true);
627
-                        }
628
-                        elseif ($button_info[1] === 'loc') {
632
+                        } elseif ($button_info[1] === 'loc') {
629 633
                             $button->setRequest_location(true);
630
-                        }
631
-                        elseif ($button_info[1] === 'poll') {
634
+                        } elseif ($button_info[1] === 'poll') {
632 635
                             $type = $button_info[2] === pollType::QUIZ ? pollType::QUIZ : pollType::REGULAR;
633 636
                             $button->setRequest_poll((new keyboardButtonPollType())->setType($type));
634
-                        }
635
-                        elseif ($button_info[1] === 'web' && isset($button_info[2])) {
637
+                        } elseif ($button_info[1] === 'web' && isset($button_info[2])) {
636 638
                             $url = $button_info[2];
637 639
                             $button->setWeb_app((new webAppInfo())->setUrl($url));
638 640
                         }
@@ -643,8 +645,7 @@  discard block
 block discarded – undo
643 645
             }
644 646
             $keyboard_object->setKeyboard($rows);
645 647
             return $keyboard_object;
646
-        }
647
-        elseif (!empty($inline)) {
648
+        } elseif (!empty($inline)) {
648 649
             $keyboard_object = new inlineKeyboardMarkup();
649 650
             $rows = [];
650 651
             foreach ($inline as $row) {
@@ -654,12 +655,10 @@  discard block
 block discarded – undo
654 655
                     if (isset($button_info[1])) {
655 656
                         if (filter_var($button_info[1], FILTER_VALIDATE_URL) && str_starts_with($button_info[1], 'http')) {
656 657
                             $button->setText($button_info[0])->setUrl($button_info[1]);
657
-                        }
658
-                        else {
658
+                        } else {
659 659
                             $button->setText($button_info[0])->setCallback_data($button_info[1]);
660 660
                         }
661
-                    }
662
-                    else {
661
+                    } else {
663 662
                         $button->setText($button_info[0])->setUrl('https://t.me/BPT_CH');
664 663
                     }
665 664
                     $buttons[] = $button;
@@ -668,8 +667,7 @@  discard block
 block discarded – undo
668 667
             }
669 668
             $keyboard_object->setInline_keyboard($rows);
670 669
             return $keyboard_object;
671
-        }
672
-        else {
670
+        } else {
673 671
             logger::write("tools::eKey function used\nkeyboard or inline parameter must be set",loggerTypes::ERROR);
674 672
             throw new bptException('ARGUMENT_NOT_FOUND_KEYBOARD_INLINE');
675 673
         }
@@ -688,8 +686,12 @@  discard block
 block discarded – undo
688 686
      * @return string
689 687
      */
690 688
     public static function inviteLink (int $user_id = null, string $bot_username = null): string {
691
-        if (empty($user_id)) $user_id = telegram::catchFields(fields::USER_ID);
692
-        if (empty($bot_username)) $bot_username = telegram::getMe()->username;
689
+        if (empty($user_id)) {
690
+            $user_id = telegram::catchFields(fields::USER_ID);
691
+        }
692
+        if (empty($bot_username)) {
693
+            $bot_username = telegram::getMe()->username;
694
+        }
693 695
         return 'https://t.me/' . str_replace('@', '', $bot_username) . '?start=ref_' . tools::shortEncode($user_id);
694 696
     }
695 697
 
@@ -724,8 +726,7 @@  discard block
 block discarded – undo
724 726
             $iv = self::randomString();
725 727
             $output = base64_encode(openssl_encrypt($text, 'AES-256-CBC', $key, 1, $iv));
726 728
             return ['hash' => $output, 'key' => $key, 'iv' => $iv];
727
-        }
728
-        elseif ($action === codecAction::DECRYPT) {
729
+        } elseif ($action === codecAction::DECRYPT) {
729 730
             if (empty($key)) {
730 731
                 logger::write("tools::codec function used\nkey parameter is not set",loggerTypes::ERROR);
731 732
                 throw new bptException('ARGUMENT_NOT_FOUND_KEY');
@@ -735,8 +736,7 @@  discard block
 block discarded – undo
735 736
                 throw new bptException('ARGUMENT_NOT_FOUND_IV');
736 737
             }
737 738
             return openssl_decrypt(base64_decode($text), 'AES-256-CBC', $key, 1, $iv);
738
-        }
739
-        else {
739
+        } else {
740 740
             logger::write("tools::codec function used\naction is not right, its must be `encode` or `decode`",loggerTypes::WARNING);
741 741
             return false;
742 742
         }
@@ -765,7 +765,9 @@  discard block
 block discarded – undo
765 765
             $array[] = $num % 62;
766 766
             $num = floor($num / 62);
767 767
         }
768
-        if (count($array) < 1) $array = [0];
768
+        if (count($array) < 1) {
769
+            $array = [0];
770
+        }
769 771
         foreach ($array as &$value) {
770 772
             $value = $codes[$value];
771 773
         }
Please login to merge, or discard this patch.
src/pay/crypto.php 2 patches
Spacing   +18 added lines, -18 removed lines patch added patch discarded remove patch
@@ -21,7 +21,7 @@  discard block
 block discarded – undo
21 21
 
22 22
     private static CurlHandle $session;
23 23
 
24
-    public static function init (): void {
24
+    public static function init(): void {
25 25
         self::$api_key = settings::$pay['crypto']['api_key'] ?? '';
26 26
         self::$ipn_secret = settings::$pay['crypto']['ipn_secret'] ?? '';
27 27
         self::$session = curl_init();
@@ -30,7 +30,7 @@  discard block
 block discarded – undo
30 30
         curl_setopt(self::$session, CURLOPT_SSL_VERIFYHOST, 2);
31 31
     }
32 32
 
33
-    private static function execute (string $method, string $endpoint, string|array $data = '') {
33
+    private static function execute(string $method, string $endpoint, string | array $data = '') {
34 34
         if (is_array($data)) {
35 35
             foreach ($data as $key => $value) {
36 36
                 if (empty($value)) {
@@ -41,17 +41,17 @@  discard block
 block discarded – undo
41 41
 
42 42
         $session = self::$session;
43 43
         curl_setopt($session, CURLOPT_HTTPHEADER, [
44
-            'X-API-KEY: ' . self::$api_key,
44
+            'X-API-KEY: '.self::$api_key,
45 45
             'Content-Type: application/json'
46 46
         ]);
47 47
         switch ($method) {
48 48
             case 'GET':
49
-                curl_setopt($session, CURLOPT_URL, self::API_BASE . $endpoint . !empty($data) && is_array($data) ? ('?' . http_build_query($data)) : '');
49
+                curl_setopt($session, CURLOPT_URL, self::API_BASE.$endpoint.!empty($data) && is_array($data) ? ('?'.http_build_query($data)) : '');
50 50
                 break;
51 51
             case 'POST':
52 52
                 curl_setopt($session, CURLOPT_POST, true);
53 53
                 curl_setopt($session, CURLOPT_POSTFIELDS, json_encode($data));
54
-                curl_setopt($session, CURLOPT_URL, self::API_BASE . $endpoint);
54
+                curl_setopt($session, CURLOPT_URL, self::API_BASE.$endpoint);
55 55
                 break;
56 56
             default:
57 57
                 return false;
@@ -59,14 +59,14 @@  discard block
 block discarded – undo
59 59
         return json_decode(curl_exec($session));
60 60
     }
61 61
 
62
-    public static function status (): bool {
62
+    public static function status(): bool {
63 63
         return self::execute('GET', 'status')->message === 'OK';
64 64
     }
65 65
 
66 66
     /**
67 67
      * @return estimatePriceInterface|mixed
68 68
      */
69
-    public static function getEstimatePrice (int|float $amount, string $currency_from, string $currency_to) {
69
+    public static function getEstimatePrice(int | float $amount, string $currency_from, string $currency_to) {
70 70
         return self::execute('GET', 'estimate', [
71 71
             'amount'        => $amount,
72 72
             'currency_from' => $currency_from,
@@ -77,7 +77,7 @@  discard block
 block discarded – undo
77 77
     /**
78 78
      * @return invoicePaymentInterface|mixed
79 79
      */
80
-    public static function createPayment (int|float $price_amount, string $price_currency, string $pay_currency, int|float $pay_amount = null, string $ipn_callback_url = null, string $order_id = null, string $order_description = null, string $purchase_id = null, string $payout_address = null, string $payout_currency = null, string $payout_extra_id = null, bool $fixed_rate = null) {
80
+    public static function createPayment(int | float $price_amount, string $price_currency, string $pay_currency, int | float $pay_amount = null, string $ipn_callback_url = null, string $order_id = null, string $order_description = null, string $purchase_id = null, string $payout_address = null, string $payout_currency = null, string $payout_extra_id = null, bool $fixed_rate = null) {
81 81
         return self::execute('POST', 'payment', [
82 82
             'price_amount'      => $price_amount,
83 83
             'price_currency'    => $price_currency,
@@ -97,7 +97,7 @@  discard block
 block discarded – undo
97 97
     /**
98 98
      * @return invoicePaymentInterface|mixed
99 99
      */
100
-    public static function createInvoicePayment (string $iid, string $pay_currency, string $purchase_id = null, string $order_description = null, string $customer_email = null, string $payout_address = null, string $payout_extra_id = null, string $payout_currency = null) {
100
+    public static function createInvoicePayment(string $iid, string $pay_currency, string $purchase_id = null, string $order_description = null, string $customer_email = null, string $payout_address = null, string $payout_extra_id = null, string $payout_currency = null) {
101 101
         return self::execute('POST', 'invoice', [
102 102
             'iid'               => $iid,
103 103
             'pay_currency'      => $pay_currency,
@@ -113,18 +113,18 @@  discard block
 block discarded – undo
113 113
     /**
114 114
      * @return estimateUpdateInterface|mixed
115 115
      */
116
-    public static function updateEstimatePrice (int $paymentID) {
117
-        return self::execute('POST', 'payment/' . $paymentID . '/update-merchant-estimate');
116
+    public static function updateEstimatePrice(int $paymentID) {
117
+        return self::execute('POST', 'payment/'.$paymentID.'/update-merchant-estimate');
118 118
     }
119 119
 
120 120
     /**
121 121
      * @return paymentInterface|mixed
122 122
      */
123
-    public static function getPaymentStatus (int $paymentID) {
124
-        return self::execute('GET', 'payment/' . $paymentID);
123
+    public static function getPaymentStatus(int $paymentID) {
124
+        return self::execute('GET', 'payment/'.$paymentID);
125 125
     }
126 126
 
127
-    public static function getMinimumPaymentAmount (string $currency_from, string $currency_to): float {
127
+    public static function getMinimumPaymentAmount(string $currency_from, string $currency_to): float {
128 128
         return self::execute('GET', 'min-amount', [
129 129
             'currency_from' => $currency_from,
130 130
             'currency_to'   => $currency_to
@@ -134,7 +134,7 @@  discard block
 block discarded – undo
134 134
     /**
135 135
      * @return invoiceResponseInterface|mixed
136 136
      */
137
-    public static function createInvoice (int|float $price_amount, string $price_currency, string $pay_currency, int|float $pay_amount = null, string $ipn_callback_url = null, string $order_id = null, string $order_description = null, string $success_url = null, string $cancel_url = null) {
137
+    public static function createInvoice(int | float $price_amount, string $price_currency, string $pay_currency, int | float $pay_amount = null, string $ipn_callback_url = null, string $order_id = null, string $order_description = null, string $success_url = null, string $cancel_url = null) {
138 138
         return self::execute('POST', 'invoice', [
139 139
             'price_amount'      => $price_amount,
140 140
             'price_currency'    => $price_currency,
@@ -148,7 +148,7 @@  discard block
 block discarded – undo
148 148
         ]);
149 149
     }
150 150
 
151
-    public static function getCurrencies (): array {
151
+    public static function getCurrencies(): array {
152 152
         return self::execute('GET', 'currencies')->currencies;
153 153
     }
154 154
 
@@ -166,7 +166,7 @@  discard block
 block discarded – undo
166 166
         return $ip === '144.76.201.30';
167 167
     }
168 168
 
169
-    public static function isIPNRequestValid (): bool {
169
+    public static function isIPNRequestValid(): bool {
170 170
         if (empty($_SERVER['HTTP_X_NOWPAYMENTS_SIG'])) {
171 171
             return false;
172 172
         }
@@ -186,7 +186,7 @@  discard block
 block discarded – undo
186 186
     /**
187 187
      * @return ipnDataInterface|mixed
188 188
      */
189
-    public static function getIPN () {
189
+    public static function getIPN() {
190 190
         if (!self::isIPNRequestValid()) {
191 191
             return false;
192 192
         }
Please login to merge, or discard this patch.
Braces   +1 added lines, -2 removed lines patch added patch discarded remove patch
@@ -158,8 +158,7 @@
 block discarded – undo
158 158
             if (isset($_SERVER['HTTP_CF_CONNECTING_IP']) && tools::isCloudFlare($ip)) {
159 159
                 $ip = $_SERVER['HTTP_CF_CONNECTING_IP'];
160 160
             }
161
-        }
162
-        elseif (settings::$arvancloud_verify && isset($_SERVER['HTTP_AR_REAL_IP']) && tools::isArvanCloud($ip)) {
161
+        } elseif (settings::$arvancloud_verify && isset($_SERVER['HTTP_AR_REAL_IP']) && tools::isArvanCloud($ip)) {
163 162
             $ip = $_SERVER['HTTP_AR_REAL_IP'];
164 163
         }
165 164
 
Please login to merge, or discard this patch.
src/pay/pay.php 1 patch
Spacing   +1 added lines, -1 removed lines patch added patch discarded remove patch
@@ -5,7 +5,7 @@
 block discarded – undo
5 5
 use BPT\settings;
6 6
 
7 7
 class pay {
8
-    public static function init (): void {
8
+    public static function init(): void {
9 9
         if (!empty(settings::$pay)) {
10 10
             if (!isset(settings::$pay['crypto'])) {
11 11
                 return;
Please login to merge, or discard this patch.
src/settings.php 1 patch
Spacing   +12 added lines, -12 removed lines patch added patch discarded remove patch
@@ -26,7 +26,7 @@  discard block
 block discarded – undo
26 26
 
27 27
     public static int $log_size = 10;
28 28
 
29
-    public static string|CURLFile|null $certificate = null;
29
+    public static string | CURLFile | null $certificate = null;
30 30
 
31 31
     public static bool $handler = true;
32 32
 
@@ -60,14 +60,14 @@  discard block
 block discarded – undo
60 60
 
61 61
     public static array $allowed_updates = ['message', 'edited_channel_post', 'callback_query', 'inline_query'];
62 62
 
63
-    public static array|null $db = ['type' => 'json'];
63
+    public static array | null $db = ['type' => 'json'];
64 64
 
65
-    public static array|null $pay = null;
65
+    public static array | null $pay = null;
66 66
 
67 67
     /**
68 68
      * @internal Only for BPT self usage , Don't use it in your source!
69 69
      */
70
-    public static function init (array|stdClass $settings): void {
70
+    public static function init(array | stdClass $settings): void {
71 71
         $settings = (array) $settings;
72 72
         foreach ($settings as $setting => $value) {
73 73
             try {
@@ -75,10 +75,10 @@  discard block
 block discarded – undo
75 75
                     if (!is_dir(realpath('bots_files'))) {
76 76
                         mkdir('bots_files');
77 77
                     }
78
-                    if (!is_dir(realpath('bots_files/' . $value))) {
79
-                        mkdir('bots_files/' . $value);
78
+                    if (!is_dir(realpath('bots_files/'.$value))) {
79
+                        mkdir('bots_files/'.$value);
80 80
                     }
81
-                    $value = 'bots_files/' . $value . '/';
81
+                    $value = 'bots_files/'.$value.'/';
82 82
                 }
83 83
                 self::$$setting = $value;
84 84
             }
@@ -112,7 +112,7 @@  discard block
 block discarded – undo
112 112
     /**
113 113
      * @internal Only for BPT self usage , Don't use it in your source!
114 114
      */
115
-    public static function done (): void {
115
+    public static function done(): void {
116 116
         if (self::$logger) {
117 117
             $estimated = round((microtime(true) - $_SERVER['REQUEST_TIME_FLOAT']) * 1000, 2);
118 118
             $status_message = match (true) {
@@ -127,7 +127,7 @@  discard block
 block discarded – undo
127 127
         }
128 128
     }
129 129
 
130
-    private static function security (): void {
130
+    private static function security(): void {
131 131
         if (self::$security) {
132 132
             ini_set('magic_quotes_gpc', 'off');
133 133
             ini_set('sql.safe_mode', 'on');
@@ -142,11 +142,11 @@  discard block
 block discarded – undo
142 142
         }
143 143
     }
144 144
 
145
-    private static function secureFolder (): void {
145
+    private static function secureFolder(): void {
146 146
         if (self::$secure_folder) {
147 147
             $address = explode('/', $_SERVER['REQUEST_URI']);
148 148
             unset($address[count($address) - 1]);
149
-            $address = implode('/', $address) . '/BPT.php';
149
+            $address = implode('/', $address).'/BPT.php';
150 150
             $text = "ErrorDocument 404 $address\nErrorDocument 403 $address\n Options -Indexes\n  Order Deny,Allow\nDeny from all\nAllow from 127.0.0.1\n<Files *.php>\n    Order Allow,Deny\n    Allow from all\n</Files>";
151 151
             $htaccess = realpath('.htaccess');
152 152
             if (!file_exists($htaccess) || filesize($htaccess) != strlen($text)) {
@@ -155,7 +155,7 @@  discard block
 block discarded – undo
155 155
         }
156 156
     }
157 157
 
158
-    private static function getUpdates (): void {
158
+    private static function getUpdates(): void {
159 159
         if (!self::$handler) {
160 160
             logger::write('You can\'t use getUpdates receiver when handler is off , use webhook or use handler', loggerTypes::ERROR);
161 161
             throw new bptException('GETUPDATE_NEED_HANDLER');
Please login to merge, or discard this patch.