Passed
Push — main ( 1e3b41...5f13e5 )
by Miaad
11:27
created
src/receiver/webhook.php 1 patch
Spacing   +11 added lines, -11 removed lines patch added patch discarded remove patch
@@ -19,7 +19,7 @@  discard block
 block discarded – undo
19 19
     /**
20 20
      * @internal Only for BPT self usage , Don't use it in your source!
21 21
      */
22
-    public static function init () {
22
+    public static function init() {
23 23
         if (settings::$multi) {
24 24
             multi::init();
25 25
         }
@@ -39,24 +39,24 @@  discard block
 block discarded – undo
39 39
         lock::deleteIfExist(['BPT-MULTI-EXEC', 'BPT-MULTI-CURL', 'getUpdate', 'getUpdateHook']);
40 40
     }
41 41
 
42
-    protected static function setWebhook(string $url,string $secret = '') {
42
+    protected static function setWebhook(string $url, string $secret = '') {
43 43
         $res = BPT::setWebhook($url, settings::$certificate, max_connections: settings::$max_connection, allowed_updates: settings::$allowed_updates, drop_pending_updates: settings::$skip_old_updates, secret_token: $secret);
44 44
         if (!BPT::$status) {
45
-            logger::write("There is some problem happened , telegram response : \n".json_encode($res),loggerTypes::ERROR);
46
-            BPT::exit(print_r($res,true));
45
+            logger::write("There is some problem happened , telegram response : \n".json_encode($res), loggerTypes::ERROR);
46
+            BPT::exit(print_r($res, true));
47 47
         }
48
-        logger::write('Webhook was set successfully',loggerTypes::INFO);
48
+        logger::write('Webhook was set successfully', loggerTypes::INFO);
49 49
     }
50 50
 
51 51
     protected static function checkURL() {
52 52
         if (!(isset($_SERVER['SERVER_NAME']) && isset($_SERVER['REQUEST_URI']))) {
53
-            logger::write('For using webhook receiver , you should open this file in your webserver(by domain)',loggerTypes::ERROR);
53
+            logger::write('For using webhook receiver , you should open this file in your webserver(by domain)', loggerTypes::ERROR);
54 54
             throw new bptException('WEBHOOK_NEED_URL');
55 55
         }
56 56
     }
57 57
 
58 58
     private static function setURL(): string {
59
-        return (isset(settings::$certificate) ? 'http://' : 'https://') . $_SERVER['SERVER_NAME'] . $_SERVER['SCRIPT_NAME'];
59
+        return (isset(settings::$certificate) ? 'http://' : 'https://').$_SERVER['SERVER_NAME'].$_SERVER['SCRIPT_NAME'];
60 60
     }
61 61
 
62 62
     protected static function setCertificate() {
@@ -71,8 +71,8 @@  discard block
 block discarded – undo
71 71
         self::checkURL();
72 72
         self::setCertificate();
73 73
         $url = self::setURL();
74
-        $secret = !empty(settings::$secret) ? settings::$secret : str_replace(':','---',settings::$token);
75
-        self::setWebhook($url,$secret);
74
+        $secret = !empty(settings::$secret) ? settings::$secret : str_replace(':', '---', settings::$token);
75
+        self::setWebhook($url, $secret);
76 76
         lock::save('BPT-HOOK', md5($secret));
77 77
         BPT::exit('Done');
78 78
     }
@@ -80,7 +80,7 @@  discard block
 block discarded – undo
80 80
     private static function checkSecret() {
81 81
         $secret_hash = lock::read('BPT-HOOK');
82 82
         if ($secret_hash !== md5(self::getSecret())) {
83
-            logger::write('This is not webhook set by BPT, webhook will reset',loggerTypes::WARNING);
83
+            logger::write('This is not webhook set by BPT, webhook will reset', loggerTypes::WARNING);
84 84
             self::processSetWebhook();
85 85
         }
86 86
     }
@@ -101,7 +101,7 @@  discard block
 block discarded – undo
101 101
      *
102 102
      * @return bool
103 103
      */
104
-    public static function fastClose (int $timeout = 86400): bool {
104
+    public static function fastClose(int $timeout = 86400): bool {
105 105
         if (settings::$multi || !lock::exist('BPT-HOOK') || settings::$receiver !== \BPT\constants\receiver::WEBHOOK) {
106 106
             return false;
107 107
         }
Please login to merge, or discard this patch.
src/tools.php 2 patches
Spacing   +50 added lines, -50 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 >= 4 && $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
     /**
@@ -251,7 +251,7 @@  discard block
 block discarded – undo
251 251
      *
252 252
      * @return string|int|false string for formatted data , int for normal data , false when size can not be found(file not found or ...)
253 253
      */
254
-    public static function size (string $path, bool $format = true, bool $space_between = true): string|int|false {
254
+    public static function size(string $path, bool $format = true, bool $space_between = true): string | int | false {
255 255
         if (filter_var($path, FILTER_VALIDATE_URL)) {
256 256
             $ch = curl_init($path);
257 257
             curl_setopt($ch, CURLOPT_RETURNTRANSFER, true);
@@ -266,7 +266,7 @@  discard block
 block discarded – undo
266 266
             $size = file_exists($path) ? filesize($path) : false;
267 267
         }
268 268
         if (isset($size) && is_numeric($size)) {
269
-            return $format ? tools::byteFormat($size, space_between: $space_between) : $size;
269
+            return $format ? tools::byteFormat($size, space_between : $space_between) : $size;
270 270
         }
271 271
         return false;
272 272
     }
@@ -284,7 +284,7 @@  discard block
 block discarded – undo
284 284
      * @return bool
285 285
      * @throws bptException
286 286
      */
287
-    public static function delete (string $path, bool $sub = true): bool {
287
+    public static function delete(string $path, bool $sub = true): bool {
288 288
         $path = realpath($path);
289 289
         if (!is_dir($path)) {
290 290
             return unlink($path);
@@ -293,7 +293,7 @@  discard block
 block discarded – undo
293 293
             return rmdir($path);
294 294
         }
295 295
         if (!$sub) {
296
-            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
+            logger::write("tools::delete function used\ndelete function cannot delete folder because its have subFiles and sub parameter haven't true value", loggerTypes::ERROR);
297 297
             throw new bptException('DELETE_FOLDER_HAS_SUB');
298 298
         }
299 299
         $it = new RecursiveDirectoryIterator($path, FilesystemIterator::SKIP_DOTS);
@@ -315,7 +315,7 @@  discard block
 block discarded – undo
315 315
      * @return bool
316 316
      * @throws bptException when zip extension not found
317 317
      */
318
-    public static function zip (string $path, string $destination): bool {
318
+    public static function zip(string $path, string $destination): bool {
319 319
         if (!extension_loaded('zip')) {
320 320
             logger::write("tools::zip function used\nzip extension is not found , It may not be installed or enabled", loggerTypes::ERROR);
321 321
             throw new bptException('ZIP_EXTENSION_MISSING');
@@ -350,14 +350,14 @@  discard block
 block discarded – undo
350 350
      *
351 351
      * @return bool true on success and false in failure
352 352
      */
353
-    public static function downloadFile (string $url, string $path, int $chunk_size = 512): bool {
353
+    public static function downloadFile(string $url, string $path, int $chunk_size = 512): bool {
354 354
         $file = fopen($url, 'rb');
355 355
         if (!$file) return false;
356 356
         $path = fopen($path, 'wb');
357 357
         if (!$path) return false;
358 358
 
359 359
         $length = $chunk_size * 1024;
360
-        while (!feof($file)){
360
+        while (!feof($file)) {
361 361
             fwrite($path, fread($file, $length), $length);
362 362
         }
363 363
         fclose($path);
@@ -380,10 +380,10 @@  discard block
 block discarded – undo
380 380
      *
381 381
      * @return string
382 382
      */
383
-    public static function byteFormat (int $byte, int $precision = 2, bool $space_between = true): string {
383
+    public static function byteFormat(int $byte, int $precision = 2, bool $space_between = true): string {
384 384
         $rate_counter = 0;
385 385
 
386
-        while ($byte > 1024){
386
+        while ($byte > 1024) {
387 387
             $byte /= 1024;
388 388
             $rate_counter++;
389 389
         }
@@ -392,7 +392,7 @@  discard block
 block discarded – undo
392 392
             $byte = round($byte, $precision);
393 393
         }
394 394
 
395
-        return $byte . ($space_between ? ' ' : '') . ['B', 'KB', 'MB', 'GB', 'TB', 'PB', 'EB'][$rate_counter];
395
+        return $byte.($space_between ? ' ' : '').['B', 'KB', 'MB', 'GB', 'TB', 'PB', 'EB'][$rate_counter];
396 396
     }
397 397
 
398 398
     /**
@@ -409,10 +409,10 @@  discard block
 block discarded – undo
409 409
      *
410 410
      * @return string|false return false when mode is incorrect
411 411
      */
412
-    public static function modeEscape (string $text, string $mode = parseMode::HTML): string|false {
412
+    public static function modeEscape(string $text, string $mode = parseMode::HTML): string | false {
413 413
         return match ($mode) {
414
-            parseMode::HTML => str_replace(['&', '<', '>',], ["&amp;", "&lt;", "&gt;",], $text),
415
-            parseMode::MARKDOWN => str_replace(['\\', '_', '*', '`', '['], ['\\\\', '\_', '\*', '\`', '\[',], $text),
414
+            parseMode::HTML => str_replace(['&', '<', '>', ], ["&amp;", "&lt;", "&gt;", ], $text),
415
+            parseMode::MARKDOWN => str_replace(['\\', '_', '*', '`', '['], ['\\\\', '\_', '\*', '\`', '\[', ], $text),
416 416
             parseMode::MARKDOWNV2 => str_replace(
417 417
                 ['_', '*', '[', ']', '(', ')', '~', '`', '>', '#', '+', '-', '=', '|', '{', '}', '.', '!', '\\'],
418 418
                 ['\_', '\*', '\[', '\]', '\(', '\)', '\~', '\`', '\>', '\#', '\+', '\-', '\=', '\|', '\{', '\}', '\.', '\!', '\\\\'],
@@ -451,9 +451,9 @@  discard block
 block discarded – undo
451 451
      * @return array{status: string,year: string,month: string,day: string,hour: string,minute: string,second: string}
452 452
      * @throws Exception
453 453
      */
454
-    public static function timeDiff (int|string $target_time, int|string|null $base_time = null): array {
454
+    public static function timeDiff(int | string $target_time, int | string | null $base_time = null): array {
455 455
         $base_time = new DateTime($base_time ?? '@'.time());
456
-        $target_time = new DateTime(is_numeric($target_time) ? '@' . $target_time : $target_time . ' +00:00');
456
+        $target_time = new DateTime(is_numeric($target_time) ? '@'.$target_time : $target_time.' +00:00');
457 457
 
458 458
         $diff = $base_time->diff($target_time);
459 459
 
@@ -480,12 +480,12 @@  discard block
 block discarded – undo
480 480
      *
481 481
      * @return string[]|string
482 482
      */
483
-    public static function realEscapeString(string|array $input): string|array {
484
-        if(is_array($input)) {
483
+    public static function realEscapeString(string | array $input): string | array {
484
+        if (is_array($input)) {
485 485
             return array_map(__METHOD__, $input);
486 486
         }
487 487
 
488
-        if(!empty($input) && is_string($input)) {
488
+        if (!empty($input) && is_string($input)) {
489 489
             return str_replace(['\\', "\0", "\n", "\r", "'", '"', "\x1a"], ['\\\\', '\\0', '\\n', '\\r', "\\'", '\\"', '\\Z'], $input);
490 490
         }
491 491
 
@@ -503,7 +503,7 @@  discard block
 block discarded – undo
503 503
      *
504 504
      * @return string[]|string
505 505
      */
506
-    public static function strReplaceFirst(string|array $search, string|array $replace, string|array $subject): string|array {
506
+    public static function strReplaceFirst(string | array $search, string | array $replace, string | array $subject): string | array {
507 507
         $pos = strpos($subject, $search);
508 508
         if ($pos !== false) {
509 509
             return substr_replace($subject, $replace, $pos, strlen($search));
@@ -520,7 +520,7 @@  discard block
 block discarded – undo
520 520
      *
521 521
      * @return string see possible values in fileType class
522 522
      */
523
-    public static function fileType (string $file_id): string {
523
+    public static function fileType(string $file_id): string {
524 524
         $data = base64_decode(str_pad(strtr($file_id, '-_', '+/'), strlen($file_id) % 4, '='));
525 525
         $new = '';
526 526
         $last = '';
@@ -534,7 +534,7 @@  discard block
 block discarded – undo
534 534
                 $last = $char;
535 535
             }
536 536
         }
537
-        $data = unpack('VtypeId/Vdc_id', $new . $last);
537
+        $data = unpack('VtypeId/Vdc_id', $new.$last);
538 538
         $data['typeId'] = $data['typeId'] & ~33554432 & ~16777216;
539 539
         return [
540 540
             fileTypes::THUMBNAIL,
@@ -572,10 +572,10 @@  discard block
 block discarded – undo
572 572
      *
573 573
      * @return string
574 574
      */
575
-    public static function randomString (int $length = 16, string $characters = 'aAbBcCdDeEfFgGhHiIjJkKlLmMnNoOpPqQrRsStTuUvVwWxXyYzZ'): string {
575
+    public static function randomString(int $length = 16, string $characters = 'aAbBcCdDeEfFgGhHiIjJkKlLmMnNoOpPqQrRsStTuUvVwWxXyYzZ'): string {
576 576
         $rand_string = '';
577 577
         $char_len = strlen($characters) - 1;
578
-        for ($i = 0; $i < $length; $i ++) {
578
+        for ($i = 0; $i < $length; $i++) {
579 579
             $rand_string .= $characters[rand(0, $char_len)];
580 580
         }
581 581
         return $rand_string;
@@ -604,7 +604,7 @@  discard block
 block discarded – undo
604 604
      * @return inlineKeyboardMarkup|replyKeyboardMarkup replyKeyboardMarkup for keyboard and inlineKeyboardMarkup for inline
605 605
      * @throws bptException
606 606
      */
607
-    public static function easyKey(array $keyboard = [], array $inline = []): inlineKeyboardMarkup|replyKeyboardMarkup {
607
+    public static function easyKey(array $keyboard = [], array $inline = []): inlineKeyboardMarkup | replyKeyboardMarkup {
608 608
         if (!empty($keyboard)) {
609 609
             $keyboard_object = new replyKeyboardMarkup();
610 610
             $keyboard_object->setResize_keyboard($keyboard['resize'] ?? true);
@@ -668,7 +668,7 @@  discard block
 block discarded – undo
668 668
             return $keyboard_object;
669 669
         }
670 670
         else {
671
-            logger::write("tools::eKey function used\nkeyboard or inline parameter must be set",loggerTypes::ERROR);
671
+            logger::write("tools::eKey function used\nkeyboard or inline parameter must be set", loggerTypes::ERROR);
672 672
             throw new bptException('ARGUMENT_NOT_FOUND_KEYBOARD_INLINE');
673 673
         }
674 674
     }
@@ -685,10 +685,10 @@  discard block
 block discarded – undo
685 685
      *
686 686
      * @return string
687 687
      */
688
-    public static function inviteLink (int $user_id = null, string $bot_username = null): string {
688
+    public static function inviteLink(int $user_id = null, string $bot_username = null): string {
689 689
         if (empty($user_id)) $user_id = telegram::catchFields(fields::USER_ID);
690 690
         if (empty($bot_username)) $bot_username = telegram::getMe()->username;
691
-        return 'https://t.me/' . str_replace('@', '', $bot_username) . '?start=ref_' . tools::shortEncode($user_id);
691
+        return 'https://t.me/'.str_replace('@', '', $bot_username).'?start=ref_'.tools::shortEncode($user_id);
692 692
     }
693 693
 
694 694
     /**
@@ -712,9 +712,9 @@  discard block
 block discarded – undo
712 712
      * @return string|bool|array{hash:string, key:string, iv:string}
713 713
      * @throws bptException
714 714
      */
715
-    public static function codec (string $action, string $text, string $key = null, string $iv = null): bool|array|string {
715
+    public static function codec(string $action, string $text, string $key = null, string $iv = null): bool | array | string {
716 716
         if (!extension_loaded('openssl')) {
717
-            logger::write("tools::codec function used\nopenssl extension is not found , It may not be installed or enabled",loggerTypes::ERROR);
717
+            logger::write("tools::codec function used\nopenssl extension is not found , It may not be installed or enabled", loggerTypes::ERROR);
718 718
             throw new bptException('OPENSSL_EXTENSION_MISSING');
719 719
         }
720 720
         if ($action === codecAction::ENCRYPT) {
@@ -725,17 +725,17 @@  discard block
 block discarded – undo
725 725
         }
726 726
         elseif ($action === codecAction::DECRYPT) {
727 727
             if (empty($key)) {
728
-                logger::write("tools::codec function used\nkey parameter is not set",loggerTypes::ERROR);
728
+                logger::write("tools::codec function used\nkey parameter is not set", loggerTypes::ERROR);
729 729
                 throw new bptException('ARGUMENT_NOT_FOUND_KEY');
730 730
             }
731 731
             if (empty($iv)) {
732
-                logger::write("tools::codec function used\niv parameter is not set",loggerTypes::ERROR);
732
+                logger::write("tools::codec function used\niv parameter is not set", loggerTypes::ERROR);
733 733
                 throw new bptException('ARGUMENT_NOT_FOUND_IV');
734 734
             }
735 735
             return openssl_decrypt(base64_decode($text), 'AES-256-CBC', $key, 1, $iv);
736 736
         }
737 737
         else {
738
-            logger::write("tools::codec function used\naction is not right, its must be `encode` or `decode`",loggerTypes::WARNING);
738
+            logger::write("tools::codec function used\naction is not right, its must be `encode` or `decode`", loggerTypes::WARNING);
739 739
             return false;
740 740
         }
741 741
     }
@@ -752,7 +752,7 @@  discard block
 block discarded – undo
752 752
     public static function shortEncode(int $num): string {
753 753
         $codes = '0123456789abcdefghijklmnopqrstuvwxyzABCDEFGHIJKLMNOPQRSTUVWXYZ';
754 754
         $array = [];
755
-        while ($num > 0){
755
+        while ($num > 0) {
756 756
             $array[] = $num % 62;
757 757
             $num = floor($num / 62);
758 758
         }
@@ -760,7 +760,7 @@  discard block
 block discarded – undo
760 760
         foreach ($array as &$value) {
761 761
             $value = $codes[$value];
762 762
         }
763
-        return strrev(implode('',$array));
763
+        return strrev(implode('', $array));
764 764
     }
765 765
 
766 766
     /**
@@ -777,7 +777,7 @@  discard block
 block discarded – undo
777 777
         $num = 0;
778 778
         $text = str_split(strrev($text));
779 779
         foreach ($text as $key=>$value) {
780
-            $num += strpos($codes,$value) * pow(62,$key);
780
+            $num += strpos($codes, $value) * pow(62, $key);
781 781
         }
782 782
         return $num;
783 783
     }
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
     }
@@ -260,8 +261,7 @@  discard block
 block discarded – undo
260 261
             curl_exec($ch);
261 262
             $size = curl_getinfo($ch, CURLINFO_CONTENT_LENGTH_DOWNLOAD);
262 263
             curl_close($ch);
263
-        }
264
-        else {
264
+        } else {
265 265
             $path = realpath($path);
266 266
             $size = file_exists($path) ? filesize($path) : false;
267 267
         }
@@ -332,8 +332,7 @@  discard block
 block discarded – undo
332 332
                     $zip->addFile($filePath, substr($filePath, $root_len));
333 333
                 }
334 334
             }
335
-        }
336
-        else {
335
+        } else {
337 336
             $zip->addFile($path, basename($path));
338 337
         }
339 338
         return $zip->close();
@@ -352,9 +351,13 @@  discard block
 block discarded – undo
352 351
      */
353 352
     public static function downloadFile (string $url, string $path, int $chunk_size = 512): bool {
354 353
         $file = fopen($url, 'rb');
355
-        if (!$file) return false;
354
+        if (!$file) {
355
+            return false;
356
+        }
356 357
         $path = fopen($path, 'wb');
357
-        if (!$path) return false;
358
+        if (!$path) {
359
+            return false;
360
+        }
358 361
 
359 362
         $length = $chunk_size * 1024;
360 363
         while (!feof($file)){
@@ -461,8 +464,9 @@  discard block
 block discarded – undo
461 464
         foreach ($string as $k => &$v) {
462 465
             if ($diff->$v) {
463 466
                 $v = $diff->$v;
467
+            } else {
468
+                unset($string[$k]);
464 469
             }
465
-            else unset($string[$k]);
466 470
         }
467 471
         $string['status'] = $base_time < $target_time ? 'later' : 'ago';
468 472
 
@@ -528,8 +532,7 @@  discard block
 block discarded – undo
528 532
             if ($last === "\0") {
529 533
                 $new .= str_repeat($last, ord($char));
530 534
                 $last = '';
531
-            }
532
-            else {
535
+            } else {
533 536
                 $new .= $last;
534 537
                 $last = $char;
535 538
             }
@@ -613,7 +616,9 @@  discard block
 block discarded – undo
613 616
             }
614 617
             $rows = [];
615 618
             foreach ($keyboard as $row) {
616
-                if (!is_array($row)) continue;
619
+                if (!is_array($row)) {
620
+                    continue;
621
+                }
617 622
                 $buttons = [];
618 623
                 foreach ($row as $base_button) {
619 624
                     $button_info = explode('||', $base_button);
@@ -622,15 +627,12 @@  discard block
 block discarded – undo
622 627
                     if (count($button_info) > 1) {
623 628
                         if ($button_info[1] === 'con') {
624 629
                             $button->setRequest_contact(true);
625
-                        }
626
-                        elseif ($button_info[1] === 'loc') {
630
+                        } elseif ($button_info[1] === 'loc') {
627 631
                             $button->setRequest_location(true);
628
-                        }
629
-                        elseif ($button_info[1] === 'poll') {
632
+                        } elseif ($button_info[1] === 'poll') {
630 633
                             $type = $button_info[2] === pollType::QUIZ ? pollType::QUIZ : pollType::REGULAR;
631 634
                             $button->setRequest_poll((new keyboardButtonPollType())->setType($type));
632
-                        }
633
-                        elseif ($button_info[1] === 'web' && isset($button_info[2])) {
635
+                        } elseif ($button_info[1] === 'web' && isset($button_info[2])) {
634 636
                             $url = $button_info[2];
635 637
                             $button->setWeb_app((new webAppInfo())->setUrl($url));
636 638
                         }
@@ -641,8 +643,7 @@  discard block
 block discarded – undo
641 643
             }
642 644
             $keyboard_object->setKeyboard($rows);
643 645
             return $keyboard_object;
644
-        }
645
-        elseif (!empty($inline)) {
646
+        } elseif (!empty($inline)) {
646 647
             $keyboard_object = new inlineKeyboardMarkup();
647 648
             $rows = [];
648 649
             foreach ($inline as $row) {
@@ -652,12 +653,10 @@  discard block
 block discarded – undo
652 653
                     if (isset($button_info[1])) {
653 654
                         if (filter_var($button_info[1], FILTER_VALIDATE_URL) && str_starts_with($button_info[1], 'http')) {
654 655
                             $button->setText($button_info[0])->setUrl($button_info[1]);
655
-                        }
656
-                        else {
656
+                        } else {
657 657
                             $button->setText($button_info[0])->setCallback_data($button_info[1]);
658 658
                         }
659
-                    }
660
-                    else {
659
+                    } else {
661 660
                         $button->setText($button_info[0])->setUrl('https://t.me/BPT_CH');
662 661
                     }
663 662
                     $buttons[] = $button;
@@ -666,8 +665,7 @@  discard block
 block discarded – undo
666 665
             }
667 666
             $keyboard_object->setInline_keyboard($rows);
668 667
             return $keyboard_object;
669
-        }
670
-        else {
668
+        } else {
671 669
             logger::write("tools::eKey function used\nkeyboard or inline parameter must be set",loggerTypes::ERROR);
672 670
             throw new bptException('ARGUMENT_NOT_FOUND_KEYBOARD_INLINE');
673 671
         }
@@ -686,8 +684,12 @@  discard block
 block discarded – undo
686 684
      * @return string
687 685
      */
688 686
     public static function inviteLink (int $user_id = null, string $bot_username = null): string {
689
-        if (empty($user_id)) $user_id = telegram::catchFields(fields::USER_ID);
690
-        if (empty($bot_username)) $bot_username = telegram::getMe()->username;
687
+        if (empty($user_id)) {
688
+            $user_id = telegram::catchFields(fields::USER_ID);
689
+        }
690
+        if (empty($bot_username)) {
691
+            $bot_username = telegram::getMe()->username;
692
+        }
691 693
         return 'https://t.me/' . str_replace('@', '', $bot_username) . '?start=ref_' . tools::shortEncode($user_id);
692 694
     }
693 695
 
@@ -722,8 +724,7 @@  discard block
 block discarded – undo
722 724
             $iv = self::randomString();
723 725
             $output = base64_encode(openssl_encrypt($text, 'AES-256-CBC', $key, 1, $iv));
724 726
             return ['hash' => $output, 'key' => $key, 'iv' => $iv];
725
-        }
726
-        elseif ($action === codecAction::DECRYPT) {
727
+        } elseif ($action === codecAction::DECRYPT) {
727 728
             if (empty($key)) {
728 729
                 logger::write("tools::codec function used\nkey parameter is not set",loggerTypes::ERROR);
729 730
                 throw new bptException('ARGUMENT_NOT_FOUND_KEY');
@@ -733,8 +734,7 @@  discard block
 block discarded – undo
733 734
                 throw new bptException('ARGUMENT_NOT_FOUND_IV');
734 735
             }
735 736
             return openssl_decrypt(base64_decode($text), 'AES-256-CBC', $key, 1, $iv);
736
-        }
737
-        else {
737
+        } else {
738 738
             logger::write("tools::codec function used\naction is not right, its must be `encode` or `decode`",loggerTypes::WARNING);
739 739
             return false;
740 740
         }
@@ -756,7 +756,9 @@  discard block
 block discarded – undo
756 756
             $array[] = $num % 62;
757 757
             $num = floor($num / 62);
758 758
         }
759
-        if (count($array) < 1) $array = [0];
759
+        if (count($array) < 1) {
760
+            $array = [0];
761
+        }
760 762
         foreach ($array as &$value) {
761 763
             $value = $codes[$value];
762 764
         }
Please login to merge, or discard this patch.
src/types/videoNote.php 1 patch
Spacing   +5 added lines, -5 removed lines patch added patch discarded remove patch
@@ -28,13 +28,13 @@  discard block
 block discarded – undo
28 28
     public int $duration;
29 29
 
30 30
     /** Optional. Video thumbnail */
31
-    public null|photoSize $thumbnail = null;
31
+    public null | photoSize $thumbnail = null;
32 32
 
33 33
     /** Optional. File size in bytes */
34
-    public null|int $file_size = null;
34
+    public null | int $file_size = null;
35 35
 
36 36
 
37
-    public function __construct(stdClass|null $object = null) {
37
+    public function __construct(stdClass | null $object = null) {
38 38
         if ($object != null) {
39 39
             parent::__construct($object, self::subs);
40 40
         }
@@ -55,8 +55,8 @@  discard block
 block discarded – undo
55 55
      *
56 56
      * @return bool|string string will be returned when destination doesn't set
57 57
      */
58
-    public function download(string|null $destination = null): bool|string {
59
-        return telegram::downloadFile($destination ?? 'unknown.mp4',$this->file_id);
58
+    public function download(string | null $destination = null): bool | string {
59
+        return telegram::downloadFile($destination ?? 'unknown.mp4', $this->file_id);
60 60
     }
61 61
 
62 62
     public function link(): string {
Please login to merge, or discard this patch.
src/types/inputMedia.php 1 patch
Spacing   +2 added lines, -2 removed lines patch added patch discarded remove patch
@@ -56,7 +56,7 @@  discard block
 block discarded – undo
56 56
      * be reused and can be only uploaded as a new file, so you can pass “attach://<file_attach_name>” if the
57 57
      * thumbnail was uploaded using multipart/form-data under <file_attach_name>.
58 58
      */
59
-    public CURLFile|string $thumbnail;
59
+    public CURLFile | string $thumbnail;
60 60
 
61 61
     /** `video` and `animation` only. width */
62 62
     public int $width;
@@ -83,7 +83,7 @@  discard block
 block discarded – undo
83 83
     public bool $disable_content_type_detection;
84 84
 
85 85
 
86
-    public function __construct(stdClass|null $object = null) {
86
+    public function __construct(stdClass | null $object = null) {
87 87
         if ($object != null) {
88 88
             parent::__construct($object, self::subs);
89 89
         }
Please login to merge, or discard this patch.
src/types/animation.php 1 patch
Spacing   +7 added lines, -7 removed lines patch added patch discarded remove patch
@@ -31,23 +31,23 @@  discard block
 block discarded – undo
31 31
     public int $duration;
32 32
 
33 33
     /** Optional. Animation thumbnail as defined by sender */
34
-    public null|photoSize $thumbnail = null;
34
+    public null | photoSize $thumbnail = null;
35 35
 
36 36
     /** Optional. Original animation filename as defined by sender */
37
-    public null|string $file_name = null;
37
+    public null | string $file_name = null;
38 38
 
39 39
     /** Optional. MIME type of the file as defined by sender */
40
-    public null|string $mime_type = null;
40
+    public null | string $mime_type = null;
41 41
 
42 42
     /**
43 43
      * Optional. File size in bytes. It can be bigger than 2^31 and some programming languages may have
44 44
      * difficulty/silent defects in interpreting it. But it has at most 52 significant bits, so a signed 64-bit
45 45
      * integer or double-precision float type are safe for storing this value.
46 46
      */
47
-    public null|int $file_size = null;
47
+    public null | int $file_size = null;
48 48
 
49 49
 
50
-    public function __construct(stdClass|null $object = null) {
50
+    public function __construct(stdClass | null $object = null) {
51 51
         if ($object != null) {
52 52
             parent::__construct($object, self::subs);
53 53
         }
@@ -68,8 +68,8 @@  discard block
 block discarded – undo
68 68
      *
69 69
      * @return bool|string string will be returned when destination doesn't set
70 70
      */
71
-    public function download(string|null $destination = null): bool|string {
72
-        return telegram::downloadFile($destination ?? $this->file_name ?? 'unknown.gif',$this->file_id);
71
+    public function download(string | null $destination = null): bool | string {
72
+        return telegram::downloadFile($destination ?? $this->file_name ?? 'unknown.gif', $this->file_id);
73 73
     }
74 74
 
75 75
     public function link(): string {
Please login to merge, or discard this patch.
src/types/botShortDescription.php 1 patch
Spacing   +1 added lines, -1 removed lines patch added patch discarded remove patch
@@ -15,7 +15,7 @@
 block discarded – undo
15 15
     public string $short_description;
16 16
 
17 17
 
18
-    public function __construct(stdClass|null $object = null) {
18
+    public function __construct(stdClass | null $object = null) {
19 19
         if ($object != null) {
20 20
             parent::__construct($object, self::subs);
21 21
         }
Please login to merge, or discard this patch.
src/types/inputSticker.php 1 patch
Spacing   +2 added lines, -2 removed lines patch added patch discarded remove patch
@@ -18,7 +18,7 @@  discard block
 block discarded – undo
18 18
      * multipart/form-data. Animated and video stickers can't be uploaded via HTTP URL. More information on Sending
19 19
      * Files »
20 20
      */
21
-    public string|CURLFile $sticker;
21
+    public string | CURLFile $sticker;
22 22
 
23 23
     /**
24 24
      * List of 1-20 emoji associated with the sticker
@@ -37,7 +37,7 @@  discard block
 block discarded – undo
37 37
     public array $keywords;
38 38
 
39 39
 
40
-    public function __construct(stdClass|null $object = null) {
40
+    public function __construct(stdClass | null $object = null) {
41 41
         if ($object != null) {
42 42
             parent::__construct($object, self::subs);
43 43
         }
Please login to merge, or discard this patch.
src/types/audio.php 1 patch
Spacing   +9 added lines, -9 removed lines patch added patch discarded remove patch
@@ -25,29 +25,29 @@  discard block
 block discarded – undo
25 25
     public int $duration;
26 26
 
27 27
     /** Optional. Performer of the audio as defined by sender or by audio tags */
28
-    public null|string $performer = null;
28
+    public null | string $performer = null;
29 29
 
30 30
     /** Optional. Title of the audio as defined by sender or by audio tags */
31
-    public null|string $title = null;
31
+    public null | string $title = null;
32 32
 
33 33
     /** Optional. Original filename as defined by sender */
34
-    public null|string $file_name = null;
34
+    public null | string $file_name = null;
35 35
 
36 36
     /** Optional. MIME type of the file as defined by sender */
37
-    public null|string $mime_type = null;
37
+    public null | string $mime_type = null;
38 38
 
39 39
     /**
40 40
      * Optional. File size in bytes. It can be bigger than 2^31 and some programming languages may have
41 41
      * difficulty/silent defects in interpreting it. But it has at most 52 significant bits, so a signed 64-bit
42 42
      * integer or double-precision float type are safe for storing this value.
43 43
      */
44
-    public null|int $file_size = null;
44
+    public null | int $file_size = null;
45 45
 
46 46
     /** Optional. Thumbnail of the album cover to which the music file belongs */
47
-    public null|photoSize $thumbnail = null;
47
+    public null | photoSize $thumbnail = null;
48 48
 
49 49
 
50
-    public function __construct(stdClass|null $object = null) {
50
+    public function __construct(stdClass | null $object = null) {
51 51
         if ($object != null) {
52 52
             parent::__construct($object, self::subs);
53 53
         }
@@ -68,8 +68,8 @@  discard block
 block discarded – undo
68 68
      *
69 69
      * @return bool|string string will be returned when destination doesn't set
70 70
      */
71
-    public function download(string|null $destination = null): bool|string {
72
-        return telegram::downloadFile($destination ?? $this->file_name ?? 'unknown.mp3',$this->file_id);
71
+    public function download(string | null $destination = null): bool | string {
72
+        return telegram::downloadFile($destination ?? $this->file_name ?? 'unknown.mp3', $this->file_id);
73 73
     }
74 74
 
75 75
     public function link(): string {
Please login to merge, or discard this patch.
src/types/video.php 1 patch
Spacing   +7 added lines, -7 removed lines patch added patch discarded remove patch
@@ -31,23 +31,23 @@  discard block
 block discarded – undo
31 31
     public int $duration;
32 32
 
33 33
     /** Optional. Video thumbnail */
34
-    public null|photoSize $thumbnail = null;
34
+    public null | photoSize $thumbnail = null;
35 35
 
36 36
     /** Optional. Original filename as defined by sender */
37
-    public null|string $file_name = null;
37
+    public null | string $file_name = null;
38 38
 
39 39
     /** Optional. MIME type of the file as defined by sender */
40
-    public null|string $mime_type = null;
40
+    public null | string $mime_type = null;
41 41
 
42 42
     /**
43 43
      * Optional. File size in bytes. It can be bigger than 2^31 and some programming languages may have
44 44
      * difficulty/silent defects in interpreting it. But it has at most 52 significant bits, so a signed 64-bit
45 45
      * integer or double-precision float type are safe for storing this value.
46 46
      */
47
-    public null|int $file_size = null;
47
+    public null | int $file_size = null;
48 48
 
49 49
 
50
-    public function __construct(stdClass|null $object = null) {
50
+    public function __construct(stdClass | null $object = null) {
51 51
         if ($object != null) {
52 52
             parent::__construct($object, self::subs);
53 53
         }
@@ -68,8 +68,8 @@  discard block
 block discarded – undo
68 68
      *
69 69
      * @return bool|string string will be returned when destination doesn't set
70 70
      */
71
-    public function download(string|null $destination = null): bool|string {
72
-        return telegram::downloadFile($destination ?? $this->file_name ?? 'unknown.mp4',$this->file_id);
71
+    public function download(string | null $destination = null): bool | string {
72
+        return telegram::downloadFile($destination ?? $this->file_name ?? 'unknown.mp4', $this->file_id);
73 73
     }
74 74
 
75 75
     public function link(): string {
Please login to merge, or discard this patch.