Skip to content
Projects
Groups
Snippets
Help
Loading...
Help
Submit feedback
Contribute to GitLab
Sign in
Toggle navigation
TelegramBot
Project
Project
Details
Activity
Releases
Cycle Analytics
Repository
Repository
Files
Commits
Branches
Tags
Contributors
Graph
Compare
Charts
Issues
0
Issues
0
List
Boards
Labels
Milestones
Merge Requests
0
Merge Requests
0
CI / CD
CI / CD
Pipelines
Jobs
Schedules
Charts
Wiki
Wiki
Snippets
Snippets
Members
Members
Collapse sidebar
Close sidebar
Activity
Graph
Charts
Create a new issue
Jobs
Commits
Issue Boards
Open sidebar
Kulya
TelegramBot
Commits
f8fd4b04
Commit
f8fd4b04
authored
Feb 01, 2016
by
Marco Boretto
Browse files
Options
Browse Files
Download
Plain Diff
Merge pull request #79 from noplanman/code_cleanup_Request
Code cleanup of Request.php
parents
1dfe672c
eed305b7
Changes
1
Show whitespace changes
Inline
Side-by-side
Showing
1 changed file
with
265 additions
and
101 deletions
+265
-101
Request.php
src/Request.php
+265
-101
No files found.
src/Request.php
View file @
f8fd4b04
<?php
<?php
/*
/*
* This file is part of the TelegramBot package.
* This file is part of the TelegramBot package.
*
*
...
@@ -7,19 +6,38 @@
...
@@ -7,19 +6,38 @@
*
*
* For the full copyright and license information, please view the LICENSE
* For the full copyright and license information, please view the LICENSE
* file that was distributed with this source code.
* file that was distributed with this source code.
*/
*/
namespace
Longman\TelegramBot
;
namespace
Longman\TelegramBot
;
use
Longman\TelegramBot\Exception\TelegramException
;
use
Longman\TelegramBot\Entities\ServerResponse
;
use
Longman\TelegramBot\Entities\File
;
use
Longman\TelegramBot\Entities\File
;
use
Longman\TelegramBot\Entities\ServerResponse
;
use
Longman\TelegramBot\Exception\TelegramException
;
class
Request
class
Request
{
{
/**
* Telegram object
*
* @var Telegram
*/
private
static
$telegram
;
private
static
$telegram
;
/**
* Input value of the request
*
* @var string
*/
private
static
$input
;
private
static
$input
;
private
static
$methods
=
array
(
/**
* Available methods to request
*
* @todo Possibly rename to "actions"?
*
* @var array
*/
private
static
$methods
=
[
'getMe'
,
'getMe'
,
'sendMessage'
,
'sendMessage'
,
'forwardMessage'
,
'forwardMessage'
,
...
@@ -35,9 +53,14 @@ class Request
...
@@ -35,9 +53,14 @@ class Request
'getUpdates'
,
'getUpdates'
,
'setWebhook'
,
'setWebhook'
,
'getFile'
,
'getFile'
,
'answerInlineQuery'
'answerInlineQuery'
,
)
;
]
;
/**
* Initialize
*
* @param Telegram $telegram
*/
public
static
function
initialize
(
Telegram
$telegram
)
public
static
function
initialize
(
Telegram
$telegram
)
{
{
if
(
is_object
(
$telegram
))
{
if
(
is_object
(
$telegram
))
{
...
@@ -47,15 +70,28 @@ class Request
...
@@ -47,15 +70,28 @@ class Request
}
}
}
}
/**
* Set raw input data string
*
* @todo Possibly set this to private, since getInput overwrites the input anyway
* @todo Why the "| $input == false"?
*
* @param string $input
*/
public
static
function
setInputRaw
(
$input
)
public
static
function
setInputRaw
(
$input
)
{
{
if
(
is_string
(
$input
)
|
$input
==
false
)
{
if
(
is_string
(
$input
)
|
$input
==
false
)
{
self
::
$input
=
$input
;
self
::
$input
=
$input
;
}
else
{
}
else
{
throw
new
TelegramException
(
"Log input is not a string"
);
throw
new
TelegramException
(
'Input must be a string!'
);
}
}
}
}
/**
* Set input from update or stdin and return it
*
* @return string
*/
public
static
function
getInput
()
public
static
function
getInput
()
{
{
if
(
$update
=
self
::
$telegram
->
getCustomUpdate
())
{
if
(
$update
=
self
::
$telegram
->
getCustomUpdate
())
{
...
@@ -67,30 +103,43 @@ class Request
...
@@ -67,30 +103,43 @@ class Request
return
self
::
$input
;
return
self
::
$input
;
}
}
/**
* Write log entry
*
* @todo Take log verbosity into account
*
* @param string $string
* @return mixed
*/
private
static
function
log
(
$string
)
private
static
function
log
(
$string
)
{
{
if
(
!
self
::
$telegram
->
getLogRequests
())
{
if
(
!
self
::
$telegram
->
getLogRequests
())
{
return
false
;
return
false
;
}
}
$path
=
self
::
$telegram
->
getLogPath
();
$path
=
self
::
$telegram
->
getLogPath
();
if
(
!
$path
)
{
if
(
!
$path
)
{
return
false
;
return
false
;
}
}
$status
=
file_put_contents
(
$path
,
$string
.
"
\n
"
,
FILE_APPEND
);
return
file_put_contents
(
$path
,
$string
.
"
\n
"
,
FILE_APPEND
);
return
$status
;
}
}
public
static
function
generateGeneralFakeServerResponse
(
$data
=
null
)
/**
* Generate general fake server response
*
* @param array $data Data to add to fake response
* @return array Fake response data
*/
public
static
function
generateGeneralFakeServerResponse
(
array
$data
=
null
)
{
{
//PARAM BINDED IN PHPUNIT TEST FOR TestServerResponse.php
//PARAM BINDED IN PHPUNIT TEST FOR TestServerResponse.php
//Maybe this is not the best possible implementation
//Maybe this is not the best possible implementation
//No value set in $data ie testing setWe
k
hook
//No value set in $data ie testing setWe
b
hook
//Provided $data['chat_id'] ie testing sendMessage
//Provided $data['chat_id'] ie testing sendMessage
$fake_response
[
'ok'
]
=
true
;
// :)
$fake_response
=
[
'ok'
=>
true
]
;
// :)
if
(
!
isset
(
$data
))
{
if
(
!
isset
(
$data
))
{
$fake_response
[
'result'
]
=
true
;
$fake_response
[
'result'
]
=
true
;
...
@@ -100,13 +149,12 @@ class Request
...
@@ -100,13 +149,12 @@ class Request
if
(
isset
(
$data
[
'chat_id'
]))
{
if
(
isset
(
$data
[
'chat_id'
]))
{
$data
[
'message_id'
]
=
'1234'
;
$data
[
'message_id'
]
=
'1234'
;
$data
[
'date'
]
=
'1441378360'
;
$data
[
'date'
]
=
'1441378360'
;
$data
[
'from'
]
=
array
(
$data
[
'from'
]
=
[
'id'
=>
123456789
,
'id'
=>
123456789
,
'first_name'
=>
'first_name'
=>
'botname'
,
'botname'
,
'username'
=>
'namebot'
,
'username'
=>
'namebot'
];
);
$data
[
'chat'
]
=
[
'id'
=>
$data
[
'chat_id'
]];
$data
[
'chat'
]
=
array
(
'id'
=>
$data
[
'chat_id'
]
);
$fake_response
[
'result'
]
=
$data
;
$fake_response
[
'result'
]
=
$data
;
}
}
...
@@ -114,20 +162,26 @@ class Request
...
@@ -114,20 +162,26 @@ class Request
return
$fake_response
;
return
$fake_response
;
}
}
/**
* Execute cURL call
*
* @param string $action Action to execute
* @param array|null $data Data to attach to the execution
* @return mixed Result of the cURL call
*/
public
static
function
executeCurl
(
$action
,
array
$data
=
null
)
public
static
function
executeCurl
(
$action
,
array
$data
=
null
)
{
{
$ch
=
curl_init
();
$ch
=
curl_init
();
if
(
$ch
===
false
)
{
if
(
$ch
===
false
)
{
throw
new
TelegramException
(
'Curl failed to initialize'
);
throw
new
TelegramException
(
'Curl failed to initialize'
);
}
}
$curlConfig
=
array
(
$curlConfig
=
[
CURLOPT_URL
=>
'https://api.telegram.org/bot'
.
self
::
$telegram
->
getApiKey
()
.
'/'
.
$action
,
CURLOPT_URL
=>
'https://api.telegram.org/bot'
.
self
::
$telegram
->
getApiKey
()
.
'/'
.
$action
,
CURLOPT_POST
=>
true
,
CURLOPT_POST
=>
true
,
CURLOPT_RETURNTRANSFER
=>
true
,
CURLOPT_RETURNTRANSFER
=>
true
,
CURLOPT_SAFE_UPLOAD
=>
true
CURLOPT_SAFE_UPLOAD
=>
true
,
)
;
]
;
if
(
!
empty
(
$data
))
{
if
(
!
empty
(
$data
))
{
$curlConfig
[
CURLOPT_POSTFIELDS
]
=
$data
;
$curlConfig
[
CURLOPT_POSTFIELDS
]
=
$data
;
...
@@ -146,7 +200,7 @@ class Request
...
@@ -146,7 +200,7 @@ class Request
if
(
self
::
$telegram
->
getLogVerbosity
()
>=
3
)
{
if
(
self
::
$telegram
->
getLogVerbosity
()
>=
3
)
{
rewind
(
$verbose
);
rewind
(
$verbose
);
$verboseLog
=
stream_get_contents
(
$verbose
);
$verboseLog
=
stream_get_contents
(
$verbose
);
self
::
log
(
"Verbose curl output:
\n
"
.
htmlspecialchars
(
$verboseLog
)
.
"
\n
"
);
self
::
log
(
'Verbose curl output:'
.
"
\n
"
.
htmlspecialchars
(
$verboseLog
)
.
"
\n
"
);
}
}
//Logging getUpdates Update
//Logging getUpdates Update
...
@@ -169,24 +223,30 @@ class Request
...
@@ -169,24 +223,30 @@ class Request
return
$result
;
return
$result
;
}
}
/**
* Download file
*
* @param Entities\File $file
* @return boolean
*/
public
static
function
downloadFile
(
File
$file
)
public
static
function
downloadFile
(
File
$file
)
{
{
$path
=
$file
->
getFilePath
();
$path
=
$file
->
getFilePath
();
#
Create the directory
//
Create the directory
$basepath
=
self
::
$telegram
->
getDownloadPath
();
$basepath
=
self
::
$telegram
->
getDownloadPath
();
$loc_path
=
$basepath
.
'/'
.
$path
;
$loc_path
=
$basepath
.
'/'
.
$path
;
$dirname
=
dirname
(
$loc_path
);
$dirname
=
dirname
(
$loc_path
);
if
(
!
is_dir
(
$dirname
))
{
if
(
!
is_dir
(
$dirname
))
{
if
(
!
mkdir
(
$dirname
,
0755
,
true
))
{
if
(
!
mkdir
(
$dirname
,
0755
,
true
))
{
throw
new
TelegramException
(
'Directory '
.
$dirname
.
' can
t be created'
);
throw
new
TelegramException
(
'Directory '
.
$dirname
.
' can\'
t be created'
);
}
}
}
}
//
o
pen file to write
//
O
pen file to write
$fp
=
fopen
(
$loc_path
,
'w+'
);
$fp
=
fopen
(
$loc_path
,
'w+'
);
if
(
$fp
===
false
)
{
if
(
$fp
===
false
)
{
throw
new
TelegramException
(
'File cant be created'
);
throw
new
TelegramException
(
'File can
\'
t be created'
);
}
}
$ch
=
curl_init
();
$ch
=
curl_init
();
...
@@ -194,60 +254,85 @@ class Request
...
@@ -194,60 +254,85 @@ class Request
throw
new
TelegramException
(
'Curl failed to initialize'
);
throw
new
TelegramException
(
'Curl failed to initialize'
);
}
}
$curlConfig
=
array
(
$curlConfig
=
[
CURLOPT_URL
=>
'https://api.telegram.org/file/bot'
.
self
::
$telegram
->
getApiKey
()
.
'/'
.
$path
,
CURLOPT_URL
=>
'https://api.telegram.org/file/bot'
.
self
::
$telegram
->
getApiKey
()
.
'/'
.
$path
,
CURLOPT_RETURNTRANSFER
=>
true
,
CURLOPT_RETURNTRANSFER
=>
true
,
CURLOPT_HEADER
=>
0
,
CURLOPT_HEADER
=>
0
,
CURLOPT_BINARYTRANSFER
=>
true
,
CURLOPT_BINARYTRANSFER
=>
true
,
CURLOPT_CONNECTTIMEOUT
=>
10
,
CURLOPT_CONNECTTIMEOUT
=>
10
,
CURLOPT_FILE
=>
$fp
CURLOPT_FILE
=>
$fp
,
)
;
]
;
curl_setopt_array
(
$ch
,
$curlConfig
);
curl_setopt_array
(
$ch
,
$curlConfig
);
$result
=
curl_exec
(
$ch
);
$result
=
curl_exec
(
$ch
);
if
(
$result
===
false
)
{
if
(
$result
===
false
)
{
throw
new
TelegramException
(
curl_error
(
$ch
),
curl_errno
(
$ch
));
throw
new
TelegramException
(
curl_error
(
$ch
),
curl_errno
(
$ch
));
}
}
// close curl
//Close curl
curl_close
(
$ch
);
curl_close
(
$ch
);
//
c
lose local file
//
C
lose local file
fclose
(
$fp
);
fclose
(
$fp
);
if
(
filesize
(
$loc_path
)
>
0
)
{
return
(
filesize
(
$loc_path
)
>
0
);
return
true
;
}
else
{
return
false
;
}
}
}
/**
* Encode file
*
* @param string $file
* @return CURLFile
*/
protected
static
function
encodeFile
(
$file
)
protected
static
function
encodeFile
(
$file
)
{
{
return
new
\CURLFile
(
$file
);
return
new
\CURLFile
(
$file
);
}
}
/**
* Send command
*
* @todo Fake response doesn't need json encoding?
* @todo Rename "methods" to "actions"
*
* @param string $action
* @param array|null $data
* @return Entities\ServerResponse
*/
public
static
function
send
(
$action
,
array
$data
=
null
)
public
static
function
send
(
$action
,
array
$data
=
null
)
{
{
if
(
!
in_array
(
$action
,
self
::
$methods
))
{
if
(
!
in_array
(
$action
,
self
::
$methods
))
{
throw
new
TelegramException
(
'This method
s
doesn\'t exist!'
);
throw
new
TelegramException
(
'This method doesn\'t exist!'
);
}
}
$bot_name
=
self
::
$telegram
->
getBotName
();
if
(
defined
(
'PHPUNIT_TESTSUITE'
))
{
if
(
defined
(
'PHPUNIT_TESTSUITE'
))
{
$fake_response
=
self
::
generateGeneralFakeServerResponse
(
$data
);
$fake_response
=
self
::
generateGeneralFakeServerResponse
(
$data
);
return
new
ServerResponse
(
$fake_response
,
self
::
$telegram
->
getBotName
()
);
return
new
ServerResponse
(
$fake_response
,
$bot_name
);
}
}
$result
=
self
::
executeCurl
(
$action
,
$data
);
$response
=
self
::
executeCurl
(
$action
,
$data
);
return
new
ServerResponse
(
json_decode
(
$response
,
true
),
$bot_name
);
$bot_name
=
self
::
$telegram
->
getBotName
();
return
new
ServerResponse
(
json_decode
(
$result
,
true
),
$bot_name
);
}
}
/**
* Get me
*
* @return mixed
*/
public
static
function
getMe
()
public
static
function
getMe
()
{
{
$result
=
self
::
send
(
'getMe'
);
return
self
::
send
(
'getMe'
);
return
$result
;
}
}
/**
* Send message
*
* @todo Could do with some cleaner recursion
*
* @param array $data
* @return mixed
*/
public
static
function
sendMessage
(
array
$data
)
public
static
function
sendMessage
(
array
$data
)
{
{
if
(
empty
(
$data
))
{
if
(
empty
(
$data
))
{
...
@@ -261,21 +346,31 @@ class Request
...
@@ -261,21 +346,31 @@ class Request
$data
[
'text'
]
=
mb_substr
(
$text
,
4096
,
$string_len_utf8
);
$data
[
'text'
]
=
mb_substr
(
$text
,
4096
,
$string_len_utf8
);
return
self
::
sendMessage
(
$data
);
return
self
::
sendMessage
(
$data
);
}
}
$result
=
self
::
send
(
'sendMessage'
,
$data
);
return
self
::
send
(
'sendMessage'
,
$data
);
return
$result
;
}
}
/**
* Forward message
*
* @param array $data
* @return mixed
*/
public
static
function
forwardMessage
(
array
$data
)
public
static
function
forwardMessage
(
array
$data
)
{
{
if
(
empty
(
$data
))
{
if
(
empty
(
$data
))
{
throw
new
TelegramException
(
'Data is empty!'
);
throw
new
TelegramException
(
'Data is empty!'
);
}
}
$result
=
self
::
send
(
'forwardMessage'
,
$data
);
return
self
::
send
(
'forwardMessage'
,
$data
);
return
$result
;
}
}
/**
* Send photo
*
* @param array $data
* @param string $file
* @return mixed
*/
public
static
function
sendPhoto
(
array
$data
,
$file
=
null
)
public
static
function
sendPhoto
(
array
$data
,
$file
=
null
)
{
{
if
(
empty
(
$data
))
{
if
(
empty
(
$data
))
{
...
@@ -286,10 +381,16 @@ class Request
...
@@ -286,10 +381,16 @@ class Request
$data
[
'photo'
]
=
self
::
encodeFile
(
$file
);
$data
[
'photo'
]
=
self
::
encodeFile
(
$file
);
}
}
$result
=
self
::
send
(
'sendPhoto'
,
$data
);
return
self
::
send
(
'sendPhoto'
,
$data
);
return
$result
;
}
}
/**
* Send audio
*
* @param array $data
* @param string $file
* @return mixed
*/
public
static
function
sendAudio
(
array
$data
,
$file
=
null
)
public
static
function
sendAudio
(
array
$data
,
$file
=
null
)
{
{
if
(
empty
(
$data
))
{
if
(
empty
(
$data
))
{
...
@@ -300,10 +401,16 @@ class Request
...
@@ -300,10 +401,16 @@ class Request
$data
[
'audio'
]
=
self
::
encodeFile
(
$file
);
$data
[
'audio'
]
=
self
::
encodeFile
(
$file
);
}
}
$result
=
self
::
send
(
'sendAudio'
,
$data
);
return
self
::
send
(
'sendAudio'
,
$data
);
return
$result
;
}
}
/**
* Send document
*
* @param array $data
* @param string $file
* @return mixed
*/
public
static
function
sendDocument
(
array
$data
,
$file
=
null
)
public
static
function
sendDocument
(
array
$data
,
$file
=
null
)
{
{
if
(
empty
(
$data
))
{
if
(
empty
(
$data
))
{
...
@@ -314,10 +421,16 @@ class Request
...
@@ -314,10 +421,16 @@ class Request
$data
[
'document'
]
=
self
::
encodeFile
(
$file
);
$data
[
'document'
]
=
self
::
encodeFile
(
$file
);
}
}
$result
=
self
::
send
(
'sendDocument'
,
$data
);
return
self
::
send
(
'sendDocument'
,
$data
);
return
$result
;
}
}
/**
* Send sticker
*
* @param array $data
* @param string $file
* @return mixed
*/
public
static
function
sendSticker
(
array
$data
,
$file
=
null
)
public
static
function
sendSticker
(
array
$data
,
$file
=
null
)
{
{
if
(
empty
(
$data
))
{
if
(
empty
(
$data
))
{
...
@@ -328,10 +441,16 @@ class Request
...
@@ -328,10 +441,16 @@ class Request
$data
[
'sticker'
]
=
self
::
encodeFile
(
$file
);
$data
[
'sticker'
]
=
self
::
encodeFile
(
$file
);
}
}
$result
=
self
::
send
(
'sendSticker'
,
$data
);
return
self
::
send
(
'sendSticker'
,
$data
);
return
$result
;
}
}
/**
* Send video
*
* @param array $data
* @param string $file
* @return mixed
*/
public
static
function
sendVideo
(
array
$data
,
$file
=
null
)
public
static
function
sendVideo
(
array
$data
,
$file
=
null
)
{
{
if
(
empty
(
$data
))
{
if
(
empty
(
$data
))
{
...
@@ -342,10 +461,16 @@ class Request
...
@@ -342,10 +461,16 @@ class Request
$data
[
'video'
]
=
self
::
encodeFile
(
$file
);
$data
[
'video'
]
=
self
::
encodeFile
(
$file
);
}
}
$result
=
self
::
send
(
'sendVideo'
,
$data
);
return
self
::
send
(
'sendVideo'
,
$data
);
return
$result
;
}
}
/**
* Send voice
*
* @param array $data
* @param string $file
* @return mixed
*/
public
static
function
sendVoice
(
array
$data
,
$file
=
null
)
public
static
function
sendVoice
(
array
$data
,
$file
=
null
)
{
{
if
(
empty
(
$data
))
{
if
(
empty
(
$data
))
{
...
@@ -356,89 +481,129 @@ class Request
...
@@ -356,89 +481,129 @@ class Request
$data
[
'voice'
]
=
self
::
encodeFile
(
$file
);
$data
[
'voice'
]
=
self
::
encodeFile
(
$file
);
}
}
$result
=
self
::
send
(
'sendVoice'
,
$data
);
return
self
::
send
(
'sendVoice'
,
$data
);
return
$result
;
}
}
/**
* Send location
*
* @param array $data
* @return mixed
*/
public
static
function
sendLocation
(
array
$data
)
public
static
function
sendLocation
(
array
$data
)
{
{
if
(
empty
(
$data
))
{
if
(
empty
(
$data
))
{
throw
new
TelegramException
(
'Data is empty!'
);
throw
new
TelegramException
(
'Data is empty!'
);
}
}
$result
=
self
::
send
(
'sendLocation'
,
$data
);
return
self
::
send
(
'sendLocation'
,
$data
);
return
$result
;
}
}
/**
* Send chat action
*
* @param array $data
* @return mixed
*/
public
static
function
sendChatAction
(
array
$data
)
public
static
function
sendChatAction
(
array
$data
)
{
{
if
(
empty
(
$data
))
{
if
(
empty
(
$data
))
{
throw
new
TelegramException
(
'Data is empty!'
);
throw
new
TelegramException
(
'Data is empty!'
);
}
}
$result
=
self
::
send
(
'sendChatAction'
,
$data
);
return
self
::
send
(
'sendChatAction'
,
$data
);
return
$result
;
}
}
public
static
function
getUserProfilePhotos
(
$data
)
/**
* Get user profile photos
*
* @param array $data
* @return mixed
*/
public
static
function
getUserProfilePhotos
(
array
$data
)
{
{
if
(
empty
(
$data
))
{
if
(
empty
(
$data
))
{
throw
new
TelegramException
(
'Data is empty!'
);
throw
new
TelegramException
(
'Data is empty!'
);
}
}
if
(
!
isset
(
$data
[
'user_id'
]))
{
if
(
!
isset
(
$data
[
'user_id'
]))
{
throw
new
TelegramException
(
'User id is empty!'
);
throw
new
TelegramException
(
'User id is empty!'
);
}
}
$result
=
self
::
send
(
'getUserProfilePhotos'
,
$data
);
return
self
::
send
(
'getUserProfilePhotos'
,
$data
);
return
$result
;
}
}
public
static
function
getUpdates
(
$data
)
/**
* Get updates
*
* @param array $data
* @return mixed
*/
public
static
function
getUpdates
(
array
$data
)
{
{
$result
=
self
::
send
(
'getUpdates'
,
$data
);
return
self
::
send
(
'getUpdates'
,
$data
);
return
$result
;
}
}
/**
* Set webhook
*
* @param string $url
* @param string $file
* @return mixed
*/
public
static
function
setWebhook
(
$url
=
''
,
$file
=
null
)
public
static
function
setWebhook
(
$url
=
''
,
$file
=
null
)
{
{
$data
[
'url'
]
=
$url
;
$data
=
[
'url'
=>
$url
]
;
if
(
!
is_null
(
$file
))
{
if
(
!
is_null
(
$file
))
{
$data
[
'certificate'
]
=
self
::
encodeFile
(
$file
);
$data
[
'certificate'
]
=
self
::
encodeFile
(
$file
);
}
}
$result
=
self
::
send
(
'setWebhook'
,
$data
);
return
self
::
send
(
'setWebhook'
,
$data
);
return
$result
;
}
}
/**
public
static
function
getFile
(
$data
)
* Get file
*
* @param array $data
* @return mixed
*/
public
static
function
getFile
(
array
$data
)
{
{
if
(
empty
(
$data
))
{
if
(
empty
(
$data
))
{
throw
new
TelegramException
(
'Data is empty!'
);
throw
new
TelegramException
(
'Data is empty!'
);
}
}
$result
=
self
::
send
(
'getFile'
,
$data
);
return
self
::
send
(
'getFile'
,
$data
);
return
$result
;
}
}
public
static
function
answerInlineQuery
(
$data
)
/**
* Answer inline query
*
* @param array $data
* @return mixed
*/
public
static
function
answerInlineQuery
(
array
$data
)
{
{
if
(
empty
(
$data
))
{
if
(
empty
(
$data
))
{
throw
new
TelegramException
(
'Data is empty!'
);
throw
new
TelegramException
(
'Data is empty!'
);
}
}
$result
=
self
::
send
(
'answerInlineQuery'
,
$data
);
return
self
::
send
(
'answerInlineQuery'
,
$data
);
return
$result
;
}
}
/**
/**
* Send Message in all the active chat
* Send message to all active chats
*
*
*
* @return bool
* @param string $callback_function
* @param array $data
* @param boolean $send_groups
* @param boolean $send_super_groups
* @param boolean $send_users
* @param string $date_from
* @param string $date_to
* @return array
*/
*/
public
static
function
sendToActiveChats
(
public
static
function
sendToActiveChats
(
$callback_function
,
$callback_function
,
array
$data
,
array
$data
,
...
@@ -448,10 +613,9 @@ class Request
...
@@ -448,10 +613,9 @@ class Request
$date_from
=
null
,
$date_from
=
null
,
$date_to
=
null
$date_to
=
null
)
{
)
{
$callback_path
=
__NAMESPACE__
.
'\Request'
;
$callback_path
=
__NAMESPACE__
.
'\Request'
;
if
(
!
method_exists
(
$callback_path
,
$callback_function
))
{
if
(
!
method_exists
(
$callback_path
,
$callback_function
))
{
throw
new
TelegramException
(
'Method "'
.
$callback_function
.
'" not found in class Request.'
);
throw
new
TelegramException
(
'Methods: '
.
$callback_function
.
' not found in class Request.'
);
}
}
$chats
=
DB
::
selectChats
(
$send_groups
,
$send_super_groups
,
$send_users
,
$date_from
,
$date_to
);
$chats
=
DB
::
selectChats
(
$send_groups
,
$send_super_groups
,
$send_users
,
$date_from
,
$date_to
);
...
@@ -459,7 +623,7 @@ class Request
...
@@ -459,7 +623,7 @@ class Request
$results
=
[];
$results
=
[];
foreach
(
$chats
as
$row
)
{
foreach
(
$chats
as
$row
)
{
$data
[
'chat_id'
]
=
$row
[
'chat_id'
];
$data
[
'chat_id'
]
=
$row
[
'chat_id'
];
$results
[]
=
call_user_func_array
(
$callback_path
.
'::'
.
$callback_function
,
array
(
$data
)
);
$results
[]
=
call_user_func_array
(
$callback_path
.
'::'
.
$callback_function
,
[
$data
]
);
}
}
return
$results
;
return
$results
;
...
...
Write
Preview
Markdown
is supported
0%
Try again
or
attach a new file
Attach a file
Cancel
You are about to add
0
people
to the discussion. Proceed with caution.
Finish editing this message first!
Cancel
Please
register
or
sign in
to comment